Skip to main content

Testing a new SIP phone

Let's suppose you have received a brand-new SIP phone that is not supported by Wazo's provisioning system. You would like to know if it's possible to add auto-provisioning support for it. That said, you have never tested the phone before.

This guide will help you get through the different steps that are needed to add auto-provisioning support for a phone to Wazo.

Prerequisites

Before continuing, you'll need the following:

  • a private LAN where only your phones and your test machines are connected to it, i.e. a LAN that you fully control.

Configuring a test environment

Although it's possible to do all the testing directly on a Wazo, it's more comfortable and usually easier to do on a separate, dedicated machine.

That said, you'll still need a Wazo nearby, since we'll be doing the call testing part on it and not on a separate asterisk.

So, for the rest of this guide, we'll suppose you are doing your tests on a Debian server with the following configuration:

  • Installed packages:

    • isc-dhcp-server
    • tftpd-hpa
    • apache2
  • Example content of the /etc/dhcp/dhcpd.conf file (restart isc-dhcp-server after modification):

    ddns-update-style none;

    default-lease-time 7200;
    max-lease-time 86400;

    log-facility local7;

    subnet 10.34.1.0 netmask 255.255.255.0 {
    authoritative;

    range 10.34.1.200 10.34.1.250;

    option subnet-mask 255.255.255.0;
    option broadcast-address 10.34.1.255;
    option routers 10.34.1.6;

    option ntp-servers 10.34.1.6;
    option domain-name "my-domain.example.org";
    option domain-name-servers 10.34.1.6;

    log(concat("[VCI: ", option vendor-class-identifier, "]"));
    }
  • Example contents of the /etc/default/tftpd-hpa file (restart tftpd-hpa after changes):

    TFTP_USERNAME="tftp"
    TFTP_DIRECTORY="/srv/tftp"
    TFTP_ADDRESS="0.0.0.0:69"
    TFTP_OPTIONS="--secure --verbose"

With this configuration, files served via TFTP will be in the /srv/tftp directory and those served via HTTP in the /var/www directory.

Testing

