SIP Tutorial on SIP Messaging

sip messages are of two types − requests and responses.

  • the opening line of a request contains a method that defines the request, and a request-uri that defines where the request is to be sent.

  • similarly, the opening line of a response contains a response code.

request methods

sip requests are the codes used to establish a communication. to complement them, there are sip responses that generally indicate whether a request succeeded or failed.

these sip requests which are known as methods make sip message workable.

  • methods can be regarded as sip requests, since they request a specific action to be taken by another user agent or server.

  • methods are distinguished into two types −

    • core methods

    • extension methods

core methods

there are six core methods as discussed below.

invite

invite is used to initiate a session with a user agent. in other words, an invite method is used to establish a media session between the user agents.

  • invite can contain the media information of the caller in the message body.

  • a session is considered established if an invite has received a success response(2xx) or an ack has been sent.

  • invite
  • a successful invite request establishes a dialog between the two user agents which continues until a bye is sent to terminate the session.

  • an invite sent within an established dialog is known as a re-invite.

  • re-invite is used to change the session characteristics or refresh the state of a dialog.

invite example

the following code shows how invite is used.

invite sips:bob@tmc.com sip/2.0 
   via: sip/2.0/tls client.anc.com:5061;branch = z9hg4bk74bf9 
   max-forwards: 70 
   from: alice<sips:alice@ttp.com>;tag = 1234567 
   to: bob<sips:bob@tmc.com>
   call-id: 12345601@192.168.2.1  
   cseq: 1 invite 
   contact: <sips:alice@client.anc.com> 
   allow: invite, ack, cancel, options, bye, refer, notify 
   supported: replaces 
   content-type: application/sdp 
   content-length: ...  
   
   v = 0 
   o = alice 2890844526 2890844526 in ip4 client.anc.com 
   s = session sdp 
   c = in ip4 client.anc.com 
   t = 3034423619 0 
   m = audio 49170 rtp/avp 0 
   a = rtpmap:0 pcmu/8000 

bye

bye is the method used to terminate an established session. this is a sip request that can be sent by either the caller or the callee to end a session.

  • it cannot be sent by a proxy server.

  • bye request normally routes end to end, bypassing the proxy server.

  • bye cannot be sent to a pending an invite or an unestablished session.

register

register request performs the registration of a user agent. this request is sent by a user agent to a registrar server.

  • the register request may be forwarded or proxied until it reaches an authoritative registrar of the specified domain.

  • it carries the aor (address of record) in the to header of the user that is being registered.

  • register request contains the time period (3600sec).

  • one user agent can send a register request on behalf of another user agent. this is known as third-party registration. here, the from tag contains the uri of the party submitting the registration on behalf of the party identified in the to header.

cancel

cancel is used to terminate a session which is not established. user agents use this request to cancel a pending call attempt initiated earlier.

  • it can be sent either by a user agent or a proxy server.

  • cancel is a hop by hop request, i.e., it goes through the elements between the user agent and receives the response generated by the next stateful element.

hop by hop

ack

ack is used to acknowledge the final responses to an invite method. an ack always goes in the direction of invite.ack may contain sdp body (media characteristics), if it is not available in invite.

sdp ack
  • ack may not be used to modify the media description that has already been sent in the initial invite.

sdp acknowledgement
  • a stateful proxy receiving an ack must determine whether or not the ack should be forwarded downstream to another proxy or user agent.

  • for 2xx responses, ack is end to end, but for all other final responses, it works on hop by hop basis when stateful proxies are involved.

options

options method is used to query a user agent or a proxy server about its capabilities and discover its current availability. the response to a request lists the capabilities of the user agent or server. a proxy never generates an options request.

extension methods

subscribe

subscribe is used by user agents to establish a subscription for the purpose of getting notification about a particular event.

  • it contains an expires header field that indicates the duration of a subscription.

  • after the time period passes, the subscription will automatically terminate.

  • subscription establishes a dialog between the user agents.

  • you can re-subscription again by sending another subscribe within the dialog before the expiration time.

  • a 200 ok will be received for a subscription from user.

  • users can unsubscribe by sending another subscribe method with expires value 0(zero).

example subscribe

notify

notify is used by user agents to get the occurrence of a particular event. usually a notify will trigger within a dialog when a subscription exists between the subscriber and the notifier.

  • every notify will get 200 ok response if it is received by notifier.

  • notify contain an event header field indicating the event and a subscriptionstate header field indicating the current state of the subscription.

  • a notify is always sent at the start and termination of a subscription.

publish

publish is used by a user agent to send event state information to a server.

publish
  • publish is mostly useful when there are multiple sources of event information.

  • a publish request is similar to a notify, except that it is not sent in a dialog.

  • a publish request must contain an expires header field and a min-expires header field.

refer

refer is used by a user agent to refer another user agent to access a uri for the dialog.

  • refer must contain a refer-to header. this is a mandatory header for refer.

  • refer can be sent inside or outside a dialog.

  • a 202 accepted will trigger a refer request which indicates that other user agent has accepted the reference.

info

info is used by a user agent to send call signalling information to another user agent with which it has established a media session.

  • this is an end-to-end request.

  • a proxy will always forward an info request.

update

update is used to modify the state of a session if a session is not established. user could change the codec with update.

update

if a session is established, a re-invite is used to change/update the session.

prack

prack is used to acknowledge the receipt of a reliable transfer of provisional response (1xx).

  • generally prack is generated by a client when it receive a provisional response containing an rseq reliable sequence number and a supported:100rel header.

  • prack contains (rseq &plus; cseq) value in the rack header.

  • the prack method applies to all provisional responses except the 100 trying response, which is never reliably transported.

  • a prack may contain a message body; it may be used for offer/answer exchange.

message

it is used to send an instant message using sip. an im usually consists of short messages exchanged in real time by participants engaged in text conversation.

message
  • message can be sent within a dialog or outside a dialog.

  • the contents of a message are carried in the message body as a mime attachment.

  • a 200 ok response is normally received to indicate that the message has been delivered at its destination.