Provisioning guide » History » Version 11
  Tijmen de Mes, 10/11/2012 04:05 PM 
  
| 1 | 1 | Tijmen de Mes | h1. Provisioning guide | 
|---|---|---|---|
| 2 | |||
| 3 | 2 | Tijmen de Mes | Provisioning of Multimedia Service Platform is performed by the NGNPro SOAP/XML provisioning server. To access the server you need a SOAP/XML client, either the web front-end that comes standard with the platform or one developed by the operator using the supplied SOAP/XML schema. | 
| 4 | 1 | Tijmen de Mes | |
| 5 | bq. The examples and screenshots presented in this document have been taken using AG Project developed NGNPro client part of CDRTool application and may differ from the actual deployment of each customer. Access to the hosted version of Multimedia Service Platform also exposes less functionality, some functions are only available to administrator account and not available to resellers. | ||
| 6 | |||
| 7 | |||
| 8 | |||
| 9 | It is the responsibility of the operator to build a web interface that talks to the SOAP/XML interface. The sample code provided with CDRTool application is merely an example for how to access the API and should not be used in production by customers. | ||
| 10 | |||
| 11 | h2. NGNPro Server | ||
| 12 | |||
| 13 | NGNPro server software provides a SOAP/XML provisioning interface that allows for the management of accounts along with all their auxiliary settings. | ||
| 14 | |||
| 15 | Using NGNPro SOAP/XML interface the Operator may build new front-ends or adapt the existing CRM, provisioning or support systems to the Multimedia Service Platform, making the integration easy and effective. SOAP/XML is an industry standard for which there are implementations available in almost any programming language (like C, Java, PHP and Python) and it can be used by web developers to create customized web portals for the Operator or its resellers without bothering with the complexity of the platform setup and the database schemas sitting behind. | ||
| 16 | |||
| 17 | The SOAP/XML provisioning API is described at: | ||
| 18 | |||
| 19 | "https://mdns.sipthor.net/ngnpro/wsdl":https://mdns.sipthor.net/ngnpro/wsdl | ||
| 20 | |||
| 21 | h3. SOAP/XML API | ||
| 22 | |||
| 23 | # SIP domain management (adding, removing and querying domains) | ||
| 24 | # SIP account management (adding, updating, deleting and getting a SIP account) | ||
| 25 | # SIP aliases (adding, deleting and getting SIP aliases for a given SIP account) | ||
| 26 | # Group membership management (granting, revoking or listing group membership) | ||
| 27 | # Voicemail account (adding, updating, removing or getting a voicemail account) | ||
| 28 | # Call diversions (setting or getting the diversions for a given user) | ||
| 29 | # Retrieving call information for a certain user (missed, placed, received calls) | ||
| 30 | # Retrieving the registered phones one user has (getting the user locations info) | ||
| 31 | # ENUM management (adding, removing and getting the ENUM mappings) | ||
| 32 | # LCR management (adding, removing and getting the PSTN routes and gateways) | ||
| 33 | |||
| 34 | 3 | Tijmen de Mes | !gNGNPro-Datatree.png! | 
| 35 | 1 | Tijmen de Mes | |
| 36 | h2. NGNPro Clients | ||
| 37 | |||
| 38 | Multimedia Service Platform comes with a fully featured provisioning client, which is part of CDRTool web application. The Operator may also chose to develop his own web portals to interface with Multimedia Service Platform by using the provided SOAP/XML schema. | ||
| 39 | |||
| 40 | h3. Python Client | ||
| 41 | |||
| 42 | 3 | Tijmen de Mes | To help the development of a custom client an "wsdl.tar.gz":/attachment/wiki/ProvisioningGuide/wsdl.tar.gz !/chrome/common/download.png(Download)! | 
| 43 | 1 | Tijmen de Mes | |
| 44 | Usage is simple and described in the WSDL.Proxy class docstring. In addition to what is mentioned there, you need to also specify the auth argument, which is a dictionary like: | ||
| 45 | |||
| 46 | bc(wiki). dict(username='myusername', password='mypassword') | ||
| 47 | |||
| 48 | |||
| 49 | The Proxy, will load the WSDL and add the methods from the specified port in the WSDL on the fly to the proxy instance that is created when you instantiate Proxy(). After the creation you can call the port methods directly on the proxy, so no code generation is needed. You can discover the available methods using inspection on the proxy instance as with any other python object. You pass simple data structures (strings, ints, lists, dicts), that are automatically converted to the appropriate SOAP types. | ||
| 50 | |||
| 51 | Inside the archive you'll also find a short example of how to use it in ngnpro_test.py | ||
| 52 | |||
| 53 | h3. PHP Client | ||
| 54 | |||
| 55 | To use this example code you must install SOAP library for PEAR project. | ||
| 56 | |||
| 57 | Generate the library with: | ||
| 58 | |||
| 59 | 4 | Tijmen de Mes | <pre><code class="php"> | 
| 60 | #!/usr/bin/php | ||
| 61 | 1 | Tijmen de Mes | <? | 
| 62 | require_once('SOAP/WSDL.php'); | ||
| 63 | $wsdl       = new SOAP_WSDL('https://mdns.sipthor.net/ngnpro/wsdl'); | ||
| 64 | print "<?\n"; | ||
| 65 | print $wsdl->generateAllProxies(); | ||
| 66 | print "?>\n"; | ||
| 67 | 6 | Tijmen de Mes | ?></code> | 
| 68 | 4 | Tijmen de Mes | </pre> | 
| 69 | 1 | Tijmen de Mes | |
| 70 | 5 | Tijmen de Mes | You will end up with a file containing all client functions, attached is an example of the generated file for NGNPro version 4.3.5 attachment:ngnpro_soap_lib.php | 
| 71 | 1 | Tijmen de Mes | |
| 72 | 5 | Tijmen de Mes | The script attachment:sip_add_account.php | 
| 73 | 1 | Tijmen de Mes | |
| 74 | h3. Server Location | ||
| 75 | |||
| 76 | NGNPro is reachable on the following URLs, which were configured during the setup phase of the platform: | ||
| 77 | |||
| 78 | |||
| 79 | |Platform|Protocol|Port|Location|SOAP ports| | ||
| 80 | |Collocated Multimedia Service Platform|TLS|443|"https://cdr.example.com/ngnpro":https://cdr.example.com/ngnpro|all ports except Voicemail port| | ||
| 81 | |Collocated Multimedia Service Platform|TLS|443|"https://cdr.example.com/ngnpro/voicemail":https://cdr.example.com/ngnpro/voicemail|Voicemail port| | ||
| 82 | |Collocated Multimedia Service Platform|TCP|9200|"http://sip.example.com:9200":http://sip.example.com:9200|all ports except Voicemail port| | ||
| 83 | |Collocated Multimedia Service Platform|TCP|9200|"http://vm.example.com:9200":http://vm.example.com:9200|Voicemail port| | ||
| 84 | |Collocated SIP Thor Platform|TLS|9200|"https://ngnpro.example.com:9200":https://ngnpro.example.com:9200|All ports| | ||
| 85 | |||
| 86 | |||
| 87 | h3. Test Server | ||
| 88 | |||
| 89 | You can test your provisioning client against the live platform hosted by AG Projects. | ||
| 90 | |||
| 91 | |||
| 92 | |Platform|Protocol|Port|Location|SOAP ports| | ||
| 93 | |Hosted AG Projects platform|TLS|443|"https://mdns.sipthor.net/ngnpro":https://mdns.sipthor.net/ngnpro|All ports| | ||
| 94 | |||
| 95 | |||
| 96 | The credentials for accessing the test server are the same as the login account used for accessing AG Projects support web page. | ||
| 97 | |||
| 98 | h3. SOAP/XML Authentication | ||
| 99 | |||
| 100 | SOAP/XML requests must contain valid authentication header with credentials in the form of a combination of username, password and impersonate attributes. There are two types of SOAP credentials to access the server: | ||
| 101 | |||
| 102 | * Administrator level. The server has an administrator account configured in the server configuration file, /etc/ngnpro/config.ini, that can be used to perform all functions without restrictions. Set the *impersonate* attribute of the SOAP authentication header to a valid customer of the system to perform actions in behalf of that customer. | ||
| 103 | * Customer level. Access a partition of the data provisioned into the platform. The customers table, managed using the SOAP/XML CustomerPort, is used as a login database for authenticating and authorizing the SOAP/XML requests. First use the administrator level account to add a customer. When the combination of username/password in the SOAP authentication header matches an entry in the customers table, all actions will be performed in behalf of that customer. This means that any record created will inherit the customer id of the customer and any modification will be checked for ownership before being committed. This allows reseller to have limited access to the platform based on rights assigned to them by the system administrator. | ||
| 104 | |||
| 105 | For more information about the *Customer* concept read below. | ||
| 106 | |||
| 107 | h2. Customer | ||
| 108 | |||
| 109 | Customers are entities created in the platform to store names, address, billing and other information. Customers can also have arbitrary attribute/value pairs stored in the properties attribute. | ||
| 110 | |||
| 111 | Each customer is assigned, during creation by the server, a unique id and a reseller id. | ||
| 112 | |||
| 113 | h3. Record Assignment | ||
| 114 | |||
| 115 | The customer id can be used for assignment of SIP domains, ENUM ranges and DNS zones. The assignment is done by setting the customer id attributes of the record in question. | ||
| 116 | |||
| 117 | All SIP accounts inherit the customer id from their parent SIP domain. For example a SIP domain that has customer and reseller attributes set cause all SIP accounts created under this domain to share the same customer and reseller too (because the SIP account always belong to a SIP domain). Same concept works for the ENUM numbers (they belong to ENUM ranges) and DNS records (they belong to DNS zones). | ||
| 118 | |||
| 119 | Before deleting a customer, make sure that no records belong to his id. | ||
| 120 | |||
| 121 | h2. Reseller | ||
| 122 | |||
| 123 | The reseller has the role of grouping multiple customers together. The concept is similar to how the users in a Unix system work, where each user has a unique id and a group id. As opposed to the Unix model, a customer can belong to a single reseller. Customers having their id equal to the reseller_id are referred as resellers. Also customers that have the impersonate attribute set to the reseller id have the same right as their reseller. | ||
| 124 | |||
| 125 | If a reseller is not specified during the creation of a new customer entry, a new reseller id equal to the customer id will be assigned, in fact creating a new Reseller in the system. Only provisioning requests made with admin rights can add a reseller into the system. | ||
| 126 | |||
| 127 | h3. Conventions for resellers | ||
| 128 | |||
| 129 | A customer that is a reseller (the customer id is equal to reseller id) is allowed to create other customers and records in the platform if the *resellerActive* attribute of the customer is set to true. | ||
| 130 | |||
| 131 | The number of records each reseller is allowed to provision into the platform is controlled by some special properties belonging to the reseller. These special properties are: sip_credit, sip_alias_credit, enum_range_credit, enum_number_credit, dns_zone_credit, email_credit | ||
| 132 | |||
| 133 | The same credit convention is valid for customers belonging to a reseller. Each customer may create records within their own credit. The total of all records created by all customers may not exceed the credit of the reseller. The server checks during creation of each record if the quota has not been exceeded. | ||
| 134 | |||
| 135 | The following properties controls if the reseller or customer has access to enable access to PSTN for the SIP accounts: | ||
| 136 | |||
| 137 | * pstn_access (can create SIP accounts with PSTN prepaid access) | ||
| 138 | * prepaid_changes (can toggle a SIP account from prepaid to postpaid and vice versa) | ||
| 139 | |||
| 140 | On CDRTool, to create an account that has access to the records belonging to a specific customer set the Impersonate field of the CDRTool login account to *customer_id.reseller_id*. | ||
| 141 | |||
| 142 | h3. Conventions for the properties | ||
| 143 | |||
| 144 | As mentioned before, each customer can have a list of attributed/value pairs attached to them in the properties attribute, this allowing for storage of arbitrary data with each customer. Each attribute has a field called permission. The following rules apply: | ||
| 145 | |||
| 146 | * Properties having permission set to admin can be modified only by the administrator | ||
| 147 | * Properties having permission set to reseller can be modified by the administrator and their reseller | ||
| 148 | * Properties having other permission can be modified by their customer, their reseller or by the administrator | ||
| 149 | |||
| 150 | If the SIP domain of a SIP account belongs to a customer (the customer_id != 0), the pstn_access and prepaid_access properties can be enabled only if the corespondent reseller has these properties set to 1. | ||
| 151 | |||
| 152 | h2. Owner | ||
| 153 | |||
| 154 | At SIP account, SIP alias and ENUM number level another attribute called owner exists. Owner attribute can be used to assign or group individual records like SIP accounts and ENUM numbers to customers in the customer table. For example one customer can have multiple SIP accounts and ENUM numbers if their owner field are set to his customer id. | ||
| 155 | |||
| 156 | h3. SOAP/XML functions | ||
| 157 | |||
| 158 | * CustomerPort->addAccount() | ||
| 159 | * CustomerPort->updateAccount() | ||
| 160 | * CustomerPort->deleteAccount() | ||
| 161 | * CustomerPort->getAccount() | ||
| 162 | * CustomerPort->getCustomers() | ||
| 163 | * CustomerPort->getResellers() | ||
| 164 | * CustomerPort->setProperties() | ||
| 165 | * CustomerPort->getProperties() | ||
| 166 | |||
| 167 | Customer attributes: | ||
| 168 | 8 | Tijmen de Mes | <pre> | 
| 169 | 7 | Tijmen de Mes | <complexType name="CustomerAccount"> | 
| 170 | − | ||
| 171 | <sequence> | ||
| 172 | <element name="id" nillable="true" type="xsd:integer"/> | ||
| 173 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 174 | <element name="impersonate" nillable="true" type="xsd:integer"/> | ||
| 175 | <element name="username" nillable="true" type="xsd:string"/> | ||
| 176 | <element name="password" nillable="true" type="xsd:string"/> | ||
| 177 | <element name="firstName" nillable="true" type="xsd:string"/> | ||
| 178 | <element name="lastName" nillable="true" type="xsd:string"/> | ||
| 179 | <element name="organization" nillable="true" type="xsd:string"/> | ||
| 180 | <element name="vatNumber" nillable="true" type="xsd:string"/> | ||
| 181 | <element name="email" nillable="true" type="xsd:string"/> | ||
| 182 | <element name="web" nillable="true" type="xsd:string"/> | ||
| 183 | <element name="tel" nillable="true" type="xsd:string"/> | ||
| 184 | <element name="fax" nillable="true" type="xsd:string"/> | ||
| 185 | <element name="mobile" nillable="true" type="xsd:string"/> | ||
| 186 | <element name="sip" nillable="true" type="xsd:string"/> | ||
| 187 | <element name="enum" nillable="true" type="xsd:string"/> | ||
| 188 | <element name="address" nillable="true" type="xsd:string"/> | ||
| 189 | <element name="postcode" nillable="true" type="xsd:string"/> | ||
| 190 | <element name="city" nillable="true" type="xsd:string"/> | ||
| 191 | <element name="state" nillable="true" type="xsd:string"/> | ||
| 192 | <element name="country" nillable="true" type="xsd:string"/> | ||
| 193 | <element name="timezone" nillable="true" type="xsd:string"/> | ||
| 194 | <element name="language" nillable="true" type="xsd:string"/> | ||
| 195 | <element name="bankAccount" nillable="true" type="xsd:string"/> | ||
| 196 | <element name="billingAddress" nillable="true" type="xsd:string"/> | ||
| 197 | <element name="billingEmail" nillable="true" type="xsd:string"/> | ||
| 198 | <element name="balance" nillable="true" type="xsd:double"/> | ||
| 199 | <element name="credit" nillable="true" type="xsd:double"/> | ||
| 200 | <element name="companyCode" nillable="true" type="xsd:string"/> | ||
| 201 | <element name="resellerActive" nillable="true" type="xsd:boolean"/> | ||
| 202 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 203 | <element name="properties" nillable="true" type="ngnpro:CustomerPropertyArray"/> | ||
| 204 | </sequence> | ||
| 205 | 1 | Tijmen de Mes | </complexType> | 
| 206 | 8 | Tijmen de Mes | </pre> | 
| 207 | 1 | Tijmen de Mes | |
| 208 | h3. Graphical client | ||
| 209 | |||
| 210 | @CDRTool->Accounts->Customers@ | ||
| 211 | |||
| 212 | 3 | Tijmen de Mes | !gngnpro-customers.png! | 
| 213 | 1 | Tijmen de Mes | |
| 214 | Click on the customer id to edit its properties. | ||
| 215 | |||
| 216 | h2. DNS Zones | ||
| 217 | |||
| 218 | The SIP Proxy is configured to serve domains that must be reachable over the Internet. The SIP devices must support RFC3263 (Locating SIP Services), namely support for DNS SRV lookups for SIP services. Each SIP domain configured in the SIP Proxy must have DNS zone configured on a DNS server responsable for that domain. When using the platform built-in DNS servers and DNS management you must create the proper DNS zones and records for each SIP domain. | ||
| 219 | |||
| 220 | To enable the use of an Internet domain for SIP you must provision in the DNS zone the following records: | ||
| 221 | |||
| 222 | 9 | Tijmen de Mes | example.com. 300 IN NAPTR 20 0 "s" "SIP+D2U" "" _sip._udp.example.com. | 
| 223 | _sip._udp.example.com. 300 IN SRV 0 0 5060 sip.example.com. | ||
| 224 | 1 | Tijmen de Mes | |
| 225 | |||
| 226 | Replace example.com with your own domain and add an A record pointing sip.example.com. to the IP address of the SIP Proxy. | ||
| 227 | |||
| 228 | h3. SOAP/XML functions | ||
| 229 | |||
| 230 | * DnsPort->addZone() | ||
| 231 | * DnsPort->updateZone() | ||
| 232 | * DnsPort->deleteZone() | ||
| 233 | * DnsPort->getZone() | ||
| 234 | * DnsPort->getZones() | ||
| 235 | * DnsPort->addRecord() | ||
| 236 | * DnsPort->addFancyRecord() | ||
| 237 | * DnsPort->updateRecord() | ||
| 238 | * DnsPort->updateFancyRecord() | ||
| 239 | * DnsPort->deleteRecord() | ||
| 240 | * DnsPort->deleteFancyRecord() | ||
| 241 | * DnsPort->getRecord() | ||
| 242 | * DnsPort->getFancyRecord() | ||
| 243 | * DnsPort->getRecords() | ||
| 244 | * DnsPort->getFancyRecords() | ||
| 245 | |||
| 246 | DNZ zone attributes: | ||
| 247 | |||
| 248 | 10 | Tijmen de Mes | <pre> | 
| 249 | <complexType name="DnsZone"> | ||
| 250 | 1 | Tijmen de Mes | − | 
| 251 | <sequence> | ||
| 252 | <element name="name" nillable="false" type="xsd:string"/> | ||
| 253 | <element name="ttl" nillable="true" type="xsd:nonNegativeInteger"/> | ||
| 254 | <element name="nameservers" nillable="true" type="ngnpro:StringArray"/> | ||
| 255 | <element name="email" nillable="true" type="xsd:string"/> | ||
| 256 | <element name="serial" nillable="true" type="xsd:int"/> | ||
| 257 | <element name="refresh" nillable="true" type="xsd:int"/> | ||
| 258 | <element name="retry" nillable="true" type="xsd:int"/> | ||
| 259 | <element name="expire" nillable="true" type="xsd:int"/> | ||
| 260 | <element name="minimum" nillable="true" type="xsd:int"/> | ||
| 261 | <element name="customer" nillable="true" type="xsd:integer"/> | ||
| 262 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 263 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 264 | <element name="info" nillable="true" type="xsd:string"/> | ||
| 265 | </sequence> | ||
| 266 | </complexType> | ||
| 267 | 10 | Tijmen de Mes | </pre> | 
| 268 | 1 | Tijmen de Mes | |
| 269 | When using AG Projects hosted platform you must select and use for DNS delegation the following name servers: | ||
| 270 | |||
| 271 | # ns1.dns-hosting.info | ||
| 272 | # ns2.dns-hosting.info | ||
| 273 | |||
| 274 | h3. Graphical client | ||
| 275 | |||
| 276 | @CDRTool->Accounts->DNS zones@ | ||
| 277 | |||
| 278 | 3 | Tijmen de Mes | !gngnpro-dns-zones.png! | 
| 279 | 1 | Tijmen de Mes | |
| 280 | Click on each zone to edit its properties. | ||
| 281 | |||
| 282 | 3 | Tijmen de Mes | !gngnpro-dns-zone.png! | 
| 283 | 1 | Tijmen de Mes | |
| 284 | h2. DNS Records | ||
| 285 | |||
| 286 | Each DNS zones has one or more records. For every SIP domain served by the platform you must create the following DNS records: | ||
| 287 | |||
| 288 | Example for: | ||
| 289 | |||
| 290 | * SIP domain: sipdomain.com | ||
| 291 | * SIP Proxy hostname configured for the platform: sip.example.com | ||
| 292 | |||
| 293 | <pre class="wiki"> | ||
| 294 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||
| 295 | ; DNS records specified by RFC 3263 (Locating SIP services) ; | ||
| 296 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; | ||
| 297 | |||
| 298 | ; SIP communications using UDP transport | ||
| 299 | sipdomain.com. IN NAPTR 10 0 "S" "SIP+d2u" "" _sip._udp.sipdomain.com. | ||
| 300 | _sip._udp.sipdomain.com. IN SRV 0 0 5060 sip.example.com. | ||
| 301 | </pre> | ||
| 302 | |||
| 303 | h3. SOAP/XML functions | ||
| 304 | |||
| 305 | * DnsPort->addRecord() | ||
| 306 | * DnsPort->updateRecord() | ||
| 307 | * DnsPort->deleteRecord() | ||
| 308 | * DnsPort->getRecord() | ||
| 309 | * DnsPort->getRecords() | ||
| 310 | |||
| 311 | DNS record attributes: | ||
| 312 | |||
| 313 | 11 | Tijmen de Mes | bc(wiki). <pre> | 
| 314 | <complexType name="DnsRecord"> | ||
| 315 | 1 | Tijmen de Mes | − | 
| 316 | <sequence> | ||
| 317 | <element name="id" nillable="true" type="xsd:integer"/> | ||
| 318 | <element name="zone" nillable="true" type="xsd:string"/> | ||
| 319 | <element name="name" nillable="true" type="xsd:string"/> | ||
| 320 | <element name="type" nillable="true" type="ngnpro:DnsRecordType"/> | ||
| 321 | <element name="ttl" nillable="true" type="xsd:unsignedInt"/> | ||
| 322 | <element name="value" nillable="true" type="xsd:string"/> | ||
| 323 | <element name="priority" nillable="true" type="xsd:unsignedShort"/> | ||
| 324 | <element name="owner" nillable="true" type="xsd:integer"/> | ||
| 325 | <element name="customer" nillable="true" type="xsd:integer"/> | ||
| 326 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 327 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 328 | </sequence> | ||
| 329 | </complexType> | ||
| 330 | 11 | Tijmen de Mes | </pre> | 
| 331 | 1 | Tijmen de Mes | |
| 332 | DNS record types: | ||
| 333 | |||
| 334 | 11 | Tijmen de Mes | <pre> | 
| 335 | <simpleType name="DnsRecordType"> | ||
| 336 | 1 | Tijmen de Mes | − | 
| 337 | <xsd:restriction base="xsd:string"> | ||
| 338 | <xsd:enumeration value="A"/> | ||
| 339 | <xsd:enumeration value="AAAA"/> | ||
| 340 | <xsd:enumeration value="CNAME"/> | ||
| 341 | <xsd:enumeration value="MX"/> | ||
| 342 | <xsd:enumeration value="NAPTR"/> | ||
| 343 | <xsd:enumeration value="NS"/> | ||
| 344 | <xsd:enumeration value="SRV"/> | ||
| 345 | <xsd:enumeration value="TXT"/> | ||
| 346 | <xsd:enumeration value="PTR"/> | ||
| 347 | <xsd:enumeration value="LOC"/> | ||
| 348 | </xsd:restriction> | ||
| 349 | </simpleType> | ||
| 350 | 11 | Tijmen de Mes | </pre> | 
| 351 | 1 | Tijmen de Mes | |
| 352 | h3. Graphical client | ||
| 353 | |||
| 354 | @CDRTool->Accounts->DNS records@ | ||
| 355 | |||
| 356 | 3 | Tijmen de Mes | !gngnpro-dns-records.png! | 
| 357 | 1 | Tijmen de Mes | |
| 358 | Click on each record to edit its attributes. | ||
| 359 | |||
| 360 | 3 | Tijmen de Mes | !gngnpro-dns-record.png! | 
| 361 | 1 | Tijmen de Mes | |
| 362 | h2. SIP Domains | ||
| 363 | |||
| 364 | Before creating SIP accounts you need to create at least one SIP domain. (e.g. example.com) | ||
| 365 | |||
| 366 | h3. SOAP/XML functions | ||
| 367 | |||
| 368 | * SipPort->addDomain() | ||
| 369 | * SipPort->updateDomain() | ||
| 370 | * SipPort->deleteDomain() | ||
| 371 | * SipPort->getDomains() | ||
| 372 | |||
| 373 | h3. Graphical client | ||
| 374 | |||
| 375 | @CDRTool->Accounts->SIP domains@ | ||
| 376 | |||
| 377 | 3 | Tijmen de Mes | !gngnpro-sip-domains.png! | 
| 378 | 1 | Tijmen de Mes | |
| 379 | h2. SIP Accounts | ||
| 380 | |||
| 381 | The provisioning of SIP account is performed using the SOAP/XML functions present in the Sip port described in NGNPro WSDL. | ||
| 382 | |||
| 383 | You must add at least one SIP domain before adding a SIP account. | ||
| 384 | |||
| 385 | SIP account passwords can be stored in clear text or encrypted formats depending on how you supply the password. NGNPro needs two MD5 checksums (hexdigests) computed based on the (id.username, id.domain, password) tuple. A hexdigest must be a string of length 32, containing only hexadecimal digits. These hexdigests can be computed by the client and given to NGNPro instead of a clear text password, as follows: the password field must be in "digest1:digest2" form, where digest1=MD5("username:domain:password") and digest2=MD5("username@domain:domain:password"). Otherwise, if the password is given in clear text, NGNPro computes these two digests and stores them. If the store_clear_text_passwords configuration option is set to Yes (the default value), the clear text password will be also be stored. If store_clear_text_passwords is set to No, the password will not be stored and it will not be available in the future. | ||
| 386 | |||
| 387 | To enable different rights for SIP accounts, they must be part of specific groups. | ||
| 388 | |||
| 389 | You can add or remove a SIP account from a group by using Sip.addToGroup() and Sip.removeFromGroup() SOAP methods. The list of groups to which a SIP account belongs can also be set using the `groups' attribute of the SipAccount structure in Sip.addAccount() and Sip.updateAccount() methods. When you're using a group list for modification, all the old groups will be deleted and the new ones will be inserted in place. | ||
| 390 | |||
| 391 | To enable PSTN calls to a SIP account, that account must be in the 'free-pstn' group. | ||
| 392 | |||
| 393 | If you want to limit the access to PSTN, in the margins of a predefined quota (expressed in the currency used by CDRTool rating engine), the SIP account must have a positive value set for the 'quota' attribute in the SipAccount structure. In this case, the CDRTool quota system blocks the user if the traffic exceedes the predefined quota by adding the user to the 'quota' group. In this case the SIP account can still place free calls. | ||
| 394 | |||
| 395 | A SIP account can be administratively blocked (it cannot make any calls and it cannot register thus not receiving calls), if it's part of the 'blocked' group. | ||
| 396 | |||
| 397 | If you want a SIP account to make calls marked as anonymous, that SIP account must be placed in the 'anonymous' group. | ||
| 398 | |||
| 399 | To mark a SIP account as prepaid, the 'prepaid' attribute of the SipAccount structure must be set to True. | ||
| 400 | |||
| 401 | SipAccount.properties attribute can be used to store per-account information in the form of name-value pairs and they can then be used on the client side for its own purposes. Properties do not influence routing decisions. Their meaning depends on the interpretation the client side gives them, for example they can be used from a web-based interface to store settings like the display language or the account type. | ||
| 402 | |||
| 403 | Diversion rules routing order: | ||
| 404 | |||
| 405 | # Unavailable, | ||
| 406 | # Unconditional | ||
| 407 | # Not-online | ||
| 408 | # Busy | ||
| 409 | # No-answer | ||
| 410 | |||
| 411 | Not-online means there is no registered device for that account, Unavailable means that the subscriber has accept rules in place that forbid the caller at the current time, accept rules can be temporary (valid a a number of minutes after which they'll be discarded) or scheduled (permanent rules based on time of day and day of week). | ||
| 412 | |||
| 413 | The last 2 rules are not handled together with the other 3, they are only handled if the call fails. | ||
| 414 | |||
| 415 | h3. SOAP/XML functions | ||
| 416 | |||
| 417 | * SipPort->addAccount() | ||
| 418 | * SipPort->updateAccount() | ||
| 419 | * SipPort->deleteAccount() | ||
| 420 | * SipPort->getAccount() | ||
| 421 | * SipPort->getAccounts() | ||
| 422 | * SipPort->addToGroup() | ||
| 423 | * SipPort->removeFromGroup() | ||
| 424 | * SipPort->getGroups() | ||
| 425 | * SipPort->addPhonebookEntry() | ||
| 426 | * SipPort->updatePhonebookEntry() | ||
| 427 | * SipPort->deletePhonebookEntry() | ||
| 428 | * SipPort->getPhonebookEntries() | ||
| 429 | * SipPort->setRejectMembers() | ||
| 430 | * SipPort->getRejectMembers() | ||
| 431 | * SipPort->setAcceptRules() | ||
| 432 | * SipPort->getAcceptRules() | ||
| 433 | * SipPort->setBarringPrefixes() | ||
| 434 | * SipPort->getBarringPrefixes() | ||
| 435 | * SipPort->setCallDiversions() | ||
| 436 | * SipPort->getCallDiversions() | ||
| 437 | * SipPort->getCalls() | ||
| 438 | * SipPort->getCallStatistics() | ||
| 439 | * SipPort->getSipDeviceLocations() | ||
| 440 | |||
| 441 | SIP account attributes: | ||
| 442 | |||
| 443 | bc(wiki). <complexType name="SipAccount"> | ||
| 444 | − | ||
| 445 | <sequence> | ||
| 446 | <element name="id" nillable="false" type="ngnpro:SipId"/> | ||
| 447 | <element name="password" nillable="true" type="xsd:string"/> | ||
| 448 | <element name="firstName" nillable="true" type="xsd:string"/> | ||
| 449 | <element name="lastName" nillable="true" type="xsd:string"/> | ||
| 450 | <element name="email" nillable="true" type="xsd:string"/> | ||
| 451 | <element name="acl" nillable="true" type="ngnpro:SubscriberACLArray"/> | ||
| 452 | <element name="groups" nillable="true" type="ngnpro:StringArray"/> | ||
| 453 | <element name="properties" nillable="true" type="ngnpro:PropertyArray"/> | ||
| 454 | <element name="timezone" nillable="true" type="xsd:string"/> | ||
| 455 | <element name="rpid" nillable="true" type="xsd:string"/> | ||
| 456 | <element name="quota" nillable="true" type="xsd:int"/> | ||
| 457 | <element name="quickdialPrefix" nillable="true" type="xsd:string"/> | ||
| 458 | <element name="callLimit" nillable="true" type="xsd:int"/> | ||
| 459 | <element name="prepaid" nillable="true" type="xsd:boolean"/> | ||
| 460 | <element name="region" nillable="true" type="xsd:string"/> | ||
| 461 | <element name="timeout" nillable="true" type="xsd:nonNegativeInteger"/> | ||
| 462 | <element name="owner" nillable="true" type="xsd:integer"/> | ||
| 463 | <element name="customer" nillable="true" type="xsd:integer"/> | ||
| 464 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 465 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 466 | <element name="createDate" nillable="true" type="xsd:string"/> | ||
| 467 | </sequence> | ||
| 468 | </complexType> | ||
| 469 | |||
| 470 | |||
| 471 | Meaning of SIP account attributes: | ||
| 472 | |||
| 473 | * rpid: caller id presented to the callee when calling to PSTN destinations | ||
| 474 | * prepaid: if true, subscriber may call within the limit of its prepaid balance, when balance is zero all calls in progress are cut | ||
| 475 | * properties: list with attribute/value pairs, used to store arbitrary data per subscriber | ||
| 476 | * quota: if set to a possitive integer, the subscriber may call to the PSTN up to this limit, calls in progress continue, the usage is reset each calendar month | ||
| 477 | * region: label that matches a region when calling an emergency number, the call is routed to the emergency point defined for that region | ||
| 478 | * callLimit: maximum amount of concurrent PSTN calls allowed | ||
| 479 | * acl: a list of allowed IP networks | ||
| 480 | |||
| 481 | * groups: group membership for SIP accounts. Available groups and their meaning: | ||
| 482 | |||
| 483 | * free-pstn: subscriber may call to PSTN destinations | ||
| 484 | * blocked: only calls to emergency numbers defind in the SIP Proxy are allowed | ||
| 485 | * anonymous: hide caller id when calling to the PSTN (using Privacy headers) | ||
| 486 | * anonymous-reject: reject calls from "anonymous@anonymous.invalid":mailto:anonymous@anonymous.invalid | ||
| 487 | * quota: subscriber has been blocked because monthy quota has been exceeded, calls to PSTN destinations are denied | ||
| 488 | * missed-calls: subscriber will be notifie by email about his sessions in the last 24 hours | ||
| 489 | |||
| 490 | Reserved groups for internal use (do not change them): | ||
| 491 | |||
| 492 | * prepaid, intercept | ||
| 493 | |||
| 494 | On updateAccount() operation all attributes must be supplied otherwise any missing attribute will be deleted. First perform a getAccount() operation, update the attributes that need to be changed and finally perform an updateAccount() with the modified object. | ||
| 495 | |||
| 496 | h3. Graphical client | ||
| 497 | |||
| 498 | @CDRTool->Accounts->SIP accounts@ | ||
| 499 | |||
| 500 | 3 | Tijmen de Mes | !gngnpro-sip-accounts.png! | 
| 501 | 1 | Tijmen de Mes | |
| 502 | h3. Control panel | ||
| 503 | |||
| 504 | 3 | Tijmen de Mes | !http://wiki.sip2sip.info/attachments/3809/sip2sip-cp-menu.png(http://wiki.sip2sip.info/attachments/3809/sip2sip-cp-menu.png)! | 
| 505 | 1 | Tijmen de Mes | |
| 506 | The above menu gives you access to various settings and information related to your SIP account. | ||
| 507 | |||
| 508 | h3. Voicemail | ||
| 509 | |||
| 510 | This panel can set the way the voicemail messages are delivered. | ||
| 511 | |||
| 512 | 3 | Tijmen de Mes | !http://wiki.sip2sip.info/attachments/3813/sip2sip-cp-voicemail.png(http://wiki.sip2sip.info/attachments/3813/sip2sip-cp-voicemail.png)! | 
| 513 | 1 | Tijmen de Mes | |
| 514 | h3. Online devices | ||
| 515 | |||
| 516 | This panel displays the list of registered SIP devices. | ||
| 517 | |||
| 518 | 3 | Tijmen de Mes | !gsip2sip-cp-devices.png! | 
| 519 | 1 | Tijmen de Mes | |
| 520 | h3. Accept calls | ||
| 521 | |||
| 522 | This panel control when and from whom calls are accepted. | ||
| 523 | |||
| 524 | 3 | Tijmen de Mes | !http://wiki.sip2sip.info/attachments/3801/sip2sip-cp-accept.png(http://wiki.sip2sip.info/attachments/3801/sip2sip-cp-accept.png)! | 
| 525 | 1 | Tijmen de Mes | |
| 526 | h3. Call diversions | ||
| 527 | |||
| 528 | This panel controls the call diversions. | ||
| 529 | |||
| 530 | 3 | Tijmen de Mes | !http://wiki.sip2sip.info/attachments/3807/sip2sip-cp-diversions.png(http://wiki.sip2sip.info/attachments/3807/sip2sip-cp-diversions.png)! | 
| 531 | 1 | Tijmen de Mes | |
| 532 | Call diversions data type: | ||
| 533 | |||
| 534 | <pre class="wiki"> | ||
| 535 | <complexType name="CallDiversions"> | ||
| 536 | − | ||
| 537 | <sequence> | ||
| 538 | − | ||
| 539 | <!-- | ||
| 540 | |||
| 541 | FUNC - forward unconditionally | ||
| 542 | FNOL - forward if not online | ||
| 543 | FUNV - forward if not available | ||
| 544 | FNOA - forward if no answer | ||
| 545 | FBUS - forward if busy | ||
| 546 | RUNC - redirect unconditionally | ||
| 547 | RNOL - redirect if not online | ||
| 548 | RUNV - redirect if not available | ||
| 549 | RNOA - redirect if no answer | ||
| 550 | RBUS - redirect if busy | ||
| 551 | |||
| 552 | - Forward conditions cause the traffic to be routed and accounted through the SIP Proxy | ||
| 553 | - Redirect conditions cause traffic to be made directly between the caller and end destination, | ||
| 554 | bypassing the SIP Proxy | ||
| 555 | - Always used FXXX conditions when accounting is desired | ||
| 556 | |||
| 557 | |||
| 558 | --> | ||
| 559 | <element name="FUNC" nillable="true" type="xsd:string"/> | ||
| 560 | <element name="FNOL" nillable="true" type="xsd:string"/> | ||
| 561 | <element name="FUNV" nillable="true" type="xsd:string"/> | ||
| 562 | <element name="FNOA" nillable="true" type="xsd:string"/> | ||
| 563 | <element name="FBUS" nillable="true" type="xsd:string"/> | ||
| 564 | <element name="RUNC" nillable="true" type="xsd:string"/> | ||
| 565 | <element name="RNOL" nillable="true" type="xsd:string"/> | ||
| 566 | <element name="RUNV" nillable="true" type="xsd:string"/> | ||
| 567 | <element name="RNOA" nillable="true" type="xsd:string"/> | ||
| 568 | <element name="RBUS" nillable="true" type="xsd:string"/> | ||
| 569 | </sequence> | ||
| 570 | </complexType> | ||
| 571 | </pre> | ||
| 572 | |||
| 573 | h3. Aliases | ||
| 574 | |||
| 575 | This panel displays the aliases associated with a SIP account. | ||
| 576 | |||
| 577 | 3 | Tijmen de Mes | !http://wiki.sip2sip.info/raw-attachment/wiki/SipSettings/sip2sip-cp-aliases.png(http://wiki.sip2sip.info/raw-attachment/wiki/SipSettings/sip2sip-cp-aliases.png)! | 
| 578 | 1 | Tijmen de Mes | |
| 579 | h2. SIP Aliases | ||
| 580 | |||
| 581 | Aliases can be used to provide custom SIP addresses that map to exiting SIP accounts. | ||
| 582 | |||
| 583 | h3. SOAP/XML functions | ||
| 584 | |||
| 585 | * SipPort->addAlias() | ||
| 586 | * SipPort->updateAlias() | ||
| 587 | * SipPort->deleteAlias() | ||
| 588 | * SipPort->getAlias() | ||
| 589 | * SipPort->getAliasesForAccount() | ||
| 590 | * SipPort->getAliases() | ||
| 591 | |||
| 592 | h3. Graphical client | ||
| 593 | |||
| 594 | @CDRTool->Accounts->SIP aliases@ | ||
| 595 | |||
| 596 | 3 | Tijmen de Mes | !gngnpro-sip-aliases.png! | 
| 597 | 1 | Tijmen de Mes | |
| 598 | h2. Trusted Peers | ||
| 599 | |||
| 600 | Trusted peers are identified by their IP addresses and are allowed to transit the platform. Trusted peers are used to define SIP trunks to/from PBXs allowed to connect to the platform. For more information see "SIP trunking section":http://msp-documentation.ag-projects.com/wiki/PeeringGuide#SIPtrunking. | ||
| 601 | |||
| 602 | h3. SOAP/XML functions | ||
| 603 | |||
| 604 | * SipPort->addTrustedPeer() | ||
| 605 | * SipPort->deleteTrustedPeer() | ||
| 606 | * SipPort->getTrustedPeers() | ||
| 607 | |||
| 608 | Trusted peer attributes: | ||
| 609 | |||
| 610 | bc(wiki). <complexType name="TrustedPeer"> | ||
| 611 | − | ||
| 612 | <sequence> | ||
| 613 | <element name="ip" nillable="false" type="xsd:string"/> | ||
| 614 | <element name="protocol" nillable="true" type="ngnpro:TrustedPeerProtocol" default="any"/> | ||
| 615 | <element name="fromPattern" nillable="true" type="xsd:string" default="^sip:.*$"/> | ||
| 616 | <element name="tag" nillable="true" type="xsd:string"/> | ||
| 617 | <element name="description" nillable="true" type="xsd:string" default=""/> | ||
| 618 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 619 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 620 | </sequence> | ||
| 621 | </complexType> | ||
| 622 | |||
| 623 | |||
| 624 | h3. Graphical client | ||
| 625 | |||
| 626 | @CDRTool->Accounts->Trusted peers@ | ||
| 627 | |||
| 628 | 3 | Tijmen de Mes | !gngnpro-trusted-peers.png! | 
| 629 | 1 | Tijmen de Mes | |
| 630 | h2. ENUM Ranges | ||
| 631 | |||
| 632 | ENUM is used in the routing logic of the SIP Proxy for sessions that use telephone numbers as identifiers. ENUM is a protocol that provides a translation mechanism for E.164 telephone numbers into IP addressing schemes. | ||
| 633 | |||
| 634 | An ENUM range is a telephone number prefix that has been allocated to your platform (by your telephone numbers supplier or telecom regulator in your country). For example you are an operator in Holland (contry code 31) and you have been allocated from the local authorities the numbers 31208005100 till 31208005199 (one hundred numbers). The prefix is therefore 312080051. First create an ENUM range using this prefix, then add individual numbers belonging to this range. | ||
| 635 | |||
| 636 | An ENUM range is similar with a DNS zones but it contains extra non DNS attributes like the type of numbers allowed to be stored. | ||
| 637 | |||
| 638 | h3. SOAP/XML functions | ||
| 639 | |||
| 640 | * EnumPort->addRange() | ||
| 641 | * EnumPort->updateRange() | ||
| 642 | * EnumPort->deleteRange() | ||
| 643 | * EnumPort->getRanges() | ||
| 644 | |||
| 645 | ENUM range attributes: | ||
| 646 | |||
| 647 | bc(wiki). <complexType name="EnumRange"> | ||
| 648 | − | ||
| 649 | <sequence> | ||
| 650 | <element name="id" nillable="false" type="ngnpro:EnumRangeId"/> | ||
| 651 | <element name="ttl" nillable="true" type="xsd:nonNegativeInteger" default="3600"/> | ||
| 652 | <element name="minDigits" nillable="true" type="xsd:int"/> | ||
| 653 | <element name="maxDigits" nillable="true" type="xsd:int"/> | ||
| 654 | <element name="size" nillable="true" type="xsd:int"/> | ||
| 655 | <element name="nameservers" nillable="true" type="ngnpro:StringArray"/> | ||
| 656 | <element name="used" nillable="true" type="xsd:int"/> | ||
| 657 | <element name="serial" nillable="true" type="xsd:int"/> | ||
| 658 | <element name="customer" nillable="true" type="xsd:integer"/> | ||
| 659 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 660 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 661 | <element name="info" nillable="true" type="xsd:string"/> | ||
| 662 | </sequence> | ||
| 663 | </complexType> | ||
| 664 | |||
| 665 | |||
| 666 | h3. Graphical client | ||
| 667 | |||
| 668 | @CDRTool->Accounts->ENUM ranges@ | ||
| 669 | |||
| 670 | 3 | Tijmen de Mes | !gngnpro-enum-ranges.png! | 
| 671 | 1 | Tijmen de Mes | |
| 672 | Click on each range to modify its properties. | ||
| 673 | |||
| 674 | 3 | Tijmen de Mes | !gngnpro-enum-range.png! | 
| 675 | 1 | Tijmen de Mes | |
| 676 | h2. ENUM Numbers | ||
| 677 | |||
| 678 | ENUM is used in the routing logic of the SIP Proxy for sessions that use telephone numbers as identifiers. For each SIP account in the platform that must be reachable besides the SIP address also by one ore more telephone numbers, you must create the ENUM numbers and add mappings to their corresponding SIP account. Before creating any ENUM number, you must create an ENUM range. | ||
| 679 | |||
| 680 | The ENUM NAPTR record management has been developed based on the standards described at "http://www.ag-projects.com/content/view/61/96/":http://www.ag-projects.com/content/view/61/96/ | ||
| 681 | |||
| 682 | Each ENUM number may have up to 5 NAPTR records as specified in ETSI TS 102 172 V1.2.1 (Minimum requirements for interoperability of ENUM implementations) | ||
| 683 | |||
| 684 | h3. SOAP/XML functions | ||
| 685 | |||
| 686 | * EnumPort->addNumber() | ||
| 687 | * EnumPort->updateNumber() | ||
| 688 | * EnumPort->deleteNumber() | ||
| 689 | * EnumPort->getNumber() | ||
| 690 | * EnumPort->getNumbers() | ||
| 691 | |||
| 692 | ENUM number attributes: | ||
| 693 | |||
| 694 | bc(wiki). <complexType name="EnumNumber"> | ||
| 695 | − | ||
| 696 | <sequence> | ||
| 697 | <element name="id" nillable="false" type="ngnpro:EnumId"/> | ||
| 698 | <element name="mappings" nillable="true" type="ngnpro:EnumMappingArray"/> | ||
| 699 | <element name="info" nillable="true" type="xsd:string"/> | ||
| 700 | <element name="owner" nillable="true" type="xsd:integer"/> | ||
| 701 | <element name="customer" nillable="true" type="xsd:integer"/> | ||
| 702 | <element name="reseller" nillable="true" type="xsd:integer"/> | ||
| 703 | <element name="changeDate" nillable="true" type="xsd:string"/> | ||
| 704 | </sequence> | ||
| 705 | </complexType> | ||
| 706 | |||
| 707 | |||
| 708 | ENUM mapping attributes: | ||
| 709 | |||
| 710 | bc(wiki). <complexType name="EnumMapping"> | ||
| 711 | − | ||
| 712 | <sequence> | ||
| 713 | <element name="id" nillable="true" type="xsd:int"/> | ||
| 714 | <element name="type" nillable="true" type="xsd:string"/> | ||
| 715 | <element name="mapto" nillable="true" type="xsd:string"/> | ||
| 716 | <element name="priority" nillable="true" type="xsd:int"/> | ||
| 717 | <element name="ttl" nillable="true" type="xsd:int" default="3600"/> | ||
| 718 | </sequence> | ||
| 719 | </complexType> | ||
| 720 | |||
| 721 | |||
| 722 | The following NAPTR record types ENUM service types are supported: | ||
| 723 | |||
| 724 | bc(wiki). var $NAPTR_services=array( | ||
| 725 |         "sip"    => array("service"=>"sip", | ||
| 726 | "webname"=>"SIP", | ||
| 727 |                               "schemas"=>array("sip:","sips:")), | ||
| 728 |         "mailto" => array("service"=>"mailto", | ||
| 729 | "webname"=>"Email", | ||
| 730 |                               "schemas"=>array("mailto:")), | ||
| 731 |         "web:http"   => array("service"=>"web:http", | ||
| 732 | "webname"=>"WEB (http)", | ||
| 733 |                               "schemas"=>array("http://")), | ||
| 734 |         "web:https"  => array("service"=>"web:https", | ||
| 735 | "webname"=>"WEB (https)", | ||
| 736 |                               "schemas"=>array("https://")), | ||
| 737 |         "x-skype:callto" => array("service"=>"x-skype:callto", | ||
| 738 | "webname"=>"Skype", | ||
| 739 |                               "schemas"=>array("callto:")), | ||
| 740 |         "h323"   => array("service"=>"h323", | ||
| 741 | "webname"=>"H323", | ||
| 742 |                               "schemas"=>array("h323:")), | ||
| 743 |         "iax"    => array("service"=>"iax", | ||
| 744 | "webname"=>"IAX", | ||
| 745 |                               "schemas"=>array("iax:")), | ||
| 746 |         "iax2"   => array("service"=>"iax2", | ||
| 747 | "webname"=>"IAX2", | ||
| 748 |                               "schemas"=>array("iax2:")), | ||
| 749 |         "mms"    => array("service"=>"mms", | ||
| 750 | "webname"=>"MMS", | ||
| 751 |                               "schemas"=>array("tel:","mailto:")), | ||
| 752 |         "sms"    => array("service"=>"sms", | ||
| 753 | "webname"=>"SMS", | ||
| 754 |                               "schemas"=>array("tel:","mailto:")), | ||
| 755 |         "ems"    => array("service"=>"ems", | ||
| 756 | "webname"=>"EMS", | ||
| 757 |                               "schemas"=>array("tel:","mailto:")), | ||
| 758 |         "im"     => array("service"=>"im", | ||
| 759 | "webname"=>"IM", | ||
| 760 |                               "schemas"=>array("im:")), | ||
| 761 |         "npd:tel"   => array("service"=>"npd+tel", | ||
| 762 | "webname"=>"Portability", | ||
| 763 |                               "schemas"=>array("tel:")), | ||
| 764 |         "void:mailto"  => array("service"=>"void:mailto", | ||
| 765 | "webname"=>"VOID(mail)", | ||
| 766 |                               "schemas"=>array("mailto:")), | ||
| 767 |         "void:http"  => array("service"=>"void:http", | ||
| 768 | "webname"=>"VOID(http)", | ||
| 769 |                               "schemas"=>array("http://")), | ||
| 770 |         "void:https" => array("service"=>"void:https", | ||
| 771 | "webname"=>"VOID(https)", | ||
| 772 |                               "schemas"=>array("https://")), | ||
| 773 |         "voice"  => array("service"=>"voice", | ||
| 774 | "webname"=>"Voice", | ||
| 775 |                               "schemas"=>array("voice:","tel:")), | ||
| 776 |         "tel"    => array("service"=>"tel", | ||
| 777 | "webname"=>"Tel", | ||
| 778 |                               "schemas"=>array("tel:")), | ||
| 779 |         "fax:tel"    => array("service"=>"fax:tel", | ||
| 780 | "webname"=>"Fax", | ||
| 781 |                               "schemas"=>array("tel:")), | ||
| 782 |         "ifax:mailto"   => array("service"=>"ifax:mailto", | ||
| 783 | "webname"=>"iFax", | ||
| 784 |                               "schemas"=>array("mailto:")), | ||
| 785 |         "pres"   => array("service"=>"pres", | ||
| 786 | "webname"=>"Presence", | ||
| 787 |                               "schemas"=>array("pres:")), | ||
| 788 |         "ft:ftp"    => array("service"=>"ft:ftp", | ||
| 789 | "webname"=>"FTP", | ||
| 790 |                               "schemas"=>array("ftp://")), | ||
| 791 |         "loc:http"  => array("service"=>"loc:http", | ||
| 792 | "webname"=>"GeoLocation", | ||
| 793 |                               "schemas"=>array("http://")), | ||
| 794 |         "key:http"  => array("service"=>"key:http", | ||
| 795 | "webname"=>"Public key", | ||
| 796 |                               "schemas"=>array("http://")), | ||
| 797 |         "key:https"  => array("service"=>"key:https", | ||
| 798 | "webname"=>"Public key (HTTPS)", | ||
| 799 |                               "schemas"=>array("https://")) | ||
| 800 | ); | ||
| 801 | |||
| 802 | |||
| 803 | |||
| 804 | h3. Graphical client | ||
| 805 | |||
| 806 | @CDRTool->Accounts->ENUM numbers@ | ||
| 807 | |||
| 808 | 3 | Tijmen de Mes | !gngnpro-enum-numbers.png! | 
| 809 | 1 | Tijmen de Mes | |
| 810 | Click on each number to modify its properties. | ||
| 811 | |||
| 812 | 3 | Tijmen de Mes | !gngnpro-enum-number.png! | 
| 813 | 1 | Tijmen de Mes | |
| 814 | h2. Voicemail Accounts | ||
| 815 | |||
| 816 | The provisioning is performed using the SOAP/XML functions present in the Voicemail port described in NGNPro WSDL. | ||
| 817 | |||
| 818 | To add a voicemail account for a SIP account, the Voicemail.addAccount() method must be used. For each newly created account, a mailbox number will be automatically generated by the provisioning to uniquely identify the voicemail account. If you set the mailbox by yourself, please note that the Asterisk configuration might need to be updated, for example if you give shorter voicemailboxes (3, 4 digits), that are not accepted by default. | ||
| 819 | |||
| 820 | By default mailboxes are created starting with number 1000000. | ||
| 821 | |||
| 822 | You can configure the voicemail server to delete or store the received voicemail messages by setting VoicemailAccount.VoicemailOptions.delete attribute to True or False, respectively. | ||
| 823 | |||
| 824 | To forward requests of a SIP account to the Voicemail account, use the '<voice-mailbox>' wildcard as a value for FUNC, FNOL, FUNV, FNOA, FBUS forwarding indicators in the Sip.setCallDiversions() method. | ||
| 825 | |||
| 826 | Each SIP account can access its own voicemail messages and settings by dialing the voicemail extension (by default *70) configured in the SIP Proxy in: | ||
| 827 | |||
| 828 | bc(wiki). /etc/opensips/config/settings.m4 | ||
| 829 | |||
| 830 | |||
| 831 | bc(wiki). # Number to dial to get to voicemail | ||
| 832 | define(`VOICEMAIL_NUMBER', `*70') | ||
| 833 | |||
| 834 | |||
| 835 | Some devices are using the * key internally. For such devices you may create an alias in the platform (like voicemail or a full number without *). | ||
| 836 | |||
| 837 | Voice messages are by default sent by email. If you wish to store the on the voicemail server and listen to them using a telephone device you must enable voicemail storage option for each SIP account using the provisioning API. If the server storage option is enabled, a Message Waiting Indicator (a.k.a MWI) is sent to the devices that subscribed for this event, the devices supporting such feature will provide an indication that voice messages have been stored on the server. | ||
| 838 | |||
| 839 | MWI is enabled if the storage of message on server is enabled. MWI is reset by accessing the voicemail box using a SIP phone. | ||
| 840 | |||
| 841 | To change the default content of asterisk email notification, you must edit in /etc/asterisk/voicemail.conf and change the following directives: | ||
| 842 | |||
| 843 | <pre class="wiki"> | ||
| 844 | ;emailbody= | ||
| 845 | ;emailsubject= | ||
| 846 | |||
| 847 | ; Change the from, body and/or subject, variables: | ||
| 848 | ; VM_NAME, VM_DUR, VM_MSGNUM, VM_MAILBOX, VM_CALLERID, VM_CIDNUM, | ||
| 849 | ; VM_CIDNAME, VM_DATE | ||
| 850 | |||
| 851 | and | ||
| 852 | |||
| 853 | ;serveremail = notification@some_domain.tld | ||
| 854 | </pre> | ||
| 855 | |||
| 856 | An asterisk reload or restart is required: | ||
| 857 | |||
| 858 | bc(wiki). sudo asterisk -r reload | ||
| 859 | |||
| 860 | |||
| 861 | h3. SOAP/XML functions | ||
| 862 | |||
| 863 | * VoicemailPort->addAccount() | ||
| 864 | * VoicemailPort->updateAccount() | ||
| 865 | * VoicemailPort->deleteAccount() | ||
| 866 | * VoicemailPort->getAccount() | ||
| 867 | * VoicemailPort->setAnnouncement() | ||
| 868 | |||
| 869 | h2. PSTN Routes | ||
| 870 | |||
| 871 | A route is a PSTN prefix, one or more carriers can be assigned for routing sessions for it. PSTN prefixes always start with 00 + Country code. (e.g. 0031 is Nederland). An empty prefix will match all possible routes while a longer match takes precedence. The actual number format sent out to the PSTN gateway can be modified using the gateway rules described below. | ||
| 872 | |||
| 873 | h3. SOAP/XML functions | ||
| 874 | |||
| 875 | * SipPort->addRoutes() | ||
| 876 | * SipPort->deleteRoutes() | ||
| 877 | * SipPort->getRoutes() | ||
| 878 | |||
| 879 | h3. Graphical client | ||
| 880 | |||
| 881 | @CDRTool->Accounts->PSTN routes@ | ||
| 882 | |||
| 883 | 3 | Tijmen de Mes | !gngnpro-pstn-routes.png! | 
| 884 | 1 | Tijmen de Mes | |
| 885 | h2. PSTN Carriers | ||
| 886 | |||
| 887 | A carrier groups one or more gateways together and can be used during the assignment of PSTN routes. You must define at least one carrier for PSTN routing. | ||
| 888 | |||
| 889 | h3. SOAP/XML functions | ||
| 890 | |||
| 891 | * SipPort->addCarrier() | ||
| 892 | * SipPort->deleteCarrier() | ||
| 893 | * SipPort->getCarriers() | ||
| 894 | |||
| 895 | h3. Graphical client | ||
| 896 | |||
| 897 | @CDRTool->Accounts->PSTN carriers@ | ||
| 898 | |||
| 899 | 3 | Tijmen de Mes | !gngnpro-pstn-carriers.png! | 
| 900 | 1 | Tijmen de Mes | |
| 901 | h2. PSTN Gateways | ||
| 902 | |||
| 903 | You must define at least one gateway for PSTN routing. Before creating any gateway you must create a carrier. | ||
| 904 | |||
| 905 | h3. SOAP/XML functions | ||
| 906 | |||
| 907 | * SipPort->addGateway() | ||
| 908 | * SipPort->updateGateway() | ||
| 909 | * SipPort->deleteGateway() | ||
| 910 | * SipPort->getGateways() | ||
| 911 | |||
| 912 | h3. Graphical client | ||
| 913 | |||
| 914 | @CDRTool->Accounts->PSTN gateways@ | ||
| 915 | |||
| 916 | 3 | Tijmen de Mes | !gngnpro-pstn-gateways.png! | 
| 917 | 1 | Tijmen de Mes | |
| 918 | h2. PSTN Rules | ||
| 919 | |||
| 920 | These rules define the format of the request URI sent to the remote gateway. Rules can be used to strip and prepend digits depending on various conditions. | ||
| 921 | |||
| 922 | h3. SOAP/XML functions | ||
| 923 | |||
| 924 | * SipPort->addGatewayRule() | ||
| 925 | * SipPort->updateGatewayRule() | ||
| 926 | * SipPort->deleteGatewayRule() | ||
| 927 | * SipPort->getGatewayRules() | ||
| 928 | |||
| 929 | h3. Graphical client | ||
| 930 | |||
| 931 | @CDRTool->Accounts->PSTN rules@ | ||
| 932 | |||
| 933 | 3 | Tijmen de Mes | !gngnpro-pstn-rules.png! | 
| 934 | 1 | Tijmen de Mes | |
| 935 | Click on rule to edit its properties. | ||
| 936 | |||
| 937 | 3 | Tijmen de Mes | !gngnpro-pstn-rule.png! | 
| 938 | 1 | Tijmen de Mes | |
| 939 | h2. Emergency Numbers | ||
| 940 | |||
| 941 | Emergency calls refer to dialing short numbers usually associated with emergency services like police or fire-brigade (e.g. 112 or 911). When a SIP session is setup to a short number designated as emergency (in the SIP Proxy configuration), a secondary database lookup is performed in the proxy database in the emergency_mapping table. Based on the *region* attribute provisioned with each SIP account, the final destination number for the emergency service in the region of the account is looked up. | ||
| 942 | |||
| 943 | # Define the emergency numbers in the /etc/opensips/config/settings.m4 | ||
| 944 | |||
| 945 | bc(wiki). # Emergency numbers | ||
| 946 | define(`EMERGENCY_NR1', `112') | ||
| 947 | define(`EMERGENCY_NR2', `911') | ||
| 948 | define(`EMERGENCY_NRS', `2') | ||
| 949 | |||
| 950 | |||
| 951 | <ol start="2"> | ||
| 952 | <li>Add the local access number for each region to emergency_mapping table, the table has the following structure:</li> | ||
| 953 | </ol> | ||
| 954 | |||
| 955 | |||
| 956 | |*Field*|*Type*| | ||
| 957 | |id|int(10) unsigned| | ||
| 958 | |username|varchar(64)| | ||
| 959 | |domain|varchar(64)| | ||
| 960 | |region|varchar(32)| | ||
| 961 | |target|varchar(128)| | ||
| 962 | |change_date|timestamp| | ||
| 963 | |||
| 964 | |||
| 965 | Example: | ||
| 966 | |||
| 967 | bc(wiki). +----------+-------------+-----------+-------------------------------+---------------------+ | ||
| 968 | | username | domain | region | target | change_date | | ||
| 969 | +----------+-------------+-----------+-------------------------------+---------------------+ | ||
| 970 | | 112 | example.com | 010 | sip:0031141217112@example.com | 2006-05-09 14:33:18 | | ||
| 971 | | 112 | example.com | 0111 | sip:0031141219112@example.com | 2006-05-09 14:33:18 | | ||
| 972 | | 112 | example.com | 0113 | sip:0031141219112@example.com | 2006-05-09 14:33:18 | | ||
| 973 | | 112 | example.com | 0114 | sip:0031141219112@example.com | 2006-05-09 14:33:18 | | ||
| 974 | | 112 | example.com | 0115 | sip:0031141219112@example.com | 2006-05-09 14:33:18 | | ||
| 975 | +----------+-------------+-----------+-------------------------------+---------------------+ | ||
| 976 | |||
| 977 | |||
| 978 | <ol start="3"> | ||
| 979 | <li>Set the *region* attribute for each SIP account using Sip->updateAccount() to match the region column in emergency_mapping table.</li> | ||
| 980 | </ol> | ||
| 981 | |||
| 982 | h2. Email Notifications | ||
| 983 | |||
| 984 | h3. Quota exceeded | ||
| 985 | |||
| 986 | This notification is sent out to the email address associated with SIP accounts that have the *quota* attribute set to a positive value, when the monthly quota has been exceeded. The email is generated by a CDRTool cron job task from the script: | ||
| 987 | |||
| 988 | bc(wiki). /var/www/CDRTool/scripts/OpenSIPS/quotaCheck.php | ||
| 989 | |||
| 990 | |||
| 991 | To change the email headers or the body of the notification message you must insert/update a row in cdrtool.settings mysql table. See for an example: | ||
| 992 | |||
| 993 | bc(wiki). /var/www/CDRTool/setup/mysql/custom_notifications.mysql | ||
| 994 | |||
| 995 | |||
| 996 | h3. Voicemail | ||
| 997 | |||
| 998 | The notification that contains also the actual voice message as a WAV attachment is sent out by the Asterisk voicemail server. To change the email headers or body you must change the configuration file: | ||
| 999 | |||
| 1000 | bc(wiki). /etc/asterisk/voicemail.conf | ||
| 1001 | |||
| 1002 | |||
| 1003 | This notification cannot be enabled/disabled per user, it is a global platform setting. | ||
| 1004 | |||
| 1005 | h3. Last sessions | ||
| 1006 | |||
| 1007 | An email with last received sessions in the previous 24 hours is sent out by a CDRTool cronjob script: | ||
| 1008 | |||
| 1009 | bc(wiki). /var/www/CDRTool/scripts/OpenSIPS/notifyLastSessions.php | ||
| 1010 | |||
| 1011 | |||
| 1012 | The From header of the email notification can be modified by changing the following setting from /etc/cdrtool/global.inc: | ||
| 1013 | |||
| 1014 | bc(wiki). $CDRTool['provider']['fromEmail'] ="support@ag-projects.com"; | ||
| 1015 | |||
| 1016 | |||
| 1017 | The notification is sent only if the SIP account belongs to the *missed-calls* group. |