Adding auto-provisioning support for a phone is mostly a question of finding answers to the following questions.

  1. Is it worth the time adding auto-provisioning support for the phone?

    Indeed. Adding quality auto-provisioning support for a phone to Wazo requires a non-negligible amount of work, even if you don't run into any real problems and are comfortable provisioning in Wazo. Not all phones are created equal. Some are cheap. Some are old and slow. Some are made to work on proprietary systems and will only work in limited capacity on anything else.

    That said, if you are uncertain, testing will help you decide.

  2. What is the vendor, model, MAC address and firmware version (if available) of your phone?

    Having the vendor and model name is essential when looking for documentation or other information. The MAC address will be needed later on for some tests, and it's always good to know the firmware version of the phone if you are trying to upgrade to a newer firmware version, and you're having some troubles, and when reading the documentation.

  3. Is the official administration guide/documentation available publicly on the vendor website? Or only available after registering and logging into the vendor's website?

    Having access to the administration guide/documentation of the phone is also essential. Once you've found it, download it and keep the link to the URL. If you can't find it, it's probably not worth going further.

  4. Is the latest firmware of the phone available publicly on the vendor website? Is it available only after registering and logging into the vendor website?

    Good auto-provisioning support means you need to have an easy way to download the latest firmware of the phone. Ideally, this mean the firmware is downloadable from a URL, with no authentication whatsoever. In the worst case, you'll need to log in on some web portal before being able to download the firmware, which will be cumbersome to automatize and probably fragile. If this is the case, it's probably not worth going further.

  5. Does the phone need other files, like language files? If so, are these files available publicly on the vendor's website? After registering?

    Although you might not be able to answer this question yet because you might not know if the phone needs such files to be either in English or in French (the two officially supported language in Wazo), you'll need to have easy access to these files if it's the case.

  6. Does the phone support auto-provisioning via DHCP + HTTP (or TFTP)?

    The provisioning system in Wazo is based on the popular method of using a DHCP server to tell the phone where to download its configuration files, and an HTTP (or TFTP) server to serve these configuration files. Some phones support other methods of provisioning (like TR-069), but that's of no use here. Also, if your phone is only configurable via its web interface, although it's technically possible to configure it automatically by navigating its web interface, it's an extremely bad idea since it's impossible to guarantee that you'll still be able to provision the phone on the next firmware release.

    If the phone supports both HTTP and TFTP, pick HTTP, it usually works better with the provisioning server of Wazo.

  7. What are the default usernames/passwords on the phone to access administration menus (phone UI and web UI)? How do you do a factory reset of the phone?

    Although this step is optional, it might be handy later to have this information. Try to find them now, and note them somewhere.

  8. What are the DHCP options and their values to send to the phones to tell it where the configuration files are located?

    Once you know that the phone supports DHCP + HTTP provisioning, the next question is what do you need to put in the DHCP response to tell the phone where its configuration files are located. Unless the admin documentation of the phone is really poor, this should not be too hard to find.

    Once you have found this information, the easiest way to send it to the phone is to create a custom host declaration for the phone in the /etc/dhcp/dhcpd.conf file, like in this example:

    host my-phone {
    hardware ethernet 00:11:22:33:44:55;
    option tftp-server-name "http://169.254.0.1/foobar.cfg";
    }
  9. What are the configuration files the phone needs (filename and content) and what do we need to put in it for the phone to minimally be able to make and receive calls on Wazo?

    Now that you are able to tell your phone where to look for its configuration files, you need to write these files with the right content in it. Again, at this step, you'll need to look through the documentation or examples to answer this question.

    Note that you only want to have the most basic configuration here, i.e. only configure 1 line, with the right SIP registrar and proxy, and the associated username and password.

  10. Do basic telephony services, like transfers, works correctly when using the phone buttons?

    On most phones, it's possible to do transfers (both attended and direct), three-way conferences or put someone on hold directly from the phone. Do some tests to see if it works correctly.

    Also, in this step, it's a good idea to check how the phone handles non-ascii characters, either in the caller ID or in its configuration files.

  11. Do other "standard" features work correctly on the phone?

    For quality auto-provisioning support, you must find how to configure and make the following features work:

    • NTP server
    • MWI
    • function keys (speed dial, BLF, directed pickup / call interception)
    • timezone and DST support
    • multi language
    • DTMF
    • hard keys, like the voicemail hard key on some phone
    • non-ASCII labels (line name, function key label)
    • non-ASCII caller ID
    • backup proxy/registrar
    • paging

Once you have answered all these questions, you'll have a good idea on how the phone works and how to configure it. Next step would be to start the development of a new provd plugin for your phone for a specific firmware version.

IOT Phones

  • FK = Funckey
  • HK = HardKey
  • Y = Supported
  • MN = Menu
  • N = Not supported
  • NT = Not tested
  • NYT = Not yet tested
  • SK = SoftKey
model
ProvisioningY
H-AY
Directory WazoY
Funckeys8
Supported programmable keys
User with supervision functionY
GroupY
QueueY
Conference Room with supervision functionY
General Functions
Online call recordingN
Phone statusY
Sound recordingY
Call recordingY
Incoming call filteringY
Do not disturbY
Group interceptionY
Listen to online callsY
Directory accessY
Filtering Boss - SecretaryY
Transfers Functions
Blind transferHK
Indirect transferHK
Forwards Functions
Disable all forwardingY
Enable/Disable forwarding on no answerY
Enable/Disable forwarding on busyY
Enable/Disable forwarding unconditionalY
Voicemail Functions
Enable voicemail with supervision functionY
Reach the voicemailY
Delete messages from voicemailY
Agent Functions
Connect/Disconnect a static agentY
Connect a static agentY
Disconnect a static agentY
Parking Functions
ParkingY
Parking positionY
Paging Functions
PagingY