Handbook Ce
Handbook Ce
Handbook Ce
Sipwise GmbH
<[email protected]>
ii
Contents
1 Introduction
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
2 Platform Architecture
3
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
SIP Load-Balancer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
SIP Proxy/Registrar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
SIP App-Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Media Relay
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Endpoint Registration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Basic Call . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
11
Session Keep-Alive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
12
Voicebox Calls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
13
4 Initial Installation
4.1 Prerequisites . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
15
15
16
16
ii
iii
16
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
16
17
17
18
18
20
20
21
21
22
22
22
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
23
23
24
24
6 Administrative Configuration
26
26
27
29
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
33
33
35
36
39
39
40
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
iii
iv
41
42
43
44
44
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
45
45
46
47
47
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
47
Block Modes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
48
Block Lists
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
48
48
49
49
49
51
51
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
52
53
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
55
55
57
59
59
59
59
iv
59
60
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
9 Billing Configuration
62
62
62
63
64
65
66
66
66
67
67
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
70
71
10 Provisioning interfaces
72
11 Configuration Framework
73
73
73
74
75
76
76
11.3.1 apply . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
76
11.3.2 build . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
76
11.3.3 commit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
76
11.3.4 decrypt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
vi
11.3.5 diff . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.6 encrypt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.7 help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.8 initialise . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.9 pull . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.10push . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.11services . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
77
11.3.12status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
78
12 Network Configuration
79
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
79
79
81
13.1 Firewalling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
81
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
82
82
83
13.4.1 Backup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
83
13.4.2 Recovery . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
84
84
vi
1
1.1
1 / 84
Introduction
About this Document
This document describes the architecture and the operational steps to install, operate and modify the Sipwise sip:provider CE.
The first chapter gives an introduction into the sip:provider CE. It describes what it is, what it contains and who should use it.
The second chapter guides through the installation and upgrade process of the sip:provider CE. It lines out the prerequisites and
the steps required to install it from scratch or upgrade it from an older version.
The third chapter provides an architectural overview of what software components are used within the sip:provider CE. It goes
into each of the main components and outlines how the signaling and media paths are routed through the system. It also provides
charts of basic call flows to give you an idea how the system internally works.
The fourth chapter describes the steps to configure the sip:provider CE in order to offer VoIP services to end users.
The fifth chapter goes deeper into advanced subscriber features and explains how to use them.
The sixth chapter shows the different customer self-care interfaces and describes how to configure them.
The seventh chapter describes the billing interface, so you can rate calls and export call detail records.
The eighth chapter describes in detail the steps necessary if you want to start modifying local configuration files to adapt and
extend the system.
The ninth chapter guides through the provisioning interface (SOAP and XMLRPC) system, so you can integrate it into your own or
third-party provisioning and billing systems.
The tenth chapter outlines additional tasks to protect the sip:provider CE from security exploits and attacks, as well as describes
the steps to perform regular backups and restore from them when necessary.
1.2
1.2.1
Getting Help
Community Support
We have set up the spce-user mailing list, where questions are answered on a best-effort basis and discussions can be started
with other community users.
1.2.2
Commercial Support
If you need professional help setting up and maintaining the sip:provider CE, send an email to [email protected].
Sipwise also provides training and commercial support for the platform. Additionally, we offer a migration path to the sip:provider
PRO appliance, which is the commercial, carrier-grade version of the sip:provider CE. If the user base grows on the CE, this will
allow operators to migrate seamlessly to a highly available and scalable platform with defined service level agreements, phone
support and on-call duty. Please visit www.sipwise.com for more information on commercial offerings.
1.3
2 / 84
The sip:provider CE is a SIP based Open Source Class5 VoIP soft-switch platform providing rich telephony services. It offers
a wide range of features to end users (call forwards, voicemail, conferencing, call blocking, click-to-dial, call-lists showing nearrealtime accounting information etc.), which can be configured by them using the customer-self-care web interface. For operators,
it offers a fully web-based administrative panel, allowing them to configure users, peerings, billing profiles etc., as well as viewing
real-time statistics of the system. For tight integration into existing infrastructures, it provides SOAP and XMLRPC APIs.
The sip:provider CE can be installed in a few steps within a couple of minutes and requires no knowledge about configuration files
of specific software components.
1.4
Opposed to other free VoIP software, the sip:provider CE is not a single application, but a whole software platform, the Sipwise
NGCP (Sipwise Next Generation Communication Platform), which is based on Debian GNU/Linux.
Using a highly modular design approach, the NGCP leverages popular open-source software like MySQL, Apache, Catalyst, Kamailio, SEMS, Asterisk etc. as its core building blocks. These blocks are glued together using optimized and proven configurations
and work-flows and are complemented by building blocks developed by Sipwise to provide fully-featured and easy to operate VoIP
services.
After downloading and starting the installer, it will fetch and install all the required Debian packages from the relevant Debian
repositories. The installed applications are managed by the NGCP Configuration Framework, which allows to change system
parameters in a single place, so administrators dont need to have any knowledge of the dozens of different configuration files of
the different packages. This provides a very easy and bullet-proof way of operating, changing and tweaking the otherwise quite
complex system.
Once configured, integrated web interfaces are provided for both end users and administrators to use the sip:provider CE. By using
the provided provisioning and billing APIs, it can be integrated tightly into existing OSS/BSS infrastructures to optimize work-flows.
1.5
The sip:provider CE is specifically tailored to companies and engineers trying to start or experiment with a fully-featured SIP based
VoIP service without having to go through the steep learning curve of SIP signalling, integrating the different building blocks to
make them work together in a reasonable way and implementing the missing components to build a business on top of that.
In the past, creating a business-ready VoIP service included installation and configuration of SIP software like Asterisk, OpenSER,
Kamailio etc., which can get quite difficult when it comes to implementing advanced features. It required to implement different
web interfaces, billing engines and connectors to existing OSS/BSS infrastructure. These things are now obsolete due to the CE,
which covers all these requirements.
3 / 84
Platform Architecture
The sip:provider CE platform is one single node running all necessary components of the system. The components are outlined
in the following figure:
2.1
In SIP-based communication networks, it is important to understand that the signaling path (e.g. for call setup and tear-down) is
completely independent of the media path. On the signaling path, the involved endpoints negotiate the call routing (which user
4 / 84
calls which endpoint, and via which path - e.g. using SIP peerings or going through the PSTN - the call is established) as well as
the media attributes (via which IPs/ports are media streams sent and which capabilities do these streams have - e.g. video using
H.261 or Fax using T.38 or plain voice using G.711). Once the negotiation on signaling level is done, the endpoints start to send
their media streams via the negotiated paths.
2.1.1
The components involved in SIP and Media on the sip:provider CE are shown in the following figure:
SIP Load-Balancer
The SIP load-balancer is a Kamailio instance acting as ingress and egress point for all SIP traffic to and from the system. Its a
high-performance SIP proxy instance based on Kamailio and is responsible for sanity checks of inbound SIP traffic. It filters broken
SIP messages, rejects loops and relay attempts and detects denial-of-service and brute-force attacks and gracefully handles them
to protect the underlying SIP elements. It also performs the conversion of TLS to internal UDP and vice versa for secure signaling
between endpoints and the sip:provider CE, and does far-end NAT traversal in order to enable signaling through NAT devices.
The load-balancer is the only SIP element in the system which exposes a SIP interface to the public network. Its second leg binds
in the switch-internal network to pass traffic from the public internet to the corresponding internal components.
The name load-balancer comes from the fact that in the commercial version, when scaling out the system beyond just one pair of
servers, the load-balancer instance becomes its own physical node and then handles multiple pairs of proxies behind it.
On the public interface, the load-balancer listens on port 5060 for UDP and TCP, as well as on 5061 for TLS connections. On the
internal interface, it speaks SIP via UDP on port 5060 to the other system components, and listens for XMLRPC connections on
TCP port 5060, which is used by the OSSBSS system to control the daemon.
Its config files reside in /etc/ngcp-config/templates/etc/kamailio/lb/, and changes to these files are applied
by executing ngcpcfg apply.
5 / 84
Tip
The SIP load-balancer can be managed via the commands /etc/init.d/kamailio-lb start, /etc/init.d/
kamailio-lb stop and /etc/init.d/kamailio-lb restart. Its status can be queried by executing /etc/
init.d/kamailio-lb status. Also ngcp-kamctl lb and ngcp-sercmd lb are provided for querying kamailio
functions, for example: ngcp-sercmd lb htable.dump ipban.
SIP Proxy/Registrar
The SIP proxy/registrar (or short proxy ) is the work-horse of the sip:provider CE. Its also a separate Kamailio instance running
in the switch-internal network and is connected to the provisioning database via MySQL, authenticates the endpoints, handles
their registrations on the system and does the call routing based on the provisioning data. For each call, the proxy looks up the
provisioned features of both the calling and the called party (either subscriber or domain features if its a local caller and/or callee,
or peering features if its from/to an external endpoint) and acts accordingly, e.g. by checking if the call is blocked, by placing
call-forwards if applicable and by normalizing numbers into the appropriate format, depending on the source and destination of a
call.
It also writes start- and stop-records for each call, which are then transformed into call detail records (CDR) by the mediation
system.
If the endpoints indicate negotiation of one or more media streams, the proxy also interacts with the Media Relay to open, change
and close port pairs for relaying media streams over the sip:provider CE, which is especially important to traverse NAT.
The proxy listens on UDP port 5062 in the system-internal network. It cannot be reached directly from the outside, but only via the
SIP load-balancer.
Its config files reside in /etc/ngcp-config/templates/etc/kamailio/proxy/, and changes to these files are applied by executing ngcpcfg apply.
Tip
The SIP proxy can be controlled via the commands /etc/init.d/kamailio-proxy start, /etc/init.d/kam
ailio-proxy stop and /etc/init.d/kamailio-proxy restart. Its status can be queried by executing /
etc/init.d/kamailio-proxy status. Also ngcp-kamctl proxy and ngcp-sercmd proxy are provided
for querying kamailio functions, for example: ngcp-kamctl proxy ul show.
6 / 84
feature filtering, outbound registration, outbound authentication and call length limitation as well as Session Keep-Alive handler.
Due to the fact that typical SIP proxies (like the load-balancer and proxy in the sip:provider CE) do only interfere with the content
of SIP messages where its necessary for the SIP routing, but otherwise leave the message intact as received from the endpoints,
whereas the B2BUA creates a new call leg with a new SIP message from scratch towards the called party, SIP message sizes are
reduced significantly by the B2BUA. This helps to bring the message size under 1500 bytes (which is a typical default value for the
MTU size) when it leaves the sip:provider CE. That way, chances of packet fragmentation are quite low, which reduces the risk of
running into issues with low-cost SOHO routers at customer sides, which typically have problems with UDP packet fragmentation.
The SIP B2BUA only binds to the system-internal network and listens on UDP port 5080 for SIP messages from the load-balancer
or the proxy, on UDP port 5040 for control messages from the cli tool and on TCP port 8090 for XMLRPC connections from the
OSSBSS to control the daemon.
Its configuration files reside in /etc/ngcp-config/templates/etc/sems, and changes to these files are applied by
executing ngcpcfg apply.
Tip
The SIP B2BUA can be controlled via the commands /etc/init.d/sems start, /etc/init.d/sems stop and /
SIP App-Server
The SIP App-Server is an Asterisk instance used for voice applications like Voicemail and Reminder Calls. Asterisk uses the
MySQL database as a message spool for voicemail, so it doesnt directly access the file system for user data. The voicemail
plugin is a slightly patched version based on Asterisk 1.4 to make Asterisk aware of the sip:provider CE internal UUIDs for each
subscriber. That way a SIP subscriber can have multiple E164 phone numbers, but all of them terminate in the same voicebox.
The App-Server listens on the internal interface on UDP port 5070 for SIP messages and by default uses media ports in the range
from UDP port 10000 to 20000.
The configuration files reside in /etc/ngcp-config/templates/etc/asterisk, and changes to these files are applied
by executing ngcpcfg apply.
Tip
The SIP App-Server can be controlled via the commands /etc/init.d/asterisk start, /etc/init.d/asteris
k stop and /etc/init.d/asterisk restart. Its status can be queried by executing /etc/init.d/asterisk
status
Media Relay
The Media Relay (also called mediaproxy-ng or mediaproxy ) is a Kernel-based packet relay, which is controlled by the SIP proxy.
For each media stream (e.g. a voice and/or video stream), it maintains a pair of ports in the range of port number 30000 to
40000. When the media streams are negotiated, mediaproxy opens the ports in user-space and starts relaying the packets to
the addresses announced by the endpoints. If packets arrive from different source addresses than announced in the SDP body
7 / 84
of the SIP message (e.g. in case of NAT), the source address is implicitly changed to the address the packets are received from.
Once the call is established and the mediaproxy has received media packets from both endpoints for this call, the media stream is
pushed into the kernel and is then handled by a custom Sipwise iptables module to increase the throughput of the system and to
reduce the latency of media packets.
The mediaproxy internally listens on UDP port 12222 for control messages from the SIP proxy. For each media stream, it opens
two pairs of UDP ports on the public interface in the range of 30000 and 40000 per default, one pair on odd port numbers
for the media data, and one pair on the next even port numbers for meta data, e.g. RTCP in case of RTP streams. Each
endpoint communicates with one dedicated port per media stream (opposed to some implementations which use one pair for both
endpoints) to avoid issues in determining where to send a packet to. The mediaproxy also sets the QoS/ToS/DSCP field of each
IP packet it sends to a configured value, 184 (0xB8, expedited forwarding) by default.
The kernel-internal part of the mediaproxy is facilitated through an iptables module having the target name MEDIAPROXY. If
any additional firewall or packet filtering rules are installed, it is imperative that this rule remains untouched and stays in place.
Otherwise, if the rule is removed from iptables, the kernel will not be able to forward the media packets and forwarding will fall
back to the user-space daemon. The packets will still be forwarded normally, but performance will be much worse under those
circumstances, which will be especially noticeable when a lot of media streams are active concurrently. See the section on
Firewalling for more information.
The mediaproxy configuration file is /etc/ngcp-config/templates/etc/default/ngcp-mediaproxy-ng-dae
mon, and changes to this file are applied by executing ngcpcfg apply. The UDP port range can be configured via the
config.yml file under the section rtpproxy. The QoS/ToS value can be changed via the key qos.tos_rtp.
Tip
The Media Relay can be controlled via the commands /etc/init.d/ngcp-mediaproxy-ng-daemon start, /
2.1.2
8 / 84
Endpoint Registration
The subscriber endpoint starts sending a REGISTER request, which gets challenged by a 401. After calculating the response of
the authentication challenge, it sends the REGISTER again, including the authentication response. The SIP proxy looks up the
credentials of the subscriber in the database, does the same calculation, and if the result matches the one from the subscriber,
the registration is granted.
The SIP proxy writes the content of the Contact header (e.g. sip:[email protected]:1234;transport=UDP) into its location
table (in case of NAT the content is changed by the SIP load-balancer to the IP/port from where the request was received), so
it knows where the reach a subscriber in case on an inbound call to this subscriber (e.g. sip:[email protected] is
mapped to sip:[email protected]:1234;transport=UDP and sent out to this address).
If NAT is detected, the SIP proxy sends a OPTION message to the registered contact every 30 seconds, in order to keep the NAT
binding on the NAT device open. Otherwise, for subsequent calls to this contact, the sip:provider PRO wouldnt be able to reach
the endpoint behind NAT (NAT devices usually drop a UDP binding after not receiving any traffic for ~30-60 seconds).
9 / 84
By default, a subscriber can register 5 contacts for an Address of Record (AoR, e.g. sip:[email protected]).
10 / 84
10
11 / 84
Basic Call
11
12 / 84
The calling party sends an INVITE (e.g. sip:[email protected]) via the SIP load-balancer to the SIP proxy. The proxy
replies with an authorization challenge in the 407 response, and the calling party sends the INVITE again with authentication
credentials. The SIP proxy checks if the called party is a local user. If it is, and if there is a registered contact found for this
user, then (after various feature-related tasks for both the caller and the callee) the Request-URI is replaced by the URI of the
registered contact (e.g. sip:[email protected]:1234;transport=UDP). If its not a local user but a numeric user, a proper
PSTN gateway is being selected by the SIP proxy, and the Request-URI is rewritten accordingly (e.g. sip:+43123456789@
2.3.4.5:5060).
Once the proxy has finished working through the call features of both parties involved and has selected the final destination for the
call, and - optionally - has invoked the Media Relay for this call, the INVITE is sent to the SIP B2BUA. The B2BUA creates a new
INVITE message from scratch (using a new Call-ID and a new From-Tag), copies only various and explicitly allowed SIP headers
from the old message to the new one, filters out unwanted media capabilities from the SDP body (e.g. to force audio calls to use
G.711 as a codec) and then sends the new message via the SIP load-balancer to the called party.
SIP replies from the called party are passed through the elements back to the calling party (replacing various fields on the B2BUA
to match the first call leg again). If a reply with an SDP body is received by the SIP proxy (e.g. a 183 or a 200), the Media Relay
is invoked again to prepare the ports for the media stream.
Once the 200 is routed from the called party to the calling party, the media stream is fully negotiated, and the endpoints can start
sending traffic to each outer (either end-to-end or via the Media Relay). Upon reception of the 200, the SIP proxy writes a start
record for the accounting process. The 200 is also acknowledged with an ACK message from the calling party to the called party,
according to the SIP 3-way handshake.
Either of the parties can tear down the media session at any time by sending a BYE, which is passed through to the other
party. Once the BYE reaches the SIP proxy, it instructs the Media Relay to close the media ports, and it writes a stop record for
accounting purposes. Both the start- and the stop-records are picked up by the mediator service in a regular interval and are
converted into a Call Detail Record (CDR), which will be rated by the rate-o-mat process and can be billed to the calling party.
Session Keep-Alive
The SIP B2BUA acts as refresher for the Session-Timer mechanism as defined in RFC 4028. If the endpoints indicate support
for the UPDATE method during call-setup, then the SIP B2BUA will use an UPDATE message if enabled per peer, domain or
subscriber via Provisioning to check if the endpoints are still alive and responsive. Both endpoints can renegotiate the timer
within a configurable range. All values can be tuned using the Admin Panel or the APIs using Peer-, Domain- and SubscriberPreferences.
Tip
Keep in mind that the values being used in the signaling are always half the value being configured. So if you want to send a
keep-alive every 300 seconds, you need to provision sst_expires to 600.
If one of the endpoints doesnt respond to the keep-alive messages or answers with 481 Call/Transaction Does Not
Exist, then the call is torn down on both sides. This mechanism prevents excessive over-billing of calls if one of the endpoints
is not reachable anymore or "forgets" about the call. The BYE message sent by the B2BUA triggers a stop-record for accounting
and also closes the media ports on the Media Relay to stop the call.
12
13 / 84
Beside the Session-Timer mechanism to prevent calls from being lost or kept open, there is a maximum call length of 21600
seconds per default defined in the B2BUA. This is a security/anti-fraud mechanism to prevent overly long calls causing excessive
costs.
Voicebox Calls
Calls to the Voicebox (both for callers leaving a voicemail message and for voicebox owners managing it via the IVR menu) are
passed directly from the SIP proxy to the App-Server without a B2BUA. The App-Server maintains its own timers, so there is no
risk of over-billing or overly long calls.
In such a case where an endpoint talks via the Media Relay to a system-internal endpoint, the Media Relay bridges the media
streams between the public in the system-internal network.
In case of an endpoint leaving a new message on the voicebox, the Message-Waiting-Indication (MWI) mechanism triggers the
sending of a unsolicited NOTIFY message, passing the number of new messages in the body. As soon as the voicebox owner
dials into his voicebox (e.g. by calling sip:[email protected] from his SIP account), another NOTIFY message is
sent to his devices, resetting the number of new messages.
13
14 / 84
Important
The sip:provider CE does not require your device to subscribe to the MWI service by sending a SUBSCRIBE (it would
rather reject it). On the other hand, the endpoints need to accept unsolicited NOTIFY messages (that is, a NOTIFY
without a valid subscription), otherwise the MWI service will not work with these endpoints.
14
15 / 84
3.1
The system upgrade from sip:provider CE v2.7 to 2.8 will perform a couple of tasks:
For upgrading the sip:provider CE from v2.7 to the latest 2.8 release, execute the following commands:
ngcp-upgrade
The upgrade script will ask you to confirm that you want to start. Read the given information carefully, and if you agree, proceed
with y.
The upgrade process will take several minutes, depending on your network connection and server performance. After everything
has been updated successfully, it will finally ask you to reboot your system. Confirm to let the system reboot (it will boot with an
updated kernel).
Once up again, double-check your config file /etc/ngcp-config/config.yml (sections will be rearranged now and will contain more
parameters) and your domain/subscriber/peer configuration and test the setup. You can find a backup of some important configuration files of your existing 2.7 installation under /var/backup/ngcp-2.8-* (where * is a place holder for a timestamp) in case you
need to roll back something at any time. A log file of the upgrade procedure is available at /var/backup/ngcp-2.8-*/upgrade.log.
15
16 / 84
Initial Installation
4.1
Prerequisites
For an initial installation of the sip:provider CE, it is mandatory that your production environment meets the following criteria:
H ARDWARE R EQUIREMENTS
Recommended: Dual-core, x86_64 compatible, 3GHz, 4GB RAM, 128GB HDD
Minimum: Single-core, x86_64 compatible, 1GHz, 2GB RAM, 16GB HDD
I NTERNET C ONNECTION
Hardware needs connection to the Internet
Important
Only Debian Squeeze (6.0) 64-bit is currently supported as a host system for the sip:provider CE.
Important
It is HIGHLY recommended that you use a dedicated server (either a physical or a virtual one) for sip:provider CE,
because the installation process will wipe out existing MySQL databases and modify several system configurations.
4.2
4.2.1
You need to install Debian Squeeze (6.0) 64-bit on the server. A basic installation without any additional task selection (like
Desktop System, Web Server etc.) is sufficient.
Tip
Sipwise recommends using the Netinstall ISO (md5sum) as installation medium.
16
17 / 84
Important
If you use other kinds of installation media (e.g. provided by your hosting provider), prepare for some issues that might
come up during installation. For example, you might be forced to manually resolve package dependencies in order to
install the sip:provider CE. Therefore, it is HIGHLY RECOMMENDED to use a clean Debian installation to simplify the
installation process.
Warning
Be aware that this step will break your web-based system administration provided by Dreamhost. Only do it if you are
certain that you wont need it.
4.2.2
The sip:provider CE is based on the Sipwise NGCP, so download and install the Sipwise NGCP installer package:
PKG=ngcp-installer-2.8.deb
wget http://deb.sipwise.com/spce/${PKG}
dpkg -i ${PKG}
ngcp-installer
The installer will ask you to confirm that you want to start the installation. Read the given information carefully, and if you agree,
proceed with y.
The installation process will take several minutes, depending on your network connection and server performance. If everything
goes well, the installer will (depending on the language you use), show something like this:
17
18 / 84
During the installation, you can watch the background processing by executing the following command on a separate console:
tail -f /tmp/ngcp-installer.log
4.3
For quick test deployments, pre-installed virtualization images are provided. These images are intended to be used for quick test,
not recommended for production use.
4.3.1
Vagrant is an open-source software for creating and configuring virtual development environments. Sipwise provides a so called
Vagrant base box for your service, to easily get direct access to your own sip:provider CE Virtual Machine without any hassles.
Note
The following software must be installed to use Vagrant boxes:
VirtualBox v.4.2.16+
Vagrant v.1.2.4+
As soon as the machine is up and ready you should have your local copy of sip:provider CE with the following benefits:
all the software and database are automatically updated to the latest available version
the system is configured to use your LAN IP address (received over DHCP)
basic SIP credentials to make SIP-2-SIP calls out of the box are available
vagrant ssh
or login to Administrator web-interface at https://127.0.0.1:1443 (with default user administrator and password administrator ).
There are two ways to access VM resources, through NAT or Bridge interface:
18
19 / 84
Note
a.b.c.d is IP address of VM machine received from DHCP; x.y.z.p is IP address of your host machine
Host-only address
LAN address
Notes
SSH
ssh://127.0.0.1:2222
ssh://a.b.c.d:22 or
ssh://x.y.z.p:2222
ssh"
Administrator interface
https://127.0.0.1:1443
https://a.b.c.d:1443 or
https://x.y.z.p:1443
Provisioning interfaces
https://127.0.0.1:3443
https://127.0.0.1:2443
https://a.b.c.d:443 or
https://x.y.z.p:3443
https://a.b.c.d:2443 or
https://x.y.z.p:2443
SIP interface
not available
sip://a.b.c.d:5060
VM IP address (a.b.c.d), as well as SIP credentials will be printed to terminal during "vagrant up" stage, e.g.:
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
[20_add_sip_account]
https://192.168.1.103:1443
vagrant halt
vagrant destroy
vagrant box remove spce-2.8
19
20 / 84
Default SSH login is root and password is sipwise. SSH connection details can be displayed via:
vagrant ssh-config
You can download a Vagrant box for VirtualBox from here manually (checksums: sha1, md5).
4.3.2
VirtualBox image
You can download a VirtualBox image from here (checksums: sha1, md5). Once you have downloaded the file you can import it
to VirtualBox via its import utility.
The format of the image is ova. If you have VirtualBox 3.x running, which is not compatible with ova format, you need to extract
the file with any tar compatible software and import the ovf file which is inside the archive.
On Linux, you can do it like this:
On Windows, right-click on the ova file, choose Open with and select WinZIP or WinRAR or any other application able to extract
tar archives. Extract the files to any place and import the resulting ovf file in VirtualBox.
Considerations when using this virtual machine:
4.3.3
VMware image
You can download a VMware image from here (checksums: sha1, md5). Once you have downloaded the file just extract the zip
file and copy its content to your virtual machines folder.
Considerations when using this virtual machine:
20
21 / 84
After the installation went through successfully, you are ready to adapt the system parameters to your needs to make the system
work properly.
5.1
Network Configuration
If you have only one network card inside your system, its device name is eth0, its configured and only IPV4 is important to you
then there should be nothing to do for you at this stage. If multiple network cards are present, your network card does not use
eth0 for its device name or you need IPv6 then the only parameter you need to change at this moment is the listening address for
your SIP services.
To do this, you have to specify the interface where your listening address is configured, which you can do with the following
command (assuming your public interface is eth0):
If you want to enable IPv6 as well, you have to set the address on the proper interface as well, like this (assuming you have an
IPv6 address fdda:5cc1:23:4:0:0:0:1f on interface eth0):
Tip
Always use a full IPv6 address with 8 octets, leaving out zero octets (e.g. fdda:5cc1:23:4::1f) is not allowed.
If you havent fully configured your network interfaces, do this by adapting also the file /etc/network/interfaces:
vim /etc/network/interfaces
Add or adapt your interface configuration accordingly. For example, if you just want to use the system in your internal network
192.168.0.0/24, it could look something like this:
auto lo
iface lo inet loopback
auto eth0
21
22 / 84
/etc/init.d/networking restart
5.2
In order to apply the changes you made to /etc/ngcp-config/config.yml, you need to execute the following command to re-generate
your configuration files and to automatically restart the services:
ngcpcfg apply
Tip
At this point, your system is ready to serve.
5.3
During installation, the system user cdrexport is created. This jailed system account is supposed to be used to export CDR files
via sftp/scp. Set a password for this user by executing the following command:
passwd cdrexport
The installer has set up a MySQL database on your server. You need to set a password for the MySQL root user to protect it from
unauthorized access by executing this command:
For the Administrative Web Panel located at https://<your-server-ip>:1443/, a default user administrator with password administrator has been created. Connect to the panel (accept the SSL certificate for now) using those credentials and change the password
of this user by going to System AdministrationAdministrators and clicking edit.
5.4
The NGCP installer will install mailx (which has Exim4 as MTA as a default dependency) on the system, however the MTA is not
configured by the installer. If you want to use the Voicemail-to-Email feature of the Voicebox, you need to configure your MTA
properly. If you are fine to use the default MTA Exim4, execute the following command:
dpkg-reconfigure exim4-config
22
23 / 84
Depending on your mail setup in your environment (whether to use a smarthost or not), configure Exim accordingly. In the most
simple setup, apply the following options when prompted for it:
General type of mail configuration: internet site;mail is sent and received directly using SMTP
System mail name: the FQDN of your server, e.g. ce.yourdomain.com
IP-addresses to listen on for incoming SMTP connections: 127.0.0.1
Other destinations for which mail is accepted: the FQDN of your server, e.g. ce.yourdomain.com
Domains to relay mail for: leave empty
Machines to relay mail for: leave empty
Keep number of DNS-queries minimal (Dial-on-Demand)? No
Delivery method for local mail: mbox format in /var/mail/
Split configuration into small files? No
Important
You are free to install and configure any other MTA (e.g. postfix) on the system, if you are more comfortable with that.
5.5
You have a typical test deployment now and you are good to go, however you may need to do extra configuration depending on
the devices you are using and functionality you want to achieve.
5.5.1
As reported by many users, Audiocodes devices suffer from a problem where they replace 127.0.0.1 address in RecordRoute headers (added by the sip:provider CEs internal components) with its own IP address. The problem has been reported
to Audiocodes but as of end 2012 the fixed firmware is not available yet so supposedly the whole range of Audiocodes devices,
including but not limited to the MP202, MP252 CPEs as well as Audiocodes media gateways, is malfunctioning. As a workaround,
you may change the internal IP address from 127.0.0.1 to some dummy network interface. Please execute the following
command (in this example 192.168.2.2 is a new internal IP address):
auto dummy0
iface dummy0 inet static
address 192.168.2.2
netmask 255.255.255.0
23
24 / 84
Refer to the Network Configuration chapter for more details about the ngcp-network tool.
Apply configuration:
ngcpcfg apply
5.5.2
By default, the load-balancer in sip:provider CE listens on the UDP and TCP ports 5060 (kamailiolbport) and TLS port 5061
(kamailiolbtlsport). Should you need to setup one or more extra non-standard listening ports in addition to those standard
ports, please edit the kamailiolbextra_sockets option in your /etc/ngcp-config/config.yml file.
The correct format consists of a label and value like this:
extra_sockets:
port_5064: udp:10.15.20.108:5064
test: udp:10.15.20.108:6060
The label is shown in outbound_socket peer preference (if you want to route calls to specific peer out via specific socket);
the value must contain a transport specification as in example above (udp, tcp or tls).
Important
The media relay uses one main primary external IP address. You should make sure it is reachable to all of your subscribers and peers (or disable the media relay for subscribers by checking the never_use_rtpproxy preference if
they have routable IP addresses) - refer to the Security and Maintenance chapter for more details on firewalling.
Apply configuration:
ngcpcfg apply
5.6
Whats next?
To test and use your installation, you need to follow these steps now:
24
25 / 84
25
26 / 84
Administrative Configuration
To be able to configure your first test clients, you will need a SIP domain and some subscribers in this domain. Throughout this
steps, lets assume youre running the NGCP on the IP address 1.2.3.4, and you want this IP to be used as SIP domain. This
means that your subscribers will have an URI like [email protected].
Tip
You can of course set up a DNS name for your IP address (e.g. letting sip.yourdomain.com point to 1.2.3.4) and use this DNS
name throughout the next steps, but well keep it simple and stick directly with the IP as a SIP domain for now.
Warning
Once you started adding subscribers to a SIP domain, and later decide to change the domain, e.g. from 1.2.3.4 to
sip.yourdomain.com, youll need to recreate all your subscribers in this new domain. Its currently not possible to easily
change the domain part of a subscriber.
Go to the Administrative Web Panel (Admin Panel) running on https://<ce-ip>:1443/ and follow the steps below. The default user
on the system is administrator with the password administrator, if you havent changed it already in [?simpara].
6.1
Creating Domains
Go to System AdministrationDomains. Youll see a form Create Domain, where you have to provide the name of your SIP
domain. In our example well put in 1.2.3.4 there and click add. The newly created domain now shows up under Edit Domains.
If you also use IPv6 and you want to use this address as a domain (opposed to creating an AAAA record for it), put it there as well
and enclose it by square brackets, e.g. [fdda:5cc1:23:4::1f].
26
27 / 84
Tip
You will most likely want to assign Rewrite Rule Set to your domain via Preferences tab. The usage of Rewrite Rule Sets is
explained in Section 6.5.
6.2
Creating Accounts
An account on the NGCP is a billing container, which contains one or more subscribers for a customer. In this billing container,
you can define which Billing Profile is used for calls being placed by the subscribers of this account.
To create a new account, go to User AdministrationAccounts and click Create new account. For our first tests, we will use the
default values, so just click Save.
27
28 / 84
You will be presented with an overview of the new account, showing basic Account Information, the Account Balance (which will
only get relevant when you start using your own Billing Profile) and the list of Subscribers for this account, which is currently empty.
28
6.3
29 / 84
Creating Subscribers
In the Subscribers section at the bottom of the account information for the account you created before, click create new to create
a new subscriber for this account. You will be presented with the Master Data form, where you have to fill in the following options:
web username: This is the user part of the username the subscriber may use to log into her Customer Self Care Interface. The
user part will be automatically suffixed by the SIP domain you choose for the SIP URI. Usually the web username is identical to
the SIP URI, but you may choose a different naming schema.
Caution
The web username needs to be unique. The system will return a fault if you try to use the same web username twice.
web password: This is the password for the subscriber to log into her Customer Self Care Interface. It must be at least 6
characters long.
E.164 number: This is the telephone number mapped to the subscriber, separated into Country Code (CC), Area Code (AC)
and Subscriber Number (SN). For the first tests, you can set a made-up number here and change it later when you get number
blocks assigned by your PSTN interconnect partner. So in our example, well use 43 as CC, 99 as AC and 1001 as SN to form
the phantasy number +43 99 1001.
Tip
This number can actually be used to place calls between local subscribers, even if you dont have any PSTN interconnection.
This comes in handy if you use phones instead of soft-clients for your tests. The format in which this number can be dialled so
the subscriber is reached is defined in Section 6.5.
Important
NGCP allows single subscriber to have multiple E.164 numbers to be used as aliases for receiving incoming calls. Also
NGCP supports "implied" extensions, e.g. if a subscriber has number 012345, but somebody calls 012345100, then
it first tries to send the call to number 012345100 (even though the user is registered as myusername), and only after
404 it falls back to the user-part for which the user is registered.
Tip
The interface ensures that any numbers entered conform to the local numbering plan. The numbering plan is defined by a set
of three regular expressions, which can be found and edited in config.yml under the key ossbss.provisioning.
routing. The defaults should work for most setups, but under some circumstances (e.g. there are no area codes) it may be
necessary to customize these.
SIP URI: Insert the user part of the URI into the first field (e.g. user1) and select the domain you want to put this subscriber into
in the drop-down.
29
30 / 84
Caution
With the default system settings, the user part has to have at least one alphabetic character, so its not possible by
default to just use a number here. To allow that, on the console set ossbssprovisioning allow_numeric_usernames
to 1 in /etc/ngcp-config/config.yml and execute the command ngcpcfg apply. If you want for example to set a
numeric customer id as the SIP user, make sure it does not overlap with actual phone numbers, otherwise these calls
will be routed to the SIP user instead of the phone number.
SIP password: The password of your subscriber to authenticate on the SIP proxy. It must be at least 6 characters long.
administrative: If you have multiple subscribers in one account and set this option for one of them, this subscriber can administrate other subscribers via the Customer Self Care Interface.
Click Save to create the subscriber. You will be presented with a status overview of the subscriber, showing the Active Device
Registration (your clients registered on the system using this subscriber) and your Active Peer Registration (the registration of this
subscriber at a remote peer, done by the system in behalf of the user; this is useful if your sip:provider CE is acting as an SBC in
front of another soft-switch; this scenario will be covered in Section 7).
30
31 / 84
Repeat the creation of accounts and subscribers for all your test accounts. You should have at least 3 subscribers to test all the
functionality of the NGCP.
Tip
At this point, youre able to register your subscribers to the NGCP and place calls between these subscribers.
You should now revise the subscriber Preferences, in particular the CLI options that control what is used as user-provided and
network-provided calling numbers. Click the tab Preferences in the top horizontal menu to reach this view.
31
32 / 84
For outgoing calls, you may define multiple numbers or patterns to control what a subscriber is allowed to send as user-provided
calling numbers using the allowed_clis preference.
If allowed_clis does not match the number sent by the subscriber, then the number configured in cli (the network-provided
number) preference will be used as user-provided calling number also.
You can override any user-provided number coming from the subscriber using the user_cli preference.
In this example, we click on the Edit button next to the allowed_clis preference and allow all numbers starting with 4311001 as
well as the number 43800999000.
32
6.4
33 / 84
Creating Peerings
If you want to terminate calls at or allow calls from 3rd party systems (e.g. PSTN gateways, SIP trunks), you need to create SIP
peerings for that. To do so, go to System AdministrationSIP Peerings. There you can add peering groups, and for each peering
group add peering servers. Every peering group needs a peering contract for correct interconnection billing.
6.4.1
In order to create peering groups, you must create at least one peering contract. It defines, which billing profile is going to be used
for calls to the corresponding peering groups. In this example, we will use the Default Billing Profile, because we havent set up
proper profiles yet.
In the SIP Peering Contracts section, click create new to add a peering contract.
33
34 / 84
You will be presented with a form to set the billing profile and some contact details for the contract. To create a very basic dummy
profile, we will set the following values:
34
6.4.2
35 / 84
In System AdministrationSIP Peerings, create a new peering group in the section Create Peering Group. You will usually have
one peering group per carrier youre planning to send traffic to and receive traffic from. We will create a test group using the
peering contract added before:
35
36 / 84
6.4.3
In the group created before, you need to add peering servers to route calls to and receive calls from. To do so, click on the Name
of your created group in the section SIP Peering Groups.
36
37 / 84
Then add your first peering server in the section Peering Servers. In this example, we will create a peering server with IP 2.3.4.5
and port 5060:
Name: test-gw-1
IP Address: 2.3.4.5
Hostname: leave empty
Port: 5060
Protocol: UDP
Weight: 1
Tip
The hostname field for a peering server is optional. Usually, the IP address of the peer is used as domain part in the Request
URI. Some peers may require you to set a particular hostname instead of the IP address there, which can be done by filling in
this field. The IP address must always be given though, and the request will always be sent to the IP address, no matter what
you put into the hostname field.
Tip
If you want to add a peering server with an IPv6 address, enter the address without surrounding square brackets into the IP
Address column, e.g. ::1.
37
38 / 84
You will now see an additional section Peering Rules after your list of peering servers. There you have to define which numbers to
route via this peering group.
Important
If you do not add at least one peering rule to your group, the servers in this group will NOT be used for outbound calls.
The NGCP will however allow inbound calls from the servers in this group even without peering rules.
Since the previously created peering group will be the only one in our example, we have to add a default rule to route all calls via
this group. To do so, create a new peering rule with the following values:
38
39 / 84
Tip
If you set the caller or callee rules to refine what is routed via this peer, enter all phone numbers in full E.164 format, that is
<cc><ac><sn>. TIP: The Caller Pattern field covers the whole URI including the subscriber domain, so you can only allow
certain domains over this peer by putting for example @example\.com into this field.
Important
The selection of peering servers for outbound calls is done in the following order: 1. length of the matching peering
rules for a call. 2. priority of the peering group. 3. weight of the peering servers in the selected peering group. After one
or more peering group(s) is matched for an outbound call, all servers in this group are tried, according to their weight
(lower weight has more precedence). If a peering server replies with SIP codes 408, 500 or 503, or if a peering
server doesnt respond at all, the next peering server in the current peering group is used as a fallback, one after the
other until the call succeeds. If no more servers are left in the current peering group, the next group which matches the
peering rules is going to be used.
6.4.4
39
40 / 84
Important
If you do NOT authenticate against a peer host, then the caller CLI is put into the From and P-Asserted-Ide
Tip
You will notice that these three preferences are also shown in the Subscriber Preferences for each subscriber. There you can
override the authentication details for all peer host if needed, e.g. if every user authenticates with his own separate credentials
at your peering provider.
40
41 / 84
Important
Be aware that this will force SEMS to restart, which will drop all calls.
6.5
You would normally begin with creating a Rewrite Rule Set for your SIP domains. This is used to control what an end user can dial
for outbound calls, and what is displayed as the calling party on inbound calls. The subscribers within a domain inherit Rewrite
Rule Sets of that domain, unless this is overridden by a subscriber Rewrite Rule Set preference.
To create a new Rewrite Rule Set, go to System AdministrationRewrite Rule Sets. There you can create a Set identified by a
name. This name is later shown in your peer-, domain- and user-preferences where you can select the rule set you want to use.
Click Add, and then on the link of the Rewrite Rule Set name to define the rules for this set.
41
42 / 84
Tip
In Europe, the following formats are widely accepted: +<cc><ac><sn>, 00<cc><ac><sn> and 0<ac><sn>. Also, some countries
allow the areacode-internal calls where only subscriber number is dialed to reach another number in the same area. Within this
section, we will use these formats to show how to use rewrite rules to normalize and denormalize number formats.
6.5.1
These rules are used to normalize user-provided numbers (e.g. passed in From Display Name or P-Preferred-Identity headers)
into E.164 format. In our example, well normalize the three different formats mentioned above into E.164 format.
S TRIP LEADING 00 OR +
Match Pattern: (00|\+)([1-9][0-9]+)$
Replacement Pattern: \2
Description: International to E.164
Tip
When routing a call, the rewrite processing is stopped after the first match of a rule, starting from top to bottom. If you have two
rules (e.g. a generic one and a more specific one), where both of them would match some numbers, drag&drop the rules into
the appropriate order.
42
6.5.2
43 / 84
These rules are used to rewrite the number the end user dials to place a call to a standard format for routing lookup. In our
example, we again allow the three different formats mentioned above and again normalize them to E.164, so we put in the same
rules as for the caller.
S TRIP LEADING 00 OR +
Match Pattern: (00|\+)([1-9][0-9]+)$
Replacement Pattern: \2
Description: International to E.164
43
44 / 84
Tip
Our provided rules will only match if the caller dials a numeric number. If he dials an alphanumeric SIP URI, none of our rules
will match and no rewriting will be done. You can however define rules for that as well. For example, you could allow your end
users to dial support and rewrite that to your support hotline using the match pattern support$ and the replace pattern
6.5.3
These rules are used to rewrite the calling party number for a call to an end user. For example, if you want the device of your
end user to show 0<ac><sn> if a national number calls this user, and 00<cc><ac><sn> if an international number calls, put the
following rules there.
Tip
Note that both of the rules would match a number starting with 43, so drag&drop the national rule to be above the international
one (if its not already the case).
6.5.4
These rules are used to rewrite the called party number immediately before sending out the call on the network. This gives you an
extra flexibility by controlling the way request appears on a wire, when your SBC or other device expects the called party number
to have a particular tech-prefix. It can be used on calls to end users too if you want to do some processing in intermediate SIP
device, e.g. apply legal intercept selectively to some subscribers.
44
45 / 84
6.5.5
To route an Emergency Call to a Peer, you can select a specific peering group by adding a peering rule with a callee prefix set to
6.5.6
Once you have finished to define your Rewrite Rule Sets, you need to assign them. For sets to be used for subscribers, you
can assign them to their corresponding domain, which then acts as default set for all subscribers. To do so, go to System
AdministrationDomains and click on the domain name you want the set to assign to. Click on Edit and select the Rewrite Rule
Set created before.
45
46 / 84
You can do the same in the Preferences tab of your subscribers. That way, you can finely control down to an individual user the
dial-plan to be used.
6.5.7
For each peering server, you can use one of the Rewrite Rule Sets that was created previously as explained in Section 6.5 (keep
in mind that special variables ${caller_ac} and ${caller_cc} can not be used when the call comes from a peer). To do
so, click on the name of the peering server, look for the preference called Rewrite Rule Sets.
If your peering servers dont send numbers in E.164 format <cc><ac><sn>, you need to create Inbound Rewrite Rules for each
peering server to normalize the numbers for caller and callee to this format, e.g. by stripping leading + or put them from national
into E.164 format.
Likewise, if your peering servers dont accept this format, you need to create Outbound Rewrite Rules for each of them, for
example to append a + to the numbers.
46
47 / 84
The sip:provider CE provides a large amount of subscriber features in order to offer compelling VoIP services to end customers,
and also to cover as many deployment scenarios as possible. In this chapter, we will go over the features and describe their
behavior and their use cases.
7.1
There are two different methods to provide fine-grained call admission control to both subscribers and admins. One is Block Lists,
where you can define which numbers or patterns can be called from a subscriber to outbound direction and which numbers or
patterns are allowed to call a subscriber in inbound direction. The other is NCOS Levels, where the admin predefines rules for
outbound calls, which are grouped in certain levels. The user can then just choose the level, or the admin can restrict a user to
a certain level. Also sip:provider CE offers some options to restrict the IP addresses that subscriber is allowed to use the service
from. The following chapters will discuss these features in detail.
7.1.1
Block Lists
Block Lists provide a way to control which users/numbers are able to call or to be called, based on a subscriber level.
Block Lists are separated into Administrative Block Lists (adm_block_*) and Subscriber Block Lists (block_*). They both have
the same behavior, but Administrative Block Lists take higher precedence. Administrative Block Lists are only accessible by the
system administrator and can thus be used to override any Subscriber Block Lists, e.g. to block certain destinations. The following
break-down of the various block features apply to both types of lists.
47
48 / 84
Block Modes
Block lists can either be whitelists or blacklists and are controlled by the User Preferences block_in_mode, block_outmode__ and
their administrative counterparts.
The blacklist mode tells the system to allow anything except the entries in the list. This mode is used if you want to just block
certain numbers and allow all the rest.
The whitelist mode indicates to reject anything except the entries in the list. This is used if you want to enforce a strict policy
and allow only selected destinations or sources.
You can change a list mode from one to the other at any time.
Block Lists
The list contents are controlled by the User Preferences block_in_list, block_out_list and their administrative counterparts. Click
on the Edit button in the User Preferences view to define the list entries.
In block list entries, you can provide shell patterns like * and []. The behavior of the list is controlled by the block_xxx_mode
feature (so they are either allowed or rejected). In our example above we have block_out_mode set to blacklist, so all calls to US
numbers and to the Austrian number +431234567 are going to be rejected.
48
49 / 84
7.1.2
NCOS Levels
NCOS Levels provide predefined lists of allowed or denied destinations for outbound calls of local subscribers. Compared to Block
Lists, they are much easier to manage, because they are defined on a global scope, and the individual levels can then be assigned
to each subscriber. Again there is the distinction for user- and administrative-levels.
NCOS levels can either be whitelists or blacklists.
The blacklist mode indicates to allow everything except the entries in this level. This mode is used if you want to just block
certain destinations and allow all the rest.
The whitelist mode indicates to reject anything except the entries in this level. This is used if you want to enforce a strict
policy and allow only selected destinations.
Enter a name, select the mode and add a description, then click the Add button.
49
50 / 84
In the Number Patterns section you can enter multiple patterns to define your level, one after the other.
In this example, we block (since the mode of the level is blacklist) all numbers starting with 439. Click the Add button to save the
entry in the level.
The option include local area code in list for a blacklist means that calls within the area code of the subscribers are denied, and
for whitelist that they are allowed, respectively. For example if a subscriber has country-code 43 and area-code 1, then selecting
this checkbox would result in an implicit entry 431.
50
51 / 84
Navigate down to the ncos and adm_ncos preference drop-downs and select your NCOS Level. Navigate further down to the end
of the preference list and press the Save button.
You can assign the NCOS level to all subscribers within a particular domain. To do so, navigate to System AdministrationSubscribers,
select domain you want to edit, go to the Preferences Tab and press the Edit button. Select your NCOS Level in the ncos or
adm_ncos preference drop-down. Press the Save button.
Note: if both domain and subscriber have same NCOS preference set (either ncos or adm_ncos, or both) the subscribers preference is used. This is done so that you can override the domain-global setting on the subscriber level.
7.1.3
IP Address Restriction
The sip:provider CE provides subscriber preference allowed_ips to restrict the IP addresses that subscriber is allowed to use the
service from. If the REGISTER or INVITE request comes from an IP address that is not in the allowed list, the sip:provider CE will
reject it with a 403 message. Also a voice message can be played when the call attempt is rejected (if configured).
51
52 / 84
By default, allowed_ips is an empty list which means that subscriber is not restricted. If you want to configure a restriction, navigate
to User AdministrationSubscribers, search for the subscriber you want to edit, go to the Preferences Tab and scroll down to the
allowed_ips preference.
You can enter multiple allowed IP addresses or IP address ranges one after another. Click the Add button to save each entry in
the list. Click the Delete button if you want to remove some entry.
7.2
The sip:provider CE provides the capabilities for normal call forwarding (deflecting a call for a local subscriber to another party
immediately or based on events like the called party being busy or doesnt answer the phone for a certain number of seconds)
and serial call hunting (sequentially executing a group of deflection targets until one of them succeeds). Targets can be stacked,
which means if a target is also a local subscriber, it can have another call forward or hunt group which is executed accordingly.
Call Forwards and Call Hunting Groups can either be executed unconditionally or based on a Time Set Definition, so you can
define deflections based on time period definitions (e.g. Monday to Friday 8am to 4pm etc).
52
7.2.1
53 / 84
A Call Forward is always based on a Destination Set, which contains one (for normal Call Forwards) or more (for Hunt Groups)
destinations.
To define a Destination Set, go to the Preferences Tab of a subscriber and click on the Edit Destination Sets button in the Call
Forwards section.
You can create a Destination Set by setting a name for the set and press the Add button.
Once you created your destination set, you can add destinations to it. Select either one of the internal services (Voicebox, Fax2Mail
if available, Conferencing) or define a number or SIP URI. You can also define how long to try this destination (which is important
for Hunt Groups if you want to let a destination only ring for a certain amount of seconds). Click the Add button once you are done
to save the destination.
53
54 / 84
If you want to add more destinations for a Destination Set in order to create a Hunt Group, click the Edit button of the Destination
Set.
To rearrange the order of the destinations within a Destination Set, just drag&drop the entries to the proper position.
54
55 / 84
You can define multiple destination sets to be used for different types of forwards (unconditional, busy etc.) and for different Time
Sets (using one Destination Set during office hours and else another one).
7.2.2
In order to activate a Destination Set to be used always (that is, without a Time Set constraint), go back to your Call Forwards
section in the Preferences view and select the Destination Set you want to use for the particular scenario, then press the Add
button. Since no Time Sets have been defined yet, you can only select always for the period option.
7.2.3
To define certain time periods in which a Destination Set should be active, click on the Edit Time Sets button in the Call Forwards
section.
55
56 / 84
Like with Destination Sets, you can create multiple Time Sets to be used for different scenarios, and you can assign multiple Time
Sets to a specific Call Forward.
To create a Time Set, just provide a name and click the Add button.
Once the Time Set is created, you can add Time Period Definitions. To do so, drag&drop the building blocks from the top into the
slots of your Time Set.
Important
The ranges mean from through to, so an hour range 08-17 means from start of hour 8 to end of hour 17, which is
08:00:00-17:59:59. Also note that ranges wrap around nicely, so an hour range definition 23-01 works perfectly fine.
To define a more complex period definition which defines after-office-hours (Mo-Fri from 00:00 to 08:29 and from 18:00-00:00, and
Sat-Sun the whole day), you need three different rules as shown in the figure below:
56
57 / 84
The first row defines the weekend, which is the whole Saturday and Sunday.
The second row defines the time on Weekdays (Mon-Fri) from 18:00 to 07:59 (again remember the meaning through).
The last row defines the half hour on Weekdays (Mon-Fri) from 08:00 to 08:29.
Once youve defined a row, click the Add button next to the row. If you want to add more rows to a Time Set, just click the Edit
button next to the Time Set Name.
7.2.4
To use a previously defined Time Set, go back to the Call Forward section of the Preferences view and select it from the drop-down
of the appropriate scenario, along with a Destination Set. If you already use a Destination Set, click the Edit button to add a Time
Set for this scenario. Note that you can add multiple rows per scenario. For our after office hours example above, we
can add a new Time Set called public holidays, which defines all public holidays where your office is closed, then add both
of them for the Call Forward Unconditional scenario, like this:
57
58 / 84
Of course you can set different Destination Sets for different Time Sets for a specific Call Forward scenario.
58
59 / 84
There are two ways for end users to maintain their subscriber settings: via the Customer Self-Care Web Interface and via Vertical
Service Codes using their SIP phones.
8.1
The NGCP provides a web panel for end users (CSC panel) to maintain their subscriber accounts, which is running on https://<ceip>. Every subscriber can log in there, change subscriber feature settings, view their call lists, retrieve voicemail messages and
trigger calls using the click-to-dial feature.
8.1.1
Login Procedure
To log into the CSC panel, the end user has to provide his full web username (e.g. [email protected]) and the web password
defined in Section 6.3. Once logged in, he can change his web password in the Account section. This will NOT change his SIP
password, so if you control the end user devices, you can auto-provision the SIP password into the device and keep it secret, and
just hand over the web password to the customer. This way, the end user will only be able to place calls with this auto-provisioned
device and not with an arbitrary soft-phone, but can nonetheless manage his account via the CSC panel.
Important
You can simplify the login procedure for one SIP domain in such a way that users in this domain only need to pass
the user part (e.g. user1) as a username instead of the full web username to log in by setting the parameter
www_csc site_domain in the config file /etc/ngcp-config/config.yml to the corresponding domain (e.g. 1.2.3.4)
and execute ngcpcfg apply.
8.1.2
Site Customization
As an operator, you can change the appearance of the CSC panel by modifying a couple of parameters in the section
www_csc site_config of the config file /etc/ngcp-config/config.yml. Modify the site title, your company details and the logo to
reflect your use case.
You can also enable/disable specific languages a user can choose from in the CSC panel. Currently, English (en), French (fr),
German (de) and Spanish (es) are supported and English is activated by default.
After changing one or more of the parameters in this file, execute ngcpcfg apply to activate the changes.
8.2
Vertical Service Codes (VSC) are codes a user can dial on his phone to provision specific features for his subscriber account. The
format is *<code>*<value> to activate a specific feature, and #<code> or #<code># to deactivate it. The code parameter
is a two-digit code, e.g. 72. The value parameter is the value being set for the corresponding feature.
59
60 / 84
Important
The value user input is normalized using the Rewrite Rules Sets assigned to domain as described in Section 6.5.
By default, the following codes are configured for setting features. The examples below assume that there is a domain rewrite rule
normalizing the number format 0<ac><sn> to <cc><ac><sn> using 43 as country code.
72 - enable Call Forward Unconditional e.g. to 431000 by dialing *72*01000, and disable it by dialing #72.
90 - enable Call Forward on Busy e.g. to 431000 by dialing *90*01000, and disable it by dialing #90.
92 - enable Call Forward on Timeout e.g. after 30 seconds of ringing to 431000 by dialing *92*30*01000, and disable it by
dialing #92.
93 - enable Call Forward on Not Available e.g. to 431000 by dialing *93*01000, and disable it by dialing #93.
50 - set Speed Dial Slot, e.g. set slot 1 to 431000 by dialing *50*101000, which then can be used by dialing *1.
55 - set One-Shot Reminder Call e.g. to 08:30 by dialing *55*0830.
31 - set Calling Line Identification Restriction for one call, e.g. to call 431000 anonymously dial *31*01000.
80 - call using Call Block Override PIN, number should be prefixed with a block override PIN configured in admin panel to
disable the outgoing user/admin block list and NCOS level for a call. For example, when override PIN is set to 7890, dial
Caution
If you have the EMTAs under your control, make sure that the specified VSCs dont overlap with EMTA-internal VSCs,
because the VSC calls must be sent to the NGCP via SIP like normal telephone calls.
8.3
60
61 / 84
Tip
To let the callers leave a voice message when user is not available he should enable Call Forward to Voicebox. The Call
Forward can be provisioned from the CSC panel as well as by dialing Call Forward VSC with the voicemail number. E.g. when
parameter voicemail_number is set to 9999, a Call Forward on Not Available to the Voicebox is set if the user dials *93*9999.
As a result, all calls will be redirected to the Voicebox if SIP phone is not registered.
As an operator, you can setup some DID number as external voicemail access number: for that, you should add a special rewrite
rule (Inbound Rewrite Rule for Callee, see Section 6.5.) on the incoming peer, to rewrite that DID to "voiceboxpass". Now when
user calls this number the call will be forwarded to the voicemail server and he will be prompted for mailbox and password. The
mailbox is the full E.164 number of the subscriber account and the password is the PIN set in the CSC panel.
The user can also dial his own number from PSTN, if he setup Call Forward on Not Available to the Voicebox, and when reaching
the voicemail server he can interrupt the "user is unavailable" message by pressing * key and then be prompted for the PIN.
After entering PIN and confirming with # key he will enter own voicemail menu. PIN is random by default and must be kept
secret for that reason.
61
62 / 84
Billing Configuration
This chapter describes the steps necessary to rate calls and export rated CDRs (call detail records) to external systems.
9.1
Service billing on the NGCP is based on billing profiles, which may be assigned to VoIP accounts and SIP peerings. The design
focuses on a simple, yet flexible approach, to support arbitrary dial-plans without introducing administrative overhead for the
system administrators. The billing profiles may define a base fee and free time or free money per billing interval. Unused free time
or money automatically expires at the end of the billing interval.
Each profile may have call destinations (usually based on E.164 number prefix matching) with configurable fees attached. Call
destination fees each support individual intervals and rates, with a different duration and/or rate for the first interval. (e.g.: charge
the first minute when the call is opened, then every 30 seconds, or make it independent of the duration at all) It is also possible
to specify different durations and/or rates for peak and off-peak hours. Peak time may be specified based on weekdays, with
additional support for manually managed dates based on calendar days. The call destinations can finally be grouped for an
overview on users invoices by specifying a zone in two detail levels. (E.g.: national landline, national mobile, foreign 1, foreign 2,
etc.)
9.1.1
The first step when setting up billing data is to create a billing profile, which will be the container for all other billing related data.
Go to System AdministrationBilling and click on create new billing profile. You will be taken to a web form where you may enter
the following parameters (all values except handle and name may be left empty):
handle: A unique, permanently fixed string which is used to attach the billing profile to a VoIP account or SIP peering contract.
name: A free form string used to identify the billing profile in the Admin Panel. This may be changed at any time.
interval charge: A base fee for the billing interval, specifying a monetary amount (represented as a floating point number) in
whatever currency you want to use.
interval free time: If you want to include free calling time in your billing profile, you may specify the number of seconds that are
available every billing interval. See Creating Billing Fees below on how to select destinations which may be called using the free
time.
interval free cash: Same as for interval free time above, but specifies a monetary amount which may be spent on outgoing
calls. This may be used for example to implement a minimum turnover for a contract, by setting the interval charge and interval
free cash to the same values.
fraud monthly limit: The monthly fraud detection limit (in Cent) for accounts with this billing profile. If the call fees of an account
reach this limit within a billing interval, an action can be triggered.
fraud monthly lock: a choice of none, foreign, outgoing, incoming, global. Specifies a lock level which will be used to lock the
account and his subscribers when fraud monthly limit is exceeded.
62
63 / 84
fraud monthly notify: An email address or comma-separated list of email addresses that will receive notifications when fraud
monthly limit is exceeded.
fraud daily limit: The fraud detection limit (in Cent) for accounts with this billing profile. If the call fees of an account reach this
limit within a calendar day, an action can be triggered.
fraud daily lock: a choice of none, foreign, outgoing, incoming, global. Specifies a lock level which will be used to lock the
account and his subscribers when fraud daily limit is exceeded.
fraud daily notify: An email address or comma-separated list of email addresses that will receive notifications when fraud daily
limit is exceeded.
currency: The currency symbol for your currency. Any UTF-8 character may be used and will be printed in web interfaces.
VAT rate: The percentage of value added tax for all fees in the billing profile. Currently for informational purpose only and not
used further.
VAT included: Whether VAT is included in the fees entered in web forms or uploaded to the platform. Currently for informational
purpose only and not used further.
9.1.2
To set up billing fees, go to System AdministrationBilling and select edit fees next to the billing profile you want to configure. Billing fees may be uploaded using a configurable CSV file format, or entered directly via the web interface by selecting
create new entry just below Stored Billing Fees. To configure the CSV field order for the file upload, rearrange the entries in
the www_adminfees_csv element_order array in /etc/ngcp-config/config.yml and execute the command ngcpcfg apply.
For input via the web interface, just fill in the text fields accordingly. In both cases, the following information may be specified
independently for every destination:
source: The source pattern. This is a POSIX regular expression matching the complete source URI (e.g. .*@sip\.
example\.org$ or someone@sip\.sipwise\.com$ or just . to match everything). If you leave this field empty, the
default pattern . matching everything will be set implicitely. Internally, this pattern will be matched against the <source_c
Important
The {source, destination, direction} combination needs to be unique for a billing profile. The system will return an error
if such a set is specified twice, both for the file upload and the input via the web interface.
63
64 / 84
Important
There are several internal services (vsc, conference, voicebox) which will need a specific destination entry with a
domain-based destination. If you dont want to charge the same (or nothing) for those services, add a fee for destination \.local$ there. If you want to charge different amounts for those services, break it down into separate fee
entries for @vsc\.local$, @conference\.local$ and @voicebox\.local$ with the according fees. NOT
CREATING EITHER THE CATCH-ALL FEE OR THE SEPARATE FEES FOR THE .local DOMAIN WILL BREAK
YOUR RATING PROCESS!
zone: A zone name for a group of destinations. May be used to group destinations for simplified display, e.g. on invoices. (e.g.
foreign zone 1)
zone detail: A zone name for a more detailed group of destinations. May be used to group destinations for simplified display,
e.g. on invoices. (e.g. germany landline)
onpeak init rate: The rate for the first rating interval in cent (of whatever currency, represented as a floating point number) per
second. Applicable to calls during onpeak hours.
onpeak init interval: The duration of the first billing interval, in seconds. Applicable to calls during onpeak hours.
onpeak follow rate: The rate for subsequent rating intervals in cent (of whatever currency, represented as a floating point
number) per second. Applicable to calls during onpeak hours. Defaults to onpeak init rate.
onpeak follow interval: The duration of subsequent billing intervals, in seconds. Applicable to calls during onpeak hours.
Defaults to onpeak init interval.
offpeak init rate: The rate for the first rating interval in cent (of whatever currency, represented as a floating point number) per
second. Applicable to calls during off-peak hours. Defaults to onpeak init rate.
offpeak init interval: The duration of the first billing interval, in seconds. Applicable to calls during off-peak hours. Defaults to
onpeak init interval.
offpeak follow rate: The rate for subsequent rating intervals in cent (of whatever currency, represented as a floating point
number) per second. Applicable to calls during off-peak hours. Defaults to offpeak init rate if that one is specified, or to onpeak
follow rate otherwise.
offpeak follow interval: The duration of subsequent billing intervals, in seconds. Applicable to calls during off-peak hours.
Defaults to offpeak init interval if that one is specified, or to onpeak follow interval otherwise.
use free time: Specifies whether free time minutes may be used when calling this destination. May be specified in the file
upload as 0, n[o], f[alse] and 1, y[es], t[rue] respectively.
9.1.3
To be able to differentiate between on-peak and off-peak calls, the platform stores off-peak times for every billing profile based on
weekdays and/or calendar days. To edit the settings for a billing profile, go to System AdministrationBilling and select edit peak
times next to the billing profile you want to configure.
64
65 / 84
To set off-peak times for a weekday, click on edit next to the according weekday. You will be presented with two input fields which
both receive a timestamp in the form of hh:mm:ss specifying a time of day for the start and end of the off-peak period. If any of
the fields is left empty, the system will automatically insert 00:00:00 (start field) or 23:59:59 (end field). Click on save to store
the setting in the database. You may create more than one off-peak period per weekday, and you may edit existing entries using
any of the input fields and clicking save next to it. To completely delete a range, just select delete next to the entry.
To specify off-peak ranges based on calendar dates, click on add new date just below Dates. Enter a date in the form of YYYYMM-DD into the date input field and fill in the start and end timestamps as outlined above. Select save to store the entry, or cancel
to close the input form. Existing dates will be listed below, grouped by year. Click on any of the years to view all dates which have
been recorded for it. If an entry is added, the corresponding year is expanded automatically. If an already existing date is added,
it will overwrite the existing entry.
9.1.4
The NGCP supports a fraud detection feature, which is designed to detect accounts causing unusually high customer costs, and
then to perform one of several actions upon those accounts. This feature can be enabled and configured through two sets of billing
profile options described in Section 9.1.1, namely the monthly (fraud monthly limit, fraud monthly lock and fraud monthly notify )
and daily limits (fraud daily limit, fraud daily lock and fraud daily notify ). Either monthly/daily limits or both of them can be active at
the same time.
Once a day, shortly after midnight local time, a background script automatically checks all accounts which are linked to a billing
profile enabled for fraud detection, and selects those which have caused a higher cost than the fraud monthly limit configured in
the billing profile, within the currently active billing interval (e.g. in the current month), or a higher cost than the fraud daily limit
configured in the billing profile, within the calendar day. It then proceeds to perform at least one of the following actions on those
accounts:
If fraud lock is set to anything other than none, it will lock the account accordingly (e.g. if fraud lock is set to outgoing, the
account will be locked for all outgoing calls).
If anything is listed in fraud notify, an email will be sent to the email addresses configured. The email will contain information
about which account is affected, which subscribers within that account are affected, the current account balance and the configured fraud limit, and also whether or not the account was locked in accordance with the fraud lock setting. It should be noted
that this email is meant for the administrators or accountants etc., and not for the customer.
Important
You can override these settings on a per-account basis via SOAP or the Admin interface.
Caution
Accounts that were automatically locked by the fraud detection feature will not be automatically unlocked when the
next billing interval starts. This has to be done manually through the administration panel or through the provisioning
interface.
65
66 / 84
Important
If fraud detection is configured to only send an email and not lock the affected accounts, it will continue to do so for
over-limit accounts every day. The accounts must either be locked in order to stop the emails (only currently active
accounts are considered when the script looks for over-limit accounts) or some other action to resolve the conflict must
be taken, such as disabling fraud detection for those accounts.
9.2
Regular billing data export is done using CSV (comma separated values) files which may be downloaded from the platform using
the cdrexport user which has been created during the installation.
9.2.1
In order to be able to easily identify billing files, the file name is constructed by the following fixed-length fields:
Length
Description
<prefix>
<separator>
<version>
<timestamp>
14
<sequence number>
10
<suffix>
A valid example filename for a billing file created at 2012-03-10 14:30:00 and being the 42nd file exported by the system, is:
sipwise_006_20130310143000_0000000042.cdr
9.2.2
File Format
Each billing file consists of three parts: one header line, zero to 5000 body lines and one trailer line.
66
67 / 84
<version>,<number of records>
<version>
Length
Type
Description
zero-
padded
uint
<number of records>
zero-
padded
uint
006,0738
<id>
<update_time>
Length
Type
1-10
uint
19
timestamp
Description
Internal CDR id.
Timestamp of last modification.
36
string
<source_provider_id>
1-255
string
<source_ext_subscriber_
0-255
string
<source_subscriber_id>
1-10
uint
<source_ext_account_id>
0-255
string
<source_account_id>
1-10
uint
<source_user>
1-255
string
<source_domain>
1-255
string
<source_cli>
1-64
string
<source_user_id>
id>
67
68 / 84
Table 4: (continued)
Body Element
Length
Type
uint
<source_ip>
0-64
string
<destination_user_id>
1 / 36
string
<source_clir>
Description
not local.
1-255
string
<dest_ext_subscriber_id>
0-255
string
<dest_subscriber_id>
1-10
uint
<dest_ext_account_id>
0-255
string
<destination_account_id>
1-10
uint
<destination_user>
1-255
string
<destination_domain>
1-255
string
<destination_user_in>
1-255
string
<destination_domain_in>
1-255
string
<dialed_digits>
1-255
string
<peer_auth_user>
0-255
string
<peer_auth_realm>
0-255
string
3-4
string
<destination_provider_
id>
soft-switch.
<call_type>
2-7
string
uint
<init_time>
23
timestamp
<start_time>
23
timestamp
<duration>
<call_id>
4-11
1-255
fixed
precision
with 3 decimals.
string
68
69 / 84
Table 4: (continued)
Body Element
<rating_status>
Length
Type
Description
2-7
string
<rated_at>
0 / 19
timestamp
<source_carrier_cost>
4-11
fixed
precision
<source_customer_cost>
4-11
fixed
precision
<source_carrier_zone>
0-127
string
<source_customer_zone>
0-127
string
<source_carrier_destinat
0-127
string
0-127
string
rated.
ion>
<source_customer_destina
1-10
uint
1-10
uint
4-11
4-11
fixed
precision
st>
<destination_carrier_zo
fixed
precision
st>
<destination_customer_co
me>
<destination_carrier_co
me>
<source_customer_free_ti
tion>
<source_carrier_free_ti
0-127
string
0-127
string
ne>
<destination_customer_zo
rated.
ne>
<destination_carrier_des
0-127
string
rated.
tination>
<destination_customer_de
0-127
string
1-10
uint
1-10
uint
ee_time>
<line_terminator>
e_time>
<destination_customer_fr
stination>
<destination_carrier_fre
string
0x0A).
69
70 / 84
A valid example of one body line of a rated CDR is (line breaks added for clarity):
15,2013-03-26 22:09:11,a84508a8-d256-4c80-a84e-820099a827b0,1,,1,,
2,testuser1,192.168.51.133,4311001,0,192.168.51.1,
94d85b63-8f4b-43f0-b3b0-221c9e3373f2,1,,3,,4,testuser3,
192.168.51.133,testuser3,192.168.51.133,testuser3,,,call,ok,200,
2013-03-25 20:24:50.890,2013-03-25 20:24:51.460,10.880,44449842,
ok,2013-03-25 20:25:27,0.00,24.00,onnet,testzone,platform internal,
testzone,0,0,0.00,200.00,,foo,,foo,0,0
<md5 sum>
The <md5 sum> is a 32 character hexadecimal MD5 hash of the Header and Body.
To validate the billing file, one must remove the Trailer before computing the MD5 sum of the file. An example bash script to
validate the integrity of the file is given below:
#!/bin/sh
error() { echo $@; exit 1; }
test -n "$1" || error "Usage: $0 <cdr-file>"
test -f "$1" || error "File $1 not found"
TMPFILE="/tmp/$(basename "$1")"
MD5="$(sed -rn $ s/^([a-z0-9]{32}).*$/\1/i p "$1")
sed $d "$1" > "$TMPFILE"
$TMPFILE"
$ ./cdr-md5.sh sipwise_001_20071110123000_0000000004.cdr
/tmp/sipwise_001_20071110123000_0000000004.cdr: OK
If the file has been altered during transmission, the output of the integrity check would be:
$ ./cdr-md5.sh sipwise_001_20071110123000_0000000004.cdr
/tmp/sipwise_001_20071110123000_0000000004.cdr: FAILED
md5sum: WARNING: 1 of 1 computed checksum did NOT match
70
9.2.3
71 / 84
File Transfer
Billing files are created twice per hour at minutes 25 and 55 and are stored in the home directory of the cdrexport user. If the
amount of records within the transmission interval exceeds the threshold of 5000 records per file, multiple billing files are created.
If no billing records are found for an interval, a billing file without body data is constructed for easy detection of lost billing files on
the 3rd party side.
CDR files are fetched by a 3rd party billing system using SFTP or SCP with either public key or password authentication using the
username cdrexport.
If public key authentication is chosen, the public key file has to be stored in the file ~/.ssh/authorized_keys2 below the
home directory of the cdrexport user. Otherwise, a password has to be set for the user.
The 3rd party billing system is responsible for deleting CDR files after fetching them.
Note
The cdrexport user is kept in a jailed environment on the system, so it has only access to a very limited set of commandline
utilities.
71
10
72 / 84
Provisioning interfaces
The sip:provider CE provides two provisioning interfaces for easy interconnection with 3rd party tools. The user can access all
the functionalities provided by the Admin interface or the CSC interface via SOAP or XMLRPC interfaces. The server provides
online documentation about all the functions available. To access the online documentation for the first time, you need to follow
the following instructions:
Note
Also see man 1 htpasswd on how to generate crypt or MD5 passwords if you like. Of course you may use any other
process to generate crypt, MD5 or SHA hashed passwords. But using htpasswd ensures the hashes are also understood by
Apache.
Edit /etc/ngcp-config/config.yml. Under section ossbsshtpasswd, replace user and pass with your new values and execute
ngcpcfg apply as usual.
Access https://<ip>:2443/SOAP/Provisioning.wsdl and login with your new credentials.
Note
The default port for provisioning interfaces is 2443. You can change it in /etc/ngcp-config/config.yml by modifying ossbssapacheport and execute ngcpcfg apply.
Important
The displayed online API documentation shows all the currently available functionalities. Enabling or disabling features
in /etc/ngcp-config/config.yml will directly reflect in the functions being available via the APIs.
Important
If your SOAP client throws errors because of the inline <documentation> tags (e.g. Visual Studio and the stock PHP
SOAP client complain about this), try to use the WSDL URL https://<ip>:2443/SOAP/Provisioning.wsdl?plain instead,
which supresses the output of these tags.
72
11
73 / 84
Configuration Framework
The sip:provider CE provides a configuration framework for consistent and easy to use low level settings management. A basic
usage of the configuration framework only needs two actions already used in previous chapters:
Edit /etc/ngcp-config/config.yml file.
Execute ngcpcfg apply command.
Low level management of the configuration framework might be required by advanced users though. This chapter explains the
architecture and usage of the NGCP configuration framework. If the basic usage explained above fits your needs, feel free to skip
this chapter and return to it when your requirements change.
A more detailed workflow of the configuration framework for creating a configuration file consists of 6 steps:
Generation or editing of configuration templates and/or configuration values.
Generation of the configuration files based on configuration templates and configuration values defined in config.yml, constants.yml and network.yml files.
Execution of prebuild commands if defined for a particular configuration file or configuration directory.
Placement of the generated configuration file in the target directory. This step is called build in the configuration framework.
Execution of postbuild commands if defined for that configuration file or configuration directory.
Execution of services commands if defined for that configuration file or configuration directory. This step is called services in the
configuration framework.
Saving of the generated changes. This step is called commit in the configuration framework.
11.1
Configuration templates
The sip:provider CE provides configuration file templates for most of the services it runs. These templates are stored in the
directory /etc/ngcp-config/templates.
Example: Template files for /etc/sems/sems.conf are stored in /etc/ngcp-config/templates/etc/sems/.
There are different types of files in this template framework, which are described below.
11.1.1
These files are the main template files that will be used to generate the final configuration file for the running service. They contain
all the configuration options needed for a running sip:provider CE system. The configuration framework will combine these files
with the values provided by config.yml, constants.yml and network.yml to generate the appropriate configuration file.
Example: In the installation chapter weve changed the public interface from lo to eth0. This parameter will for example change ka-
mailios listen address, when the configuration file is generated. A quick look to the template file under /etc/ngcp-config/templates/etc/kama
will show a line like this:
73
74 / 84
After applying the changes with the ngcpcfg apply command, a new configuration file will be created under /etc/kamailio/kamailio.cfg with the proper values taken from the main configuration files (in this case network.yml):
listen=udp:1.2.3.4:5060
All the low-level configuration is provided by these .tt2 template files and the corresponding config.yml file. Anyways, advanced
users might require a more particular configuration.
Instead of editing .tt2 files, the configuration framework recognises .customtt.tt2 files. These files are the same as .tt2, but they
have higher priority when the configuration framework creates the final configuration files. An advanced user should create a
.customtt.tt2 file from a copy of the corresponding .tt2 template and leave the .tt2 template untouched. This way, the user will have
his personalized configuration and the system will continue providing a working, updated configuration template in .tt2 format.
Example: Well create /etc/ngcp-config/templates/etc/kamailio.cfg.customtt.tt2 and use it for our personalized configuration. In this
example, well just append a comment at the end of the template.
cd /etc/ngcp-config/templates/etc/kamailio/lb
cp kamailio.cfg.tt2 kamailio.cfg.customtt.tt2
echo # This is my last line comment >> kamailio.cfg.customtt.tt2
ngcpcfg apply
The ngcpcfg command will generate /etc/kamailio/kamailio.cfg from our custom template instead of the general one.
tail -1 /etc/kamailio/kamailio.cfg
# This is my last line comment
Tip
The tt2 files use the Template Toolkit language. Therefore you can use all the feature this excellent toolkit provides within
ngcpcfgs template files (all the ones with the .tt2 suffix).
11.1.2
After creating the configuration files, the configuration framework can execute some commands before and after placing that file
in its target directory. These commands usually are used for changing the files owner, groups, or any other attributes. There are
some rules these commands need to match:
They have to be placed in a .prebuild or .postbuild file in the same path as the original .tt2 file.
The file name must be the same as the configuration file, but having the mentioned suffixes.
The commands must be bash compatible.
The commands must return 0 if successful.
74
75 / 84
Example: We need www-data as owner of the configuration file /etc/ngcp-ossbss/provisioning.conf. The configuration framework
will by default create the configuration files with root:root as owner:group and with the same permissions (rwx) as the original
template. For this particular example, we will change the owner of the generated file using the .postbuild mechanism.
11.1.3
.services files
.services files are pretty similar and might contain commands that will be executed after the build process. There are two types of
.services files:
The particular one, with the same name as the configuration file it is associated to.
Example: /etc/ngcp-config/templates/etc/asterisk/sip.conf.services is associated to /etc/asterisk/sip.conf
The general one, named ngcpcfg.services wich is associated to every file in its target directory.
Example: /etc/ngcp-config/templates/etc/asterisk/ngcpcfg.services is associated to every file under /etc/asterisk/
When the services step is triggered all .services files associated to a changed configuration file will be executed. In case of the
general file, any change to any of the configuration files in the directory will trigger the execution of the commands.
Tip
If the service script has the execute flags set (chmod +x $file) it will be invoked directly. If it doesnt have execute flags set it will
be invoked under bash. Make sure the script is bash compatible if you do not set execute permissions on the service file.
These commands are usually service reload/restarts to ensure the new configuration has been loaded by running services.
Note
The configuration files mentioned in the following example usually already exist on the platform. Please make sure you dont
overwrite any existing files if following this example.
Example:
In this example we created two .services files. Now, each time we trigger a change to /etc/mysql.my.cnf or to /etc/asterisk/* well
see that MySQL or Asterisk services will be restarted by the ngcpcfg system.
75
11.2
76 / 84
The /etc/ngcp-config/config.yml file contains all the user-configurable options, using the YAML (YAML Aint Markup Language)
syntax.
The /etc/ngcp-config/constants.yml file provides configuration options for the platform that arent supposed to be edited by the
user. Do not manually edit this file unless you really know what youre doing.
The /etc/ngcp-config/network.yml file provides configuration options for all interfaces and IP addresses on those interfaces. You
can use the ngcp-network tool for conveniently change settings without having to manually edit this file.
The /etc/ngcp-config/ngcpcfg.cfg file is the main configuration file for ngcpcfg itself. Do not manually edit this file unless you really
know what youre doing.
11.3
11.3.1
apply
The apply option is a short-cut for the options "build && services && commit" and also executes etckeeper to record any modified
files inside /etc. It is the recommended option to use the ngcpcfg framework unless you want to execute any specific commands
as documented below.
11.3.2
build
The build option generates (and therefore also updates) configuration files based on their configuration (config.yml) and template
files (.tt2). Before the configuration file is generated a present .prebuild will be executed, after generation of the configuration file
the according .postbuild script (if present) will be executed. If a file or directory is specified as argument the build will generate
only the specified configuration file/directory instead of running through all present templates.
Example: to generate only the file /etc/apache2/sites-available/ngcp-www-admin you can execute:
Example: to generate all the files located inside the directory /etc/apache2/ you can execute:
11.3.3
commit
The commit option records any changes done to the configuration tree inside /etc/ngcp-config. The commit option should be
executed when youve modified anything inside the configuration tree.
76
11.3.4
77 / 84
decrypt
Decrypt /etc/ngcp-config-crypted.tgz.gpg and restore configuration files, doing the reverse operation of the encrypt option. Note:
This feature is only available if the ngcp-ngcpcfg-locker package is installed.
11.3.5
diff
Show uncommited changes between ngcpcfgs Git repository and the working tree inside /etc/ngcp-config. Iff the tool doesnt
report anything it means that there are no uncommited changes. If the --addremove option is specified then new and removed
files (iff present) that are not yet (un)registered to the repository will be reported, no further diff actions will be executed then. Note:
This option is available since ngcp-ngcpcfg version 0.11.0.
11.3.6
encrypt
Encrypt /etc/ngcp-config and all resulting configuration files with a user defined password and save the result as /etc/ngcp-configcrypted.tgz.gpg. Note: This feature is only available if the ngcp-ngcpcfg-locker package is installed.
11.3.7
help
The help options displays ngcpcfgs help screen and then exits without any further actions.
11.3.8
initialise
The initialise option sets up the ngcpcfg framework. This option is automatically executed by the installer for you, so you shouldnt
have to use this option in normal operations mode.
11.3.9
pull
Retrieve modifications from shared storage. Note: This option is available in the High Availability setup only.
11.3.10
push
Push modifications to shared storage and remote systems. After changes have been pushed to the nodes the build option will be
executed on each remote system to rebuild the configuration files (unless the --nobuild has been specified, then the build step will
be skipped). If hostname(s) or IP address(es) is given as argument then the changes will be pushed to the shared storage and to
the given hosts only. If no host has has been specified then the hosts specified in /etc/ngcp-config/systems.cfg are used. Note:
This option is available in the High Availability setup only.
11.3.11
services
The services option executes the service handlers for any modified configuration file(s)/directory.
77
11.3.12
78 / 84
status
The status option provides a human readable interface to check the state of the configuration tree. If you are unsure what should
be done as next step or if want to check the current state of the configuration tree just invoke ngcpcfg status.
If everything is OK and nothing needs to be done the output should look like:
# ngcpcfg status
Checking state of ngcpcfg:
OK:
nothing to commit.
nothing to commit.
If the output doesnt say "OK" just follow the instructions provided by the output of ngcpcfg status.
Further details regarding the ngcpcfg tool are available through man ngcpcfg on the Sipwise Next Generation Platform.
78
12
79 / 84
Network Configuration
Starting with version 2.7, the sip:provider CE uses a dedicated network.yml file to configure the IP addresses of the system.
The reason for this is to be able to access all IPs of all nodes for all services from any particular node in case of a distributed
system on one hand, and in order to be able the generate /etc/network/interfaces automatically for all nodes based on this central
configuration file.
12.1
General Structure
hosts:
self:
role:
- proxy
- lb
- mgmt
interfaces:
- eth0
- lo
eth0:
ip: 192.168.51.213
netmask: 255.255.255.0
type:
- sip_ext
- rtp_ext
- web_ext
lo:
ip: 127.0.0.1
netmask: 255.255.255.0
type:
- sip_int
- web_int
- ha_int
In CE systems, there is only one host entry in the file, and its always named self.
12.2
There are three different main sections for a host in the config file, which are role, interfaces and the actual interface definitions.
role: The role setting is an array defining which logical roles a node will act as. Possible entries for this setting are:
mgmt: This entry means the host is acting as management node for the platform. In a sip:provider CE, this option must always
been set. The management node exposes the admin and csc panels to the users and the APIs to external applications and
79
80 / 84
lb: This entry means the host is acting as SIP load-balancer for the platform. In a sip:provider CE, this option must always
been set. The SIP load-balancer acts as an ingress and egress point for all SIP traffic to and from the platform.
proxy : This entry means the host is acting as SIP proxy for the platform. In a sip:provider CE, this option must always been
set. The SIP proxy acts as registrar, proxy and application server and media relay, and is responsible for providing the features
for all subscribers provisioned on it.
interfaces: The interfaces setting is an array defining all interface names in the system. The actual interface details are set in
the actual interface settings below.
<interface name>: After the interfaces are defined in the interfaces setting, each of those interfaces needs to be specified as a
separate setting with the following options:
ip
netmask
advertised_ip
type
80
13
81 / 84
Once the sip:provider CE is in production, security and maintenance becomes really important. In this chapter, well go through a
set of best practices for any production system.
13.1
Firewalling
The sip:provider CE runs a wide range of services. Some of them need to interact with the user, while some others need to interact
with the administrator or with nobody at all. Assuming that we trust the sip:provider CE server for outgoing connections, well focus
only on incoming traffic to define the services that need to be open for interaction.
Table 5: Subscribers
Service
Customer self care interface
SIP
Default port
443 TCP
5060 UDP,
Config option
www_cscapacheport
kamailiolbport
TCP
SIP over TLS
RTP
5061 TCP
30000-40000
kamailiolbtlsport + kamailiolbtlsenable
rtpproxyminport + rtpproxymaxport
UDP
XCAP
1080 TCP
kamailioproxypresenceenable + nginxxcap_port
Table 6: Administrators
Service
SSH/SFTP
Default port
22 TCP
Config option
NA
Administrator interface
1443 TCP
www_adminapacheport
Provisioning interfaces
2443 TCP
ossbssapacheport
Caution
To function correctly, the mediaproxy requires an additional iptables rule installed. This rule (with a target of MEDIAPR
OXY) is automatically installed and removed when the mediaproxy starts and stops, so normally you dont need to worry
about it. However, any 3rd party firewall solution can potentially flush out all existing iptables rules before installing
its own, which would leave the system without the required MEDIAPROXY rule and this would lead to decreased
performance. It is imperative that any 3rd party firewall solution either leaves this rule untouched, or installs it back into
place after flushing all rules out. The complete parameters to install this rule (which needs to go into the INPUT chain
of the filter table) are: -p udp -j MEDIAPROXY --id 0
81
13.2
82 / 84
Password management
The sip:provider CE comes with some default passwords the user should change during the deployment of the system. They have
been explained in the previous chapters of this document.
The login for the system account cdrexport is disabled by default. Although this is a jailed account, it has access to sensitive
information, namely the Call Detail Records of all calls. SSH keys should be used to login this user, or alternatively a really
strong password should be used when setting the password via passwd cdrexport.
The root user in MySQL has no default password. A password should be set using the mysqladmin password command.
The administrative web interface has a default user administrator with password administrator. It should be changed within this
interface.
Generate new password for user ngcpsoap to access the provisioning interfaces, see the details in Section 10.
The Vagrant/VirtualBox/VmWare sip:provider CE images come with more default credentials which should be changed immediately:
The default password of the system account root is sipwise. A password must be changed immediately using command passwd
root.
SSH authorized_keys for users root and sipwise should be wiped out using command rm ~root/.ssh/authorized_keys ~sipwise/.ssh/authorized_keys for VirtualBox/VmWare images (skip the step if you use Vagrant).
Important
Many NGCP services use MySQL backend. Users and passwords for these services are created during the installation.
These passwords are unique for each installation, and the connections are restricted to localhost. You should not
change these users and passwords.
13.3
SSL certificates.
The sip:provider CE provides default, self-signed SSL certificates for SSL connections. These certificates are common for every
installation. Before going to production state, the system administrator should provide SSL certificates for the web services. These
certificates can either be shared by all web interfaces (provisioning, administrator interface and customer self care interface), or
separate ones for each them can be used.
Generate the certificates. The customer self care interface certificate should be signed by a certification authority to avoid
browser warnings.
Upload the certificates to the system
Set the path to the new certificates in /etc/ngcp-config/config.yml:
82
83 / 84
13.4
13.4.1
Backup
The sip:provider CE can be integrated with most of the existing backup solutions. While it does not provide any backup system
by default, any Debian compatible system can be installed. Its not the scope of this chapter to go through backup system
configuration. Well focus on which information needs to be saved.
The minimum set of information to be backed up is:
The database information.
This is the most important data in the system. All subscriber information, billing, CDRs, user preferences etc. are stored in the
MySQL server. A periodical dump of all the databases should be performed.
System configuration options
/etc/ngcp-config/config.yml, /etc/ngcp-config/constants.yml, /etc/mysql/debian.cnf and /etc/mysql/sipwise.cnf files, where your
specific system configurations are stored, should be included in the backup as well.
Optional: Exported CDRs
The directory /home/jail/home/cdrexport contains the exported CDRs the system has generated so far. It depends on your local
call data retention policy whether or not to remove these files after exporting them to an external system.
Optional: Custom files
Any custom configurations, like modified templates or additionally implemented services which are not provided by the sip:provider
CE
83
13.4.2
84 / 84
Recovery
In the worst case scenario, when the system needs to be recovered from a total loss, you only need 4 steps to get back online:
13.5
Reset database
To reset database to its original state you can use the script provided by CE: * Execute ngcp-reset-db. It will assign new unique
password for the NGCP services and restart all services. IMPORTANT: All existing data will be wiped out without possibility of
restoring.
84