SipDeveloperGuide

Version 79 (Adrian Georgescu, 03/14/2010 01:05 pm)

1 61 Adrian Georgescu
= Developer Guide =
2 1 Adrian Georgescu
3 1 Adrian Georgescu
[[TOC(WikiStart, Sip*, depth=2)]]
4 1 Adrian Georgescu
5 73 Adrian Georgescu
The goal of SIP SIMPLE client SDK is to provide a simple to use API to create Real Time Communications Applications for Internet end-points based on SIP and related protocols.
6 1 Adrian Georgescu
7 73 Adrian Georgescu
By using this API you can add Audio, Instant Messaging, File Transfer capabilities to and existing product or create a new product from scratch.
8 73 Adrian Georgescu
9 41 Adrian Georgescu
== Prerequisites ==
10 41 Adrian Georgescu
11 79 Adrian Georgescu
To use SIP SIMPLE client SDK and the concepts described below you must be familiar with Python programming language and have basic [http://www.tech-invite.com/Ti-sip-ex3261.html SIP knowledge]. Understanding of TCP/IP networking in general and real time application development in particular are strongly recommended.
12 1 Adrian Georgescu
13 79 Adrian Georgescu
Detailed instructions for installing the SDK are found [wiki:SipInstallation here].
14 11 Adrian Georgescu
15 1 Adrian Georgescu
== Middleware ==
16 1 Adrian Georgescu
17 79 Adrian Georgescu
To develop your SIP client Application you should use the Middleware API that hides the complexity and the interactions of the low level SIP, SDP, RTP, ICE, MSRP, XCAP protocols. With a minimal amount of coding you can create a rich client for setting up Audio, Instant Messaging, File Transfer and Desktop Sharing sessions.
18 1 Adrian Georgescu
19 67 Adrian Georgescu
 * [wiki:SipMiddlewareApi Middleware API] - middleware for developing of SIP Client Applications
20 1 Adrian Georgescu
 * [wiki:SipConfigurationAPI Configuration API] - used for managing the settings used by the Middleware
21 1 Adrian Georgescu
22 1 Adrian Georgescu
=== Sample Code ===
23 76 Adrian Georgescu
24 1 Adrian Georgescu
 *  [wiki:SipTesting Command Line Tools] provide detailed practical examples for how to use all functions available in the SDK
25 79 Adrian Georgescu
 * SIP SIMPLE client SDK is used by [http://icanblink.com Blink], a fully featured and easy to use SIP client or MacOSX
26 1 Adrian Georgescu
27 50 Adrian Georgescu
=== Components ===
28 1 Adrian Georgescu
29 79 Adrian Georgescu
If you wish to develop your own middleware or application while having full control over the underlying protocol layers yourself, you can use the following APIs that provide granular control over their respective components:
30 1 Adrian Georgescu
31 77 Adrian Georgescu
 * [wiki:SipCoreApiDocumentation SIP Core API] - SIP, RTP, ICE and Audio Engine including cross platform audio-device abstraction, codecs and jitter buffer
32 77 Adrian Georgescu
 * [wiki:SipMSRPApi MSRP API]  - Message Session Relay Protocol (MSRP) and its Relay Extension
33 77 Adrian Georgescu
 * [wiki:SipPresenceApi Presence API]  - Payloads carried within SIP signaling used for publication, subscription and notifications of SIP events
34 77 Adrian Georgescu
 * [wiki:SipXCAPApi XCAP API]  - Manage presence policy documents on XCAP servers
35 69 Adrian Georgescu
36 1 Adrian Georgescu
You may use for example the above components API to create SIP Server Applications, something the high level middleware was not designed for.
37 43 Adrian Georgescu
38 65 Adrian Georgescu
== Network ==
39 1 Adrian Georgescu
40 72 Adrian Georgescu
To use a SIP Application you need access to the Internet. The following ports are being used:
41 43 Adrian Georgescu
42 43 Adrian Georgescu
|| '''Local port''' || '''Direction''' || '''Remote port''' || '''Protocol''' || '''Description''' || '''Allocation''' || '''Setting''' ||
43 64 Adrian Georgescu
|| 1xport >1024 || In/Out || Typically 5060 set in DNS|| UDP || [wiki:SipCoreApiDocumentation#Engine SIP over UDP] || At start || Global.sip.udp_port ||
44 64 Adrian Georgescu
|| 1xport >1024 || In/Out || Typically 5060 set in DNS ||TCP || [wiki:SipCoreApiDocumentation#Engine SIP over TCP] || At start ||Global.sip.tcp_port ||
45 64 Adrian Georgescu
|| 1xport >1024 || In/Out || Typically 5061  set in DNS ||TCP|| [wiki:SipCoreApiDocumentation#Engine SIP over TLS] || At start || Global.sip.tls_port ||
46 54 Adrian Georgescu
|| 2xport >1024 || In/Out || Random negotiated in SDP || UDP || [wiki:SipCoreApiDocumentation#RTPTransport RTP/RTCP stream] || Per session || Global.rtp.port_range ||
47 54 Adrian Georgescu
|| 1xport >1024 || In/Out || Typically 2855 negotiated in SDP || TCP || [wiki:SipMSRPApi#transport.MSRPTransport MSRP stream] || Per session || Global.msrp.local_port ||
48 57 Adrian Georgescu
|| 1xport >1024 || Out || Typically 443, configured || TCP || [wiki:SipXCAPApi XCAP requests] || Per request|| ||