Project

General

Profile

Sip register » History » Version 22

Adrian Georgescu, 03/28/2009 12:39 PM

1 16 Adrian Georgescu
== sip_register ==
2 1 Adrian Georgescu
3 17 Adrian Georgescu
[[TOC(SipTesting*, sip_*, depth=2)]]
4
5 18 Adrian Georgescu
To use this script you must to have a valid [wiki:SipSettingsAPI configuration].
6 2 Adrian Georgescu
7 21 Adrian Georgescu
[[Image(http://www.tech-invite.com/img/cf3665/cf3665-2x.gif, align=right)]]
8 19 Adrian Georgescu
9 16 Adrian Georgescu
=== Description ===
10 6 Adrian Georgescu
11 12 Adrian Georgescu
SIP protocol offers a discovery capability. If a user wants to initiate a session
12
with another user, he must discover the current host(s) at which the
13 8 Adrian Georgescu
destination user is reachable. To do this, SIP network elements consult an
14
abstract service known as a location service, which provides address
15
bindings for a particular domain. Registration entails sending a REGISTER
16
request to a special type of UAS known as a registrar.  A registrar acts as
17
the front end to the location service for a domain, reading and writing
18
mappings based on the contents of REGISTER requests. This location service
19
is then typically consulted by a proxy server that is responsible for
20
routing requests for that domain.
21
22
This script implements REGISTER method, which registers the contact (ip:port
23
address) for a given address of record (SIP address).
24
25 6 Adrian Georgescu
Source code: [source:scripts/sip_register.py scripts/sip_register.py]
26 3 Adrian Georgescu
27 1 Adrian Georgescu
{{{
28 22 Adrian Georgescu
adigeo@ag-imac3:~$sip_register -h
29
Usage: sip_register [options]
30 1 Adrian Georgescu
31
This script will register a SIP account to a SIP registrar and refresh it
32
while the program is running. When Ctrl+D is pressed it will unregister.
33
34
Options:
35
  -h, --help            show this help message and exit
36
  -a ACCOUNT_NAME, --account-name=ACCOUNT_NAME
37
                        The account name from which to read account settings.
38
                        Corresponds to section Account_NAME in the
39
                        configuration file.
40
  -s, --trace-sip       Dump the raw contents of incoming and outgoing SIP
41
                        messages (disabled by default).
42 22 Adrian Georgescu
  -j, --trace-pjsip     Print PJSIP logging output (disabled by default).
43 1 Adrian Georgescu
  -r MAX_REGISTERS, --max-registers=MAX_REGISTERS
44 22 Adrian Georgescu
                        Max number of REGISTERs sent (default 1, set to 0 for
45
                        infinite).
46 7 Adrian Georgescu
}}}
47 1 Adrian Georgescu
48
=== Example ===
49
50
{{{
51 22 Adrian Georgescu
adigeo@ag-imac3:~$sip_register   
52
Using account 31208005169@ag-projects.com
53
Registration succeeded at 85.17.186.7:5060;transport=udp.
54
Contact: sip:xqdwrctb@192.168.1.6:58481 (expires in 600 seconds).
55 1 Adrian Georgescu
Other registered contacts:
56 22 Adrian Georgescu
  sip:31208005169@192.168.1.123:5060 (expires in 262 seconds)
57
  sip:31208005169@192.168.1.122:5062;line=634g6j67 (expires in 360 seconds)
58
  sip:31208005169@192.168.1.1;uniq=5B2860C44383A3D6705629A7E1FB8 (expires in 734 seconds)
59
Registration ended: 200 OK.
60 1 Adrian Georgescu
}}}