Class OverSIP::SIP::Request
An instance of the OverSIP::SIP::Request
class contains a parsed SIP request.
Parent class
OverSIP::SIP::Request
inherits all the methods of OverSIP::SIP::Message
.
Included modules
The following modules add methods into the OverSIP::SIP::Request
class:
Class instance methods
ruri
Gets the Request-URI parsed as a OverSIP::SIP::Uri
instance.
NOTE: If the fields of the OverSIP::SIP::Uri
instance are modified then the Request-URI will be rewritten when the request is forwarded and OverSIP will check the new Request-URI for retrieving the destination of the request (unless there is a top Route header or an explicit destination is given to the route()
method of the OverSIP::SIP::Proxy
instance).
Example
request.ruri.user
#=> "bob"
ruri=
(uri)
Replaces the Request-URI of the request with the given uri
.
uri
- Can be a
String
, aOverSIP::SIP::Uri
or aOverSIP::SIP::NameAddr
.
In case of passing a String
as uri
parameter such a value is parsed and verified to be a valid SIP URI.
Examples
request.ruri = "sip:ibc@aliax.net"
request.ruri = OverSIP::SIP::Uri.new(:sip, "ibc", "aliax.net")
initial?
Returns true
if the request has no To ;tag
parameter.
in_dialog?
Returns true
if the request has To ;tag
parameter.
secure?
Returns true
if the request’s transport
is :tls
or :wss
.
outgoing_outbound_requested?
Returns true
if the request asks for Outbound assistance (or fix_nat()
method has been previously called).
incoming_outbound_requested?
Returns true
if the request destination is an Outbound connection established by another client.
reply
(status_code, reason_phrase=nil, extra_headers=[], body=nil)
Generate a SIP response for this SIP request which is sent stateful if a server transaction exists for this request or stateless otherwise.
Parameters
status_code
- The response status code (
Fixnum
). reason_phrase
- The reason phrase (
String
) for the response (by default the standard reason phrase for the given status code). extra_headers
- An
Array
of extra headers (Strings
) to append to the response. body
- The body (
String
) for the response.
Examples
request.reply 404
request.reply 501, "Method #{request.sip_method} not implemented"
request.reply 403, "Not Allowed", ["Content-Type: text/plain", "X-Reason: foo"], "Sorry, request not allowed"
tvars
Transaction variables. A Hash
for storing custom key / values associated to the client transaction initiated by OverSIP if this request is forwarded. The same Hash
can be later retrieved from the SIP responses replied by peers for this request via the same instance method tvars
of the OverSIP::SIP::Response
class.
Example
request.tvars[:time] = Time.now
proxy = ::OverSIP::SIP::Proxy.new
proxy.on_success_response do |response|
log_info "2XX response for a request sent at #{response.tvars[:time]}"
end
proxy.route request
cvars
Connection variables. A Hash
for storing custom key / values associated to the connection (OverSIP::SIP::Connection
or OverSIP::WebSocket::Connection
) from which the request has been received.
Example
request.cvars[:trusted_ip] = true