List of SIP response codes
The Session Initiation Protocol (SIP) is a signalling protocol used for controlling communication sessions such as Voice over IP telephone calls. SIP is based around request/response transactions, in a similar manner to the Hypertext Transfer Protocol (HTTP). Each transaction consists of a SIP request (which will be one of several request methods), and at least one response.[1]:p11
SIP requests and responses may be generated by any SIP user agent; user agents are divided into clients (UACs), which initiate requests, and servers (UASes), which respond to them.[1]:§8 A single user agent may act as both UAC and UAS for different transactions:[1]:p26 for example, a SIP phone is a user agent that will be a UAC when making a call, and a UAS when receiving one. Additionally, some devices will act as both UAC and UAS for a single transaction; these are called Back-to-Back User Agents (B2BUAs).[1]:p20
SIP responses specify a three-digit integer response code, which is one of a number of defined codes that detail the status of the request. These codes are grouped according to their first digit as "provisional", "success", "redirection", "client error", "server error" or "global failure" codes, corresponding to a first digit of 1–6; these are expressed as, for example, "1xx" for provisional responses with a code of 100–199.[1]:§7.2 The SIP response codes are an extension to the HTTP response codes, although not all HTTP response codes are valid in SIP.[1]:§21
SIP responses also specify a "reason phrase", and a default reason phrase is defined with each response code.[1]:§7.2 These reason phrases can be varied, however, such as to provide additional information[1]:§21.4.18 or to provide the text in a different language.[1]:§20.3
SIP, including the response codes and corresponding reason phrases, is defined in Internet Engineering Task Force (IETF) Requests for Comments (RFCs), namely RFC 3261.[2] That RFC includes provisions for later RFCs to update the specification.[1]:§8.1.1.9 Specific parts of the SIP protocol, including response codes and their default reason phrases, are registered with the Internet Assigned Numbers Authority (IANA).[1]:§27[3]
This list details all the SIP response codes defined in IETF RFCs and registered with the IANA as of 18 April 2013. It also includes SIP response codes defined in obsolete SIP RFCs (specifically, RFC 2543), which are therefore not registered with the IANA; these are explicitly noted as such.
1xx—Provisional Responses
- 100 Trying
- Extended search being performed may take a significant time so a forking proxy must send a 100 Trying response.[1]:§21.1.1
- 180 Ringing
- Destination user agent received INVITE, and is alerting user of call.[1]:§21.1.2
- 181 Call is Being Forwarded
- Servers can optionally send this response to indicate a call is being forwarded.[1]:§21.1.3
- 182 Queued
- Indicates that the destination was temporarily unavailable, so the server has queued the call until the destination is available. A server may send multiple 182 responses to update progress of the queue.[1]:§21.1.4
- 183 Session in Progress
- This response may be used to send extra information for a call which is still being set up.[1]:§21.1.5
- 199 Early Dialog Terminated
- Can be used by User Agent Server to indicate to upstream SIP entities (including the User Agent Client (UAC)) that an early dialog has been terminated.[4]
2xx—Successful Responses
- 200 OK
- Indicates the request was successful.[1]:§21.2.1
- 202 Accepted
- Indicates that the request has been accepted for processing, but the processing has not been completed.[5]:§7.3.1[6] Deprecated.[7]:§8.3.1[3]
- 204 No Notification
- Indicates the request was successful, but the corresponding response will not be received.[8]
3xx—Redirection Responses
- 300 Multiple Choices
- The address resolved to one of several options for the user or client to choose between, which are listed in the message body or the message's Contact fields.[1]:§21.3.1
- 301 Moved Permanently
- The original Request-URI is no longer valid, the new address is given in the Contact header field, and the client should update any records of the original Request-URI with the new value.[1]:§21.3.2
- 302 Moved Temporarily
- The client should try at the address in the Contact field. If an Expires field is present, the client may cache the result for that period of time.[1]:§21.3.3
- 305 Use Proxy
- The Contact field details a proxy that must be used to access the requested destination.[1]:§21.3.4
- 380 Alternative Service
- The call failed, but alternatives are detailed in the message body.[1]:§21.3.5
4xx—Client Failure Responses
- 400 Bad Request
- The request could not be understood due to malformed syntax.[1]:§21.4.1
- 401 Unauthorized
- The request requires user authentication. This response is issued by UASs and registrars.[1]:§21.4.2
- 402 Payment Required
- Reserved for future use.[1]:§21.4.3
- 403 Forbidden
- The server understood the request, but is refusing to fulfil it.[1]:§21.4.4 Sometimes (but not always) this means the call has been rejected by the receiver.
- 404 Not Found
- The server has definitive information that the user does not exist at the domain specified in the Request-URI. This status is also returned if the domain in the Request-URI does not match any of the domains handled by the recipient of the request.[1]:§21.4.5
- 405 Method Not Allowed
- The method specified in the Request-Line is understood, but not allowed for the address identified by the Request-URI.[1]:§21.4.6
- 406 Not Acceptable
- The resource identified by the request is only capable of generating response entities that have content characteristics but not acceptable according to the Accept header field sent in the request.[1]:§21.4.7
- 407 Proxy Authentication Required
- The request requires user authentication. This response is issued by proxys.[1]:§21.4.8
- 408 Request Timeout
- Couldn't find the user in time. The server could not produce a response within a suitable amount of time, for example, if it could not determine the location of the user in time. The client MAY repeat the request without modifications at any later time. [1]:§21.4.9
- 409 Conflict
- User already registered.[9]:§7.4.10 Deprecated by omission from later RFCs[1] and by non-registration with the IANA.[3]
- 410 Gone
- The user existed once, but is not available here any more.[1]:§21.4.10
- 411 Length Required
- The server will not accept the request without a valid Content-Length.[9]:§7.4.12 Deprecated by omission from later RFCs[1] and by non-registration with the IANA.[3]
- 412 Conditional Request Failed
- The given precondition has not been met.[10]
- 413 Request Entity Too Large
- Request body too large.[1]:§21.4.11
- 414 Request-URI Too Long
- The server is refusing to service the request because the Request-URI is longer than the server is willing to interpret.[1]:§21.4.12
- 415 Unsupported Media Type
- Request body in a format not supported.[1]:§21.4.13
- 416 Unsupported URI Scheme
- Request-URI is unknown to the server.[1]:§21.4.14
- 417 Unknown Resource-Priority
- There was a resource-priority option tag, but no Resource-Priority header.[11]
- 420 Bad Extension
- Bad SIP Protocol Extension used, not understood by the server.[1]:§21.4.15
- 421 Extension Required
- The server needs a specific extension not listed in the Supported header.[1]:§21.4.16
- 422 Session Interval Too Small
- The received request contains a Session-Expires header field with a duration below the minimum timer.[12]
- 423 Interval Too Brief
- Expiration time of the resource is too short.[1]:§21.4.17
- 424 Bad Location Information
- The request's location content was malformed or otherwise unsatisfactory.[13]
- 428 Use Identity Header
- The server policy requires an Identity header, and one has not been provided.[14]:p11
- 429 Provide Referrer Identity
- The server did not receive a valid Referred-By token on the request.[15]
- 430 Flow Failed
- A specific flow to a user agent has failed, although other flows may succeed. This response is intended for use between proxy devices, and should not be seen by an endpoint (and if it is seen by one, should be treated as a 400 Bad Request response).[16]:§11.5
- 433 Anonymity Disallowed
- The request has been rejected because it was anonymous.[17]
- 436 Bad Identity-Info
- The request has an Identity-Info header, and the URI scheme in that header cannot be dereferenced.[14]:p11
- 437 Unsupported Certificate
- The server was unable to validate a certificate for the domain that signed the request.[14]:p11
- 438 Invalid Identity Header
- The server obtained a valid certificate that the request claimed was used to sign the request, but was unable to verify that signature.[14]:p12
- 439 First Hop Lacks Outbound Support
- The first outbound proxy the user is attempting to register through does not support the "outbound" feature of RFC 5626, although the registrar does.[16]:§11.6
- 470 Consent Needed
- The source of the request did not have the permission of the recipient to make such a request.[18]
- 480 Temporarily Unavailable
- Callee currently unavailable.[1]:§21.4.18
- 481 Call/Transaction Does Not Exist
- Server received a request that does not match any dialog or transaction.[1]:§21.4.19
- 482 Loop Detected.
- Server has detected a loop.[1]:§21.4.20
- 483 Too Many Hops
- Max-Forwards header has reached the value '0'.[1]:§21.4.21
- 484 Address Incomplete
- Request-URI incomplete.[1]:§21.4.22
- 485 Ambiguous
- Request-URI is ambiguous.[1]:§21.4.23
- 486 Busy Here
- Callee is busy.[1]:§21.4.24
- 487 Request Terminated
- Request has terminated by bye or cancel.[1]:§21.4.25
- 488 Not Acceptable Here
- Some aspect of the session description or the Request-URI is not acceptable.[1]:§21.4.26
- 489 Bad Event
- The server did not understand an event package specified in an Event header field.[5]:§7.3.2[7]:§8.3.2
- 491 Request Pending
- Server has some pending request from the same dialog.[1]:§21.4.27
- 493 Undecipherable
- Request contains an encrypted MIME body, which recipient can not decrypt.[1]:§21.4.28
- 494 Security Agreement Required
- The server has received a request that requires a negotiated security mechanism, and the response contains a list of suitable security mechanisms for the requester to choose between,[19]:§§2.3.1–2.3.2 or a digest authentication challenge.[19]:§2.4
5xx—Server Failure Responses
- 500 Server Internal Error
- The server could not fulfill the request due to some unexpected condition.[1]:§21.5.1
- 501 Not Implemented
- The server does not have the ability to fulfill the request, such as because it does not recognize the request method. (Compare with 405 Method Not Allowed, where the server recognizes the method but does not allow or support it.)[1]:§21.5.2
- 502 Bad Gateway
- The server is acting as a gateway or proxy, and received an invalid response from a downstream server while attempting to fulfill the request.[1]:§21.5.3
- 503 Service Unavailable
- The server is undergoing maintenance or is temporarily overloaded and so cannot process the request. A "Retry-After" header field may specify when the client may reattempt its request.[1]:§21.5.4
- 504 Server Time-out
- The server attempted to access another server in attempting to process the request, and did not receive a prompt response.[1]:§21.5.5
- 505 Version Not Supported
- The SIP protocol version in the request is not supported by the server.[1]:§21.5.6
- 513 Message Too Large
- The request message length is longer than the server can process.[1]:§21.5.7
- 580 Precondition Failure
- The server is unable or unwilling to meet some constraints specified in the offer.[20]
6xx—Global Failure Responses
- 600 Busy Everywhere
- All possible destinations are busy. Unlike the 486 response, this response indicates the destination knows there are no alternative destinations (such as a voicemail server) able to accept the call.[1]:§21.6.1
- 603 Decline
- The destination does not wish to participate in the call, or cannot do so, and additionally the destination knows there are no alternative destinations (such as a voicemail server) willing to accept the call.[1]:§21.6.2
- 604 Does Not Exist Anywhere
- The server has authoritative information that the requested user does not exist anywhere.[1]:§21.6.3
- 606 Not Acceptable
- The user's agent was contacted successfully but some aspects of the session description such as the requested media, bandwidth, or addressing style were not acceptable.[1]:§21.6.4
References
- 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 Rosenberg, Jonathan; Schulzrinne, Henning; Camarillo, Gonzalo; Johnston, Alan; Peterson, Jon; Sparks, Robert; Handley, Mark; Schooler, Eve (June 2002). SIP: Session Initiation Protocol. IETF. RFC 3261. https://tools.ietf.org/html/rfc3261.
- ↑ Camarillo, Gonzalo; García-Martín, Miguel A. (2008). The 3G IP Multimedia Subsystem (IMS) (3rd ed.). Wiley. pp. 12–13,30. ISBN 978-0-470-51662-1.
- 1 2 3 4 Roach, Adam; Jennings, Cullen; Peterson, Jon; Barnes, Mary (17 April 2013) [Created January 2002]. "Response Codes". Session Initiation Protocol (SIP) Parameters. IANA. External link in
|work=
(help) - ↑ Holmberg, Christer (May 2011). Session Initiation Protocol (SIP) Response Code for Indication of Terminated Dialog. IETF. p. 1. Abstract. RFC 6228. https://tools.ietf.org/html/rfc6228#section-Abstract.
- 1 2 Roach, Adam B. (June 2002). Session Initiation Protocol (SIP)-Specific Event Notification. IETF. RFC 3265. https://tools.ietf.org/html/rfc3265.
- ↑ Fielding, Roy T.; Gettys, James; Mogul, Jeffrey C.; Nielsen, Henrik Frystyk; Masinter, Larry; Leach, Paul; Berners-Lee, Tim (June 1999). "202 Accepted". Hypertext Transfer Protocol -- HTTP/1.1. IETF. sec. 10.2.3. RFC 2616. https://tools.ietf.org/html/rfc2616#section-10.2.3.
- 1 2 Roach, Adam (July 2012). SIP-Specific Event Notification. IETF. RFC 6665. https://tools.ietf.org/html/rfc6665.
- ↑ Niemi, Aki (May 2010). "204 (No Notification) Response Code". In Willis, Dean. An Extension to Session Initiation Protocol (SIP) Events for Conditional Event Notification. IETF. sec. 7.1. RFC 5839. https://tools.ietf.org/html/rfc5839#section-7.1.
- 1 2 Handley, Mark; Schulzrinne, Henning; Schooler, Eve; Rosenberg, Jonathan (March 1999). SIP: Session Initiation Protocol. IETF. RFC 2543. https://tools.ietf.org/html/rfc2543.
- ↑ Niemi, Aki, ed. (October 2004). ""412 Conditional Requset Failed" Response Code". Session Initiation Protocol (SIP) Extension for Event State Publication. IETF. sec. 11.2.1. RFC 3903. https://tools.ietf.org/html/rfc3903#section-11.2.1.
- ↑ Schulzrinne, Henning; Polk, James (February 2006). "No Known Namespace or Priority Value". Communications Resource Priority for the Session Initiation Protocol (SIP). IETF. sec. 4.6.2. RFC 4412. https://tools.ietf.org/html/rfc4412#section-4.6.2.
- ↑ Donovan, Steve; Rosenberg, Jonathan (April 2005). "422 Response Code Definition". Session Timers in the Session Initiation Protocol (SIP). IETF. sec. 6. RFC 4028. https://tools.ietf.org/html/rfc4028#section-6.
- ↑ Polk, James; Rosen, Brian; Peterson, Jon (December 2011). "424 (Bad Location Information) Response Code". Location Conveyance for the Session Initiation Protocol. IETF. sec. 4.3. RFC 6442. https://tools.ietf.org/html/rfc6442#section-4.3.
- 1 2 3 4 Peterson, Jon; Jennings, Cullen (August 2006). Enhancements for Authenticated Identity Management in the Session Initiation Protocol (SIP). IETF. RFC 4474. https://tools.ietf.org/html/rfc4474.
- ↑ Sparks, Robert J. (September 2004). "The 429 Provide Referrer Identity Error Response". The Session Initiation Protocol (SIP) Referred-By Mechanism. IETF. sec. 5. RFC 3892. https://tools.ietf.org/html/rfc3892#section-5.
- 1 2 Jennings, Cullen; Mahy, Rohan; Audet, Francois, eds. (October 2009). Managing Client-Initiated Connections in the Session Initiation Protocol (SIP). IETF. RFC 5626. https://tools.ietf.org/html/rfc5626.
- ↑ Rosenberg, Jonathan (December 2007). "433 (Anonymity Disallowed) Definition". Rejecting Anonymous Requests in the Session Initiation Protocol (SIP). IETF. sec. 5. RFC 5079. https://tools.ietf.org/html/rfc5079#section-5.
- ↑ Rosenberg, Jonathan; Willis, Dean (October 2008). "Definition of the 470 Response Code". In Camarillo, Gonzalo. A Framework for Consent-Based Communications in the Session Initiation Protocol (SIP). IETF. sec. 5.9.2. RFC 5360. https://tools.ietf.org/html/rfc5360#section-5.9.2.
- 1 2 Arkko, Jari; Torvinen, Vesa; Camarillo, Gonzalo; Niemi, Aki; Haukka, Tao (January 2003). Security Mechanism Agreement for the Session Initiation Protocol (SIP). IETF. RFC 3329. https://tools.ietf.org/html/rfc3329.
- ↑ Rosenberg, Jonathan (October 2002). "Refusing an offer". In Camarillo, Gonzalo; Marshall, Bill. Integration of Resource Management and Session Initiation Protocol (SIP). IETF. sec. 8. RFC 3312. https://tools.ietf.org/html/rfc3312#section-8.
External links
- Mapping SIP Error Messages to DSS1 codes
- Session Initiation Protocol (SIP) Parameters Contains a registry of different SIP parameters, including response codes