Howto:Configure the innovaphone Voicemail: Difference between revisions
| m Added section "Quick Reference For innovaphone Voicemail" | |||
| (126 intermediate revisions by 22 users not shown) | |||
| Line 6: | Line 6: | ||
| Message Waiting Indication (MWI) is supported. | Message Waiting Indication (MWI) is supported. | ||
| <!-- voice mail Anrufbeantworter --> | |||
| ==Applies To== | ==Applies To== | ||
| This information applies to | This information applies to | ||
| * innovaphone PBX, V6 | * innovaphone PBX, V6 and Higher | ||
| ==Supporting The innovaphone Voicemail== | |||
| ===Tracing=== | |||
| For a decent supportable trace | |||
| *Activate the '''trace''' checkmark within the UI of the voicemail object | |||
| *Append the parameter '''$_trace=251''' to the configured script URL, alike so: <code>https://1.2.3.4/drive/CF0/de/vm.xml?$_trace=251</code> | |||
| *Activate the '''PBX''' checkmark within the [[Reference13r3:Maintenance/Diagnostics/Tracing]] page | |||
| ==More Information== | ==More Information== | ||
| ===System Requirements=== | ===System Requirements=== | ||
| Voicemail license: The innovaphone voicemail requires licensing. The number of acquired voicemail licenses must be equal or greater than the number of PBX basic licenses. | |||
| WebDAV server, e.g.: Apache 2.x, IIS W2K, IIS W3K, or with V6 sr1 the compat flash drive (no external WebDAV server needed) | WebDAV server, e.g.: Apache 2.x, IIS W2K, IIS W3K, or with V6 sr1 the compat flash drive (no external WebDAV server needed) | ||
| Innovaphone will provide you with an XML script, that represents the actual voicemail.   | Innovaphone will provide you with an XML script, that represents the actual voicemail. In addition you will get a set of files with *.g711a, *.g711u, *.g722, *.opus-wb, *.opus-nb and *.g729 extensions. These files contain the audio snippets and the menu prompts, that the voicemail requires. | ||
| In addition you will get a set of files with *.g711a and *.g729 extensions.   | |||
| These files contain the audio snippets and the menu prompts, that the voicemail requires. | |||
| ==Installation, WebDAV== | ==Installation, WebDAV== | ||
| Line 40: | Line 44: | ||
| ===Creating the Voicemail Object=== | ===Creating the Voicemail Object=== | ||
| Proceed to Administration/PBX/Objects. | Proceed to Administration/PBX/Objects. | ||
| *Select Voicemail from the drop-down list and click on new. | |||
| Select Voicemail from the drop-down list and click on new. | *Enter Long Name, Name. | ||
| *Enter 66 as Number. | |||
| Enter Long Name, Name. | *Enter the Script URL as http://192.168.0.5/webdav/vm/vm.xml. | ||
| **'''Note:'''Meanwhile it is recommended to enter it as: http://192.168.0.5/webdav/vm/vm.xml?$_pbxfwd=true (see [[#URL Query String Variables]]) | |||
| Enter 66 as Number. | |||
| Enter the Script URL as http://192.168.0.5/webdav/vm/vm.xml. | |||
| ===Distributing the Voicemail Script and Pre-Recorded Audio Files=== | ===Distributing the Voicemail Script and Pre-Recorded Audio Files=== | ||
| Download the installation program for the ''innovaphone voicemail'' from the [http://download.innovaphone.com innovaphone download area]. | The download section offers ZIP files and a Windows installation program. See [[#Download]] for how to find the download site. | ||
| * ZIP files | |||
| Start the installer program (innovaphone-voicemail-install.exe). | **Download the ZIP file for the language your are interested in (e.g. ''vm-de'', ''vm-en'', ...) from the ''apps'' package on the [http://download.innovaphone.com/ice/6.00/ innovaphone download area, V6 Apps]. | ||
| **Un-ZIP the file. This step creates a language specific sub-directory that may be copied onto the CF-card. | |||
| The installer will be asking for a target directory. Enter ''c:\Inetpub\webdav\vm\''. | * Windows installation program | ||
| Now, the installer will copy all of the localized voicemail files into language specific sub-directories. The english files will remain under the absolute path ''c:\Inetpub\webdav\vm\en\''. | **Download the installation program for the ''innovaphone voicemail'' from the [http://download.innovaphone.com innovaphone download area]. | ||
| **Start the installer program (innovaphone-voicemail-install.exe). | |||
| **The installer will be asking for a target directory. Enter ''c:\Inetpub\webdav\vm\''. Now, the installer will copy all of the localized voicemail files into language specific sub-directories. The english files will remain under the absolute path ''c:\Inetpub\webdav\vm\en\''. | |||
| ===Configuration=== | ===Configuration=== | ||
| Please note, that a user's VM number is the number of the VM object, that you | Please note, that a user's VM number is the number of the VM object, that you assigned here, plus the user's number.   | ||
| assigned here, plus the user's number.   | |||
| Example: If a user has the number 49 and the number of the VM object is 66, then the user's corresponding VM number will be 6649. | Example: If a user has the number 49 and the number of the VM object is 66, then the user's corresponding VM number will be 6649. | ||
| ===IP Phone Configuration=== | ===IP Phone Configuration=== | ||
| ====V6, SR1: Recommended Configuration==== | |||
| A user may wish to manually activate or deactivate a CFU diversion to his VM. | A user may wish to manually activate or deactivate a CFU diversion to his VM. | ||
| * Browse to the IP phone of the user 49:test: | |||
| * Proceed to ''Configuration/RegistrationX/Function Keys''. | |||
| * Select a free function key, choose ''Call Forwarding'' and click on ''new''.  | |||
| * A new window will open. Enter ''AM-on'' under ''Idle State/Text''. | |||
| * Enter AM-off under ''Active State [1]/Text''. | |||
| * Enter ''6649'' into ''Active State [1]/Text/Always/Number''. | |||
| * Click on ''OK''. | |||
| An additional function key is required to present the MWI and to quick-dial the VM: | |||
| * Proceed to ''Configuration/RegistrationX/Function Keys''. | |||
| * Select a free function key, choose ''Message Waiting'' and click on new.  | |||
| * A new window will open. Enter ''AM'' under ''Idle State/Text''. | |||
| * Select the ''letter'' icon under ''Active State/Icon''. | |||
| * If you desire, then choose ''LED/blink''. | |||
| * Enter ''6649'' into ''Message Center Account/Number''. | |||
| * Click on ''OK''. | |||
| ====V6, SR2: Recommended Configuration==== | |||
| The SR2 configuration adapts to mass-deployment requirements, in such that the set of required configuration parameters can be distributed identically among all affected phones. | |||
| Select a free function key, choose Call Forwarding and click on new.   | A user may wish to manually activate or deactivate a CFU diversion to his VM. | ||
| * Browse to the IP phone of the user 49:test: | |||
| A new window will open. | * Proceed to ''Configuration/RegistrationX/Function Keys''. | ||
| * Select a free function key, choose ''Call Forwarding'' and click on ''new''.   | |||
| Enter AM-on under Idle State/Text. | * A new window will open. Enter ''AM-on'' under ''Idle State/Text''. | ||
| * Enter ''AM-off'' under ''Active State [1]/Text''. | |||
| Enter AM-off under Active State [1]/Text. | * Enter ''66'' into ''Active State [1]/Text/Always/Number''. | ||
| * Click on ''OK''. | |||
| Enter  | |||
| Click on OK. | |||
| An additional function key is required to present the MWI and to quick-dial the VM: | An additional function key is required to present the MWI and to quick-dial the VM: | ||
| * Proceed to ''Configuration/RegistrationX/Function Keys''. | |||
| * Select a free function key, choose ''Message Waiting'' and click on new.  | |||
| * A new window will open. Enter ''AM'' under ''Idle State/Text''. | |||
| * Select the letter ''icon'' under ''Active State/Icon''. | |||
| * If you desire, then choose ''LED/blink''. | |||
| * Enter ''66'' into ''Message Center Account/Number''. | |||
| * Activate the ''Append Own Number'' checkmark. | |||
| * Click on ''OK''. | |||
| ====Deploying the MWI Function Key By An Update Script==== | |||
| From on V6,SR2 the MWI key configuration can be designed to be applicable for all phones. The following excerpt shows how the resulting configuration line would look alike for our example. | |||
|  mod cmd PHONE USER-UI/0 fkey-edit /id 0 /fkey_id 0 /fkey_type mwi /label mwi-off /icon letter /mwi.label mwi-on /mwi.icon letter-black /mwi.led blink /mwi.e164 66 /mwi.ext on /op OK | |||
| * ''/mwi.e164 66'' defines the MC number ''66'' | |||
| * ''/mwi.ext on'' activates the ''Append Own Number'' checkmark | |||
| ===Webserver Aspects=== | ===Webserver Aspects=== | ||
| WebDAV in Common: As stated above, WebDAV is required for the VM to work.   | WebDAV in Common: As stated above, WebDAV is required for the VM to work.   | ||
| What is WebDAV?   | What is WebDAV? In its long form it reads "Web-based Distributed Authoring And Versioning" and is specified in RFC2518.   | ||
| In its long form it reads "Web-based Distributed Authoring And Versioning" and is specified in RFC2518.   | |||
| Technically is WebDAV a set of protocol extensions to the HTTP protocol.   | Technically is WebDAV a set of protocol extensions to the HTTP protocol.   | ||
| These extensions allow for some file i/o operations,that aren't covered by HTTP: | These extensions allow for some file i/o operations,that aren't covered by HTTP: | ||
| *Renaming, moving, copying a file file. | |||
| *Properties: That is, information retrieval about a certain file. E.g. the file creation time. | |||
| ===Webserver Authentication=== | |||
| If HTTP Authentication is required, configure a triple of ''URL,User,Password'' underneath ''Configuration/General/HTTP-Client''. | |||
| In our example ''http://192.168.0.5/webdav/'' may be entered as ''URL''. Every URL that head-matches this URL and requires authentication will be authenticated with the user,password provided here. | |||
| ===Apache Webserver 2.x=== | ===Apache Webserver 2.x=== | ||
| The Apache supports WebDAV from on version 2.0 natively.   | The Apache supports WebDAV from on version 2.0 natively.   | ||
| However, WebDAV must be enabled to be run.   | However, WebDAV must be enabled to be run. Please find the respective documentation page at apache.org under http://httpd.apache.org/docs/2.0/mod/mod_dav.html . | ||
| Please find the respective documentation page at apache.org | |||
| under | |||
| http://httpd.apache.org/docs/2.0/mod/mod_dav.html . | |||
| Test Environment: Our test environment was a RedHat Linux 8.x.   | Test Environment: Our test environment was a RedHat Linux 8.x.   | ||
| The configuration file for httpd resides under /etc/httpd/conf/httpd.conf .   | The configuration file for httpd resides under /etc/httpd/conf/httpd.conf .   | ||
| The voicemail is located underneath /var/www/webdav/vm/. | The voicemail is located underneath /var/www/webdav/vm/. | ||
| Open httpd.conf with a text editor. | Open httpd.conf with a text editor. | ||
| *Ensure the modules required for WebDAV are being loaded | |||
| <syntaxhighlight lang="apache"> | |||
| LoadModule dav_module modules/mod_dav.so | |||
| LoadModule dav_fs_module modules/mod_dav_fs.so | |||
| </syntaxhighlight> | |||
| *Ensure, that WebDAV is enabled and that an alias is being created for webdav | |||
| <syntaxhighlight lang="apache"> | |||
| Dav On | |||
| Alias /webdav "/var/www/webdav" | |||
| </syntaxhighlight> | |||
| Ensure, that WebDAV is enabled and that an alias is being created for webdav | |||
| *In our test environment we didn't restrict access to the webdav directory | |||
| <syntaxhighlight lang="apache"> | |||
| Options Indexes MultiViews | |||
| Allow from all | |||
| </syntaxhighlight> | |||
| An important aspect is the fact, that we had to apply chmod -R 766 to the /var/www/webdav directory. chmod -R 666 didn't suffice.   | An important aspect is the fact, that we had to apply chmod -R 766 to the /var/www/webdav directory. chmod -R 666 didn't suffice.   | ||
| Without doing so, i.e. granting the read-/write-/execute-access, we received Forbidden responses when e.g. | Without doing so, i.e. granting the read-/write-/execute-access, we received Forbidden responses when e.g. trying to read the filenames within a directory. | ||
| trying to read the filenames within a directory. | |||
| A potential delay source can be reverse DNS lookups.   | A potential delay source can be reverse DNS lookups. A webserver is trying to retrieve a DNS name for every source address it receives requests from. The drawback is, that every HTTP request is being delayed by the amount of time it takes to complete the reverse DNS lookup.   | ||
| Within httpd.conf we therefore wrote ''HostNameLookups Off'', in order to avoid DNS requests for logging purposes.   | |||
| Within httpd.conf we therefore wrote HostNameLookups Off, in order to avoid DNS requests for logging purposes.   | |||
| Please note further that access restrictions with DNS names, instead of IP addresses, will | Please note further that access restrictions with DNS names, instead of IP addresses, will | ||
| bypass this setting, i.e. will make the  | bypass this setting, i.e. will make the ''HostNameLookups Off'' -setting ineffective. | ||
| ===Microsoft Internet Information Server (IIS), W2K=== | ===Microsoft Internet Information Server (IIS), W2K=== | ||
| As a testbed an IIS 5.0 was utilized on a Windows 2000 server. By default WebDAV is already enabled within IIS 5.0. However, no data is published. | |||
| *To publish data simply. | |||
| Create a new virtual directory webdav within the default website by means of the IIS Admin. Allow read, write and browse operations being executed on that directory and underneath. | |||
| To publish data simply. | |||
| Create a new virtual directory webdav within the default website by means of the IIS Admin. | |||
| Allow read, write and browse operations being executed on that directory and underneath. | |||
| Use the Windows Explorer to modify the security settings of the directory (and underneath) and set it to full access for everyone (It is left up to the Windows experts how to restrict this further). | Use the Windows Explorer to modify the security settings of the directory (and underneath) and set it to full access for everyone (It is left up to the Windows experts how to restrict this further). | ||
| ===Microsoft Internet Information Server (IIS6), W2003 === | ===Microsoft Internet Information Server (IIS6), W2003 === | ||
| In contrast to Windows 2000 Server, Windows Server 2003 does not come with WebDAV being already enabled. In addition File extensions with *.g711a, *.g711u and *.g729 must be configured as a new Mime-Type. You must enable WebDAV from within the IIS Admin first. Files with the extension *.g711a, *.g711u and *.g729 will not be returned.  | |||
| *You must add *.g711a, *.g711u *.g729 as a Mime-Type, otherwise the audio files won't be accessible.  | |||
| Pls. see: MS KB article Q326965 http://support.microsoft.com/kb/326965/en-us ,respectively http://support.microsoft.com/kb/326965/de-de for how to do this. | |||
| Browse to http://192.168.0.5/webdav/vm/ and try to download a g711a-file and a g729-file from within your browser. This step will prove, that the Mime-Types were successfully added. | |||
| '''Note:''' After the new Mime-Types were added an IIS6 restart seemed to be a MUST. | |||
| ===Microsoft Internet Information server (IIS7)=== | |||
| Two possibilities for authentication are available. | |||
| ====HTTPS With Basic Authentication==== | |||
| IIS7 does NOT support HTTP ''Basic Authentication'' without HTTPS/TLS. Therefore it is mandatory to run WebDAV towards the IIS7 on HTTPS and not on HTTP. | |||
| *Within the Voicemail object a "<nowiki>https://..</nowiki>"-URL must be configured. | |||
| *Under ''General/HTTP/Client'' a user/password tupel must be configured for the "<nowiki>https://..</nowiki>"-URL. | |||
| *Within the IIS Admin it must be ensured that ''Basic Authentication'' is allowed. | |||
| *Try calling the voicemail object. The request for the voicemail script is going to fail. | |||
| *Watch out for a rejected certificate under ''General/Certificates'' and trust that certificate. | |||
| *Try calling again the voicemail object. This time the request for the voicemail script should be succeeding. | |||
| ====HTTP With Digest Authentication==== | |||
| {{FIXME|reason="Information is vague. Practical confirmation needed. Detailing needed."}} | |||
| A user account must be configured within the Active Directory to allow it's password be cached. This is simply because the digest authentication needs to derive a challenge value from a password. That user account/password tupel must in turn be utilized for the innovaphone HTTP client. | |||
| We have had reports that digest authentication does not work with some IIS7 servers.  Evaluation has shown that these servers do require <code>MD5-sess</code> instead of <code>MD5</code> as endpoint authentication type.   | |||
| http:// | Microsoft states ''For security reasons, Windows-based digest authentication only supports MD5-sess encryption over domain controllers that are running under Windows Server 2003.'' [http://technet.microsoft.com/en-us/library/ms191264.aspx].  This suggests that authenticated HTTP access from an innovaphone box to an IIS7 using a domain account may not work at all as long as we do not support MD5-sess (which we don't do as of this writing (January 2012)).  A possible fix may be to use a local server account (although this has not been tested). | ||
| ===Microsoft Internet Information server (IIS7.5)=== | |||
| Despite an allegedly configured server role ''WebDAV Publishing'' a WebDAV-connect wasn't possible until adding a ''WebDAV Authoring Rule'' by means of the IIS Admin. | |||
| *'''Access for''' Entire Content | |||
| *'''Grant Conten Access For''' All Users | |||
| *'''Rights''' Read, Source, Write | |||
| Before administrating this step a ''PROPFIND'' was always honored by a ''405/Method Not Allowed''. | |||
| ===innovaphone own WebDav Server (Compact flash card slot)=== | ===innovaphone own WebDav Server (Compact flash card slot)=== | ||
| Please see [[#Installation, CompactFlash Card|Installation, CompactFlash Card]] below. | |||
| ===Testing WebDAV Access=== | ===Testing WebDAV Access=== | ||
| From within the Windows Explorer go to Tools/Map Network Drive. | From within the Windows Explorer go to Tools/Map Network Drive. | ||
| *Select Web folder or FTP site. | |||
| Select Web folder or FTP site. | *Enter the URL http://192.168.0.5/webdav/ and proceed.   | ||
| Enter the URL | |||
| http://192.168.0.5/webdav/ and proceed | |||
| Now you may test whether you can read files, write files, delete files, create directories. | Now you may test whether you can read files, write files, delete files, create directories. | ||
| ===User-Related Files And Directories=== | ===User-Related Files And Directories=== | ||
| Our sample user has the number 49 and the name test. When this user calls his box 6649 for the first time, the VM will create a directory for him and underneath a pair of additional directories. The new directories for the user test are: | |||
| *…/webdav/vm/test/. New voicemails will be copied here. | |||
| *…/webdav/vm/test/personal. The personal greeting message resides here. | |||
| *…/webdav/vm/test/store. When a message is stored, it is copied into this location. | |||
| If the directory creation fails, the call to the VM will be forcedly disconnected. | |||
| ===PIN Administration=== | |||
| Initially, there is a default PIN active. When being asked for a PIN, enter 8765.   | |||
| The PIN can be changed by means of menu option 4. | |||
| The PIN can be reset administratively to the default by just deleting ''.../personal/pin.txt'' within a user's directory. | |||
| You should '''change the default PIN''' to a different value before installing the Voice Mail. This is done with a text editor in the ''vm.xml'' script.  Change the value <code>8765</code> in function ''CheckPin'' and function ''EnterPin''. | |||
| ===URL Query String Variables=== | ===URL Query String Variables=== | ||
| Line 263: | Line 253: | ||
| **true: Voicemail owner doesn't need to enter a PIN when calling from his extension. | **true: Voicemail owner doesn't need to enter a PIN when calling from his extension. | ||
| **false (default): A PIN must be entered | **false (default): A PIN must be entered | ||
| (Note: A PIN must always be entered when calling from "foreign" extensions) | |||
| * $_initdelay: Controls, whether an initial silence prompt is going to be played to a caller. From on script version ['''vm.xml 60096''']. | |||
| ** 0(default): No silence prompt will be played. | |||
| ** a value greater than 0: A silence prompt of ''N'' seconds is going to be played. For hosting scenarios the recommended value is '1'. | |||
| * $_pbxcoder. Allows to restrain the offered coder list, when executing <pbx-prompt> for files with "*.$coder" extensions.   | * $_pbxcoder. Allows to restrain the offered coder list, when executing <pbx-prompt> for files with "*.$coder" extensions.   | ||
| ** The internal default is: $_pbxcoder=g729,g711a,g711u, | ** The internal default is: $_pbxcoder=g729,g711a,g711u,g722,opus-wb,opus-nb | ||
| * $_pbxfwd | * $_pbxfwd | ||
| Line 277: | Line 272: | ||
| ** false: No REMOTE-HOLD is sent | ** false: No REMOTE-HOLD is sent | ||
| * $_trace, decimal number: Controls verbosity of tracing outputs. The following values can be added. | * $_noctl (from on v8hotfix8) | ||
| ** 1:  errors, 2:  interpreter, 4:  parsing, 8:  code, 16: store operations, 32: http operations (during <exec>) | **true: Control-calls (calls without media) will be rejected | ||
| **false (default): no rejection | |||
| * $_divconn (from on v9hotfix17) | |||
| **true: Auto-Connect for calls being recognized as diverted or transferred calls | |||
| ***Note: Until V11r1sr2 the former default was ''true'' | |||
| **false(default): No automated connection for diverted/transferred calls. | |||
| '''Note:''' It is recommended to configure '''$_divconn=false''' in scenarios with remote media streaming(via an active registration at the VM object). | |||
| * $_trace, decimal number: Controls verbosity of tracing outputs. The following values can be added. Everything can be traced by simply entering 255 (i.e. ''$_trace=255''). | |||
| ** 1:  errors, 2:  interpreter, 4:  parsing, 8:  code, 16: store operations, 32: http operations (during <exec>), 64: <debug> statements, 128: webmedia | |||
| *$_leg2tweak (from on v9hotfix21) controls <pbx-getcallinfo out-leg2=".."/> | |||
| **true(default): set leg2 to <ext-nr> from <vm-nr>+<ext-nr> | |||
| **false: set leg2 according to received divertingInfoLeg2 facility | |||
| *$_trailhash (from on v9hotfix21) controls <pbx-getcallinfo out-cdpn=".."/> | |||
| **true: pass trailing (en-bloc) '#' into cdpn | |||
| **false(default): don't pass trailing (en-bloc) '#' into cdpn | |||
| * $_pbxfwdrel controls <pbx-fwd> (from on v10sr5) | |||
| **conn: release all interpreter resources after a successful connect. No further scripting affects the call. | |||
| **imm: release all interpreter resources immediately on the execution of the <pbx-fwd> statement. No further scripting affects the call. | |||
| **false(default): No tweaks apply. The script interpreter remains active. | |||
| *$app activates settings, necessary for the App Platform's Voicemail App (v13r1 and later only) | |||
| **on: Activate internal settings for the Voicemail App (only use this setting if the voicemail runs on the new App Platform) | |||
| **off(default): No tweaks apply. | |||
| *$_defaultpin configures a default pin (from on vm.xml, 60137) | |||
| **E.g. to configure the default pin ''123456'' <code>http://a.b.c.d/vm.xml?$_defaultpin=123456</code> | |||
| ==Installation, CompactFlash Card== | ==Installation, CompactFlash Card== | ||
| Line 288: | Line 313: | ||
| ==Advanced Configuration== | ==Advanced Configuration== | ||
| === Maximum Message Length === | |||
| By default, voicemail messages are limited to 50 seconds each. | |||
| To change the maximum length (e.g. to 5 minutes), you have to change the following code line | |||
|  <pbx-record url="$vm" sec="50"/> | |||
| to | |||
|  <pbx-record url="$vm" sec="300"/> | |||
| === Change Filename of the Recorded Messages of Voicemail === | |||
| ==== Filename without Meta Data (< V13r1) ==== | |||
| By default the vm.xml records the voice messages in the CF at UserBox with an Unique Name, type of GUID + Extension and this is also what is send to the user email when we set that option.  | |||
| Example: 2110d5f4e909d311baab0090332901b6-202.wav | |||
| We can change this filename format by editing the vm.xml approx. line 63: | |||
| replace | |||
|  <store-getnew root="$sub" out-url="$vm"/> | |||
|  <lib-strcat string="$vm" string2="-" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$cgpn" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2=".g711a" out-string="$vm" /> | |||
| with | |||
|  <store-getstat root="" name="NULL" out-wday="$wday" out-mday="$mday" out-mon="$mon" out-year="$year" out-hour="$hour" out-min="$min"/> | |||
|  <store-get root="$sub" name="Date_" out-url="$vm"/>	 | |||
|  <lib-strcat string="$vm" string2="$year" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="_" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$mon" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="_" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$mday" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="_time_" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$hour" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="_" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$min" out-string="$vm" />	 | |||
|  <lib-strcat string="$vm" string2="_number-" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2="$cgpn" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2=".g711a" out-string="$vm" /> | |||
| Doing this will obtain a filename with Date, Hour, Number and CGPN. | |||
| ==== Filename with Meta Data ==== | |||
| From version 13r1 on the filename of the stored voice messages contains meta data which is needed by the Voicemail-App to display the caller correctly.  | |||
| Example: 3322f244be0c6701ce370090334209f2-cgpn=202&sip=jdo&dn=Jane%20Doe.g711a  | |||
| As we simply cannot remove this meta from the filename, we can do the following: | |||
| Extend vm.xml from line 70 on, so that an extra filename (stored in '$vm-mail') is created: | |||
|  <store-getnew root="$sub" out-url="$vm"/> | |||
|  <lib-strcat string="$vm" string2="-" out-string="$vm" /> | |||
|  <call name="PrepMetaData"/> | |||
|  <lib-strcat string="$vm" string2="$sig-meta" out-string="$vm" /> | |||
|  <lib-strcat string="$vm" string2=".g711a" out-string="$vm" /> | |||
|  <!-- This is newly inserted code, which can be adjusted freely: --> | |||
|  <!-- Custom Code creating the desired filename for the email-attachment -->  | |||
|  <store-getstat root="" name="NULL" out-wday="$wday" out-mday="$mday" out-mon="$mon" out-year="$year" out-hour="$hour" out-min="$min"/> | |||
|  <store-get root="$sub" name="Date_" out-url="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$year" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$mon" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$mday" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="_" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$hour" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$min" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="_VM_from_" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2="$cgpn" out-string="$vm-mail" /> | |||
|  <lib-strcat string="$vm-mail" string2=".g711a" out-string="$vm-mail" /> | |||
|  <!-- Custom Code creating the desired filename for the email-attachment --> | |||
|  <pbx-mwi/> | |||
| As we have just defined the desired filename to be mailed out, we need to use this when mailing. So we'll still need to adjust email.xml in two places too. | |||
| replace (line 92-94) | |||
|  <if cond="$vm">		 | |||
|   <assign out="$file" value="$vm"/>       <!-- $vm holds file name --> | |||
|  </if> | |||
| with | |||
|  <if cond="$vm"> | |||
|   <if cond="$vm-mail"> <!-- Use Adjusted Filename Part 1 --> | |||
|    <store-ren root="" name="$vm" new-name="$vm-mail"/>     <!-- 1. Rename the file in the database --> | |||
|    <assign out="$file" value="$vm-mail"/>                  <!-- 2. Select the renamed file --> | |||
|   </if> | |||
|   <else> | |||
|    <assign out="$file" value="$vm"/>                       <!-- Use Default Filename --> | |||
|   </else> | |||
|  </if> | |||
| This will change the current filename in database with the desired filename to be mailed out. | |||
| add the following code, just under the second mail-attempt (line 114 and further / just before the last </if>):  | |||
|  <if cond="$vm-mail"> <!-- Use Adjusted Filename Part 2 --> | |||
|   <store-ren root="" name="$vm-mail" new-name="$vm"/>     <!-- 3. Reset the Original Name in the database --> | |||
|  </if> | |||
| This will rename the filename in the database with the previous one containing the necessary meta data. | |||
| ===Leave Message to the VoiceMail Box of the original called User=== | |||
| By default the VoiceMail stores the voice message to the Mailbox of the Object performing diversion to the VoiceMail. E.g. if "User A" creates a call forward to the VoiceMail, the Mailbox is used to store the message is from "User A". In case "User A" creates a call forward to a Waiting Queue or Call Broadcast, and than from Call Broadcast Group to the VoiceMail, the message will be stored in the Mailbox of the Call Broadcast Group. | |||
| To change this behaviour and to store the Message always to the Mailbox of the originally called User, change the vm.xml as following: | |||
| search the line: | |||
| <syntaxhighlight lang="xml"> | |||
| <pbx-getcallinfo out-cgpn="$cgpn" out-cdpn="$cdpn" out-leg2="$leg2"/> | |||
| </syntaxhighlight> | |||
| and replace them with the following | |||
| <syntaxhighlight lang="xml"> | |||
| <pbx-getcallinfo out-cgpn="$cgpn" out-cdpn="$cdpn" out-leg2="$leg2" out-leg2-orig="$leg3"/> | |||
| <switch var="$leg3"> | |||
|   <case not-equal=""> | |||
|     <assign out="$leg2" value="$leg3"/> | |||
|     <assign out="$_pbxcdpn" value="$leg3"/> | |||
|   </case> | |||
| </switch> | |||
| </syntaxhighlight> | |||
| ===Sending of additional MWIs=== | ===Sending of additional MWIs=== | ||
| A comma-separated list of MWI destinations/recipients can be configured by means of a variable $_m within the script URL's query string. [[Howto:Group_Voicemail | The Group Voicemail article]] outlines a configuration scheme for this functionality. | |||
| Alternatively, the [[Howto:How To Send Additional MWIs within a PBX|How To Send Additional MWIs within a PBX]] describes an older solution - not integrated within the [[Reference13r2:Concept_App_Service_Voicemail | Voicemail App]]. | |||
| ===Custom Personal Announcement=== | ===Custom Personal Announcement=== | ||
| * [[Howto:Deploy A Custom Personal Announcement For the innovaphone Voicemail|Deploy A Custom Personal Announcement For the innovaphone Voicemail]] | * [[Howto:Deploy A Custom Personal Announcement For the innovaphone Voicemail|Deploy A Custom Personal Announcement For the innovaphone Voicemail]] | ||
| Explains where to copy an externally generated personal announcement file. | Explains where to copy an externally generated personal announcement file. | ||
| ===A Simple Recording Solution On-Top of The innovaphone Voicemail=== | |||
| * [[Howto:A Simple Recording Solution On-Top of The innovaphone Voicemail|A Simple Recording Solution On-Top of The innovaphone Voicemail]] | |||
| This article explains how a simple recording solution could be set up on-top of an innovaphone Voicemail. | |||
| ===Send Email MWI Notification From The innovaphone Voicemail=== | |||
| *[[Howto:Send Email MWI Notification From The innovaphone Voicemail|Send Email MWI Notification From The innovaphone Voicemail]] | |||
| This functionality is available from on SR2 and allows to send MWI notifications by email. | |||
| ===Enable Mailbox Administration from extern=== | |||
| Since build 60143 the administration menu was removed. | |||
| It is possible to log in into the voicemail administration with a ''9'' as DTMF key while leaving a message. After entering the correct [[Howto:Configure_the_innovaphone_Voicemail#PIN_Administration|PIN]], you can access the voicemail administration. | |||
| This may create problems, if you use an unsecure PIN, no PIN or the default PIN.  | |||
| To bring back this function you have to change the following code line inside the function ''AnsweringMachine'' in your ''vm.xml''. | |||
| <syntaxhighlight lang="xml"> | |||
| <if notcond="$greeting"> | |||
|   <assign out="$greeting" value="box"/> | |||
| </if> | |||
| <switch var="$greeting"> | |||
| </syntaxhighlight> | |||
| to  | |||
| <syntaxhighlight lang="xml"> | |||
| <if notcond="$greeting"> | |||
|   <assign out="$greeting" value="box"/> | |||
| </if> | |||
| <event type="dtmf" block="false"> | |||
|   <pbx-getdtmfdigit out-dtmf="$dtmf" /> | |||
|   <switch var="$dtmf"> | |||
|     <case equal="9"> | |||
|       <call name="Voicebox"/> | |||
|     </case> | |||
|   </switch> | |||
| </event> | |||
| <switch var="$greeting"> | |||
| </syntaxhighlight> | |||
| ==Quick Reference For innovaphone Voicemail== | ==Quick Reference For innovaphone Voicemail== | ||
| * [[Howto:Quick Reference For innovaphone Voicemail|Quick Reference For innovaphone Voicemail]] | * [[Howto:Quick Reference For innovaphone Voicemail|Quick Reference For innovaphone Voicemail]] | ||
| The article outlines the menu structure and provides a few operational hints from a user's perspective. | The article outlines the menu structure and provides a few operational hints from a user's perspective. | ||
| ==Special-Purpose Script Variables, Firmware Version 13r1== | |||
| From on 13r1 a few script variables with special meaning were introduced. Among others, this enables a script to read the static configuration underneath ''PBX/Config/Authentication/Email Verification''. | |||
| ;$_pbx_auth_email_server: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/SMTP server'' | |||
| ;$_pbx_auth_email_host: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/Client host name'' | |||
| ;$_pbx_auth_email_addr: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/Email address'' | |||
| ;$_pbx_auth_email_usr: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/Username'' | |||
| ;$_pbx_auth_email_pwd: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/Password'' | |||
| ;$_pbx_auth_email_sender: | |||
| Retrieves ''PBX/Config/Authentication/Email Verification/Sender name'' | |||
| ;$_pbx_version_soap: | |||
| Retrieves the firmware version. E.g. "1300" for 13r1. | |||
| ==Known Problems== | ==Known Problems== | ||
| Line 304: | Line 515: | ||
| This is why V5 endpoints are not supported. | This is why V5 endpoints are not supported. | ||
| *[[Support:Voicemail Calls Hanging Around In PBX Call Monitor|Support:Voicemail Calls Hanging Around In PBX Call Monitor]] | |||
| *[[Support:Voicemail: Voicebox Not Configurable With "Send Number" set|Support: Voicemail: Voicebox Not Configurable With "Send Number" set]] | |||
| * When the voicebox is created upon the first call to the users voicemail, you must not have the ''Send Number'' property configured in the calling user object.  Otherwise, the voicebox will be created for the wrong number | |||
| * [[Support:Voicemail Fails With "Missing Voicemail License!"|Support:Voicemail Fails With "Missing Voicemail License!"]] | |||
| *[[Support:Voicemail Fails With "Authentication Required"|Support:Voicemail Fails With "Authentication Required"]] | |||
| *[[Support:Webdav_Access_Slow_From_Windows_7_/_Vista|Support:Webdav Access Slow From Windows 7 /Vista]] | |||
| * You can not have a voice mailbox for users that have a slash (<code>/</code>) in the ''Long Name''.  For such user, when calling the voice mail, a spoken error message ''an error occured'' is heard | |||
| ** de: ''es ist leider ein Fehler aufgetreten'' | |||
| * If the voicemail URL is a webdav server on a LinuxAP, the dns domain name of the URL must be typed in lower cases, otherwise changes to the welcome and personal message (name_greetings and personal_greetings) won't be correctly saved. | |||
| * If the voicemail is located on a webdav server on a LinuxAP make sure the folder of the voicemail has for group and owner "www-data" and not "root". Otherwise you cannot create user folders. | |||
| * Forking to a VM Object without mobility object (license required) will display the name of the forking target in the caller display and his calllist. (To prevent this behaviour, use a mobility object for the forking to <code>doorcall-trigger</code>) | |||
| == Related Articles == | |||
| ===Voicemail Installation=== | |||
| * [[Howto:How to setup an V6 IP Phone for innovaphone voicemail usage]] | |||
| * [[Howto:Send Email MWI Notification From The innovaphone Voicemail]] | |||
| * [[Howto:Quick Reference For innovaphone Voicemail]] | |||
| * [[Howto:Forward your Mobile's Mailbox to your innovaphone Voicemail]] | |||
| * [[Howto:MWI for DECT]] | |||
| ==  | ===Voicemail on Compact Flash=== | ||
| [[Howto: | |||
| * [[Howto:General information for compact flash cards]] | |||
| * [[Howto:Installing the voicemail/music on hold on a compact flash card]] | |||
| ===Voicemail Customising=== | |||
| [ | * [[Howto:Deploy A Custom Personal Announcement For the innovaphone Voicemail]] | ||
| *[[Howto:Does innovaphone voicemail support multiple announcements?]] | |||
| * [[Howto:How To Send Additional MWIs within a PBX]] | |||
| *[[Howto:Send Email from the innovaphone Voicemail without saving data on the CF]] | |||
| *[[Howto:Localize Voice Mail Messages]] | |||
| [ | ===Voicemail Scripting=== | ||
| *[[Howto:Wiki_Sources]] | |||
| *[[Howto:Implement a simple caller notification]] | |||
| *[[Howto:Getting started with your own PBX voicemail script]] | |||
| *[[Howto:Debug_your_own_PBX_voicemail_script]] | |||
| *[[Howto:A Simple Recording Solution On-Top of The innovaphone Voicemail]] | |||
| *[[Howto:Voicemail Scripting And Projektcode, PIN, Auth Code]] | |||
| *[[Howto:Simple ACD with Voicemail XML Script]] | |||
| *[[Howto:Control Call Forward with Voicemail XML Script]] | |||
| *[[Howto:Using the Voicemail object as a post call review]] | |||
| *[[Howto:Voice_Mail_multiple_announcements_with_and_without_possibility_to_leave_a_message]] | |||
| *[[Howto:Speaking_Clock_with_Voicemail_XML_Script]] | |||
| *[[Howto:Absence_Memo_with_VoiceMail_XML_Script]] | |||
| [ | == Download == | ||
| The voicemail product can currently be found on the [http://download.innovaphone.com/ice/6.00/#apps apps section] of the innovaphone download site.  This product is suitable for PBX firmware ''versions 6 and up''. | |||
| [[Category:Howto|{{PAGENAME}}]] | [[Category:Howto|{{PAGENAME}}]] | ||
Latest revision as of 08:24, 14 October 2024
The innovaphone voicemail (VM) is implemented as a PBX object. An answering machine can be assigned to each PBX user. The VM is script-driven and controlled by means of DTMF touchtones. It features a built-in WebDAV client, enabling the VM to communicate to an external WebDAV server, which serves as the mass-storage for audio files, script files and user-directories. The VM script and pre-recorded audio files are subject to be provided by innovaphone. Message Waiting Indication (MWI) is supported.
Applies To
This information applies to
- innovaphone PBX, V6 and Higher
Supporting The innovaphone Voicemail
Tracing
For a decent supportable trace
- Activate the trace checkmark within the UI of the voicemail object
- Append the parameter $_trace=251 to the configured script URL, alike so: https://1.2.3.4/drive/CF0/de/vm.xml?$_trace=251
- Activate the PBX checkmark within the Reference13r3:Maintenance/Diagnostics/Tracing page
More Information
System Requirements
Voicemail license: The innovaphone voicemail requires licensing. The number of acquired voicemail licenses must be equal or greater than the number of PBX basic licenses.
WebDAV server, e.g.: Apache 2.x, IIS W2K, IIS W3K, or with V6 sr1 the compat flash drive (no external WebDAV server needed)
Innovaphone will provide you with an XML script, that represents the actual voicemail. In addition you will get a set of files with *.g711a, *.g711u, *.g722, *.opus-wb, *.opus-nb and *.g729 extensions. These files contain the audio snippets and the menu prompts, that the voicemail requires.
Installation, WebDAV
A few preconditions are assumed as basis for the following few installation and configuration steps:
- The number of the VM object is 66.
- The number of a sample user test is 49.
- The IP address of the WebDAV server is 192.168.0.5.
- The root directory, that contains the VM script and the pre-recorded audio files is c:\Inetpub\webdav\vm\en which corresponds to the URL http://192.168.0.5/webdav/vm/.
- The file name of the voicemail XML script is vm.xml.
Creating the Voicemail Object
Proceed to Administration/PBX/Objects.
- Select Voicemail from the drop-down list and click on new.
- Enter Long Name, Name.
- Enter 66 as Number.
- Enter the Script URL as http://192.168.0.5/webdav/vm/vm.xml.
- Note:Meanwhile it is recommended to enter it as: http://192.168.0.5/webdav/vm/vm.xml?$_pbxfwd=true (see #URL Query String Variables)
 
Distributing the Voicemail Script and Pre-Recorded Audio Files
The download section offers ZIP files and a Windows installation program. See #Download for how to find the download site.
- ZIP files
- Download the ZIP file for the language your are interested in (e.g. vm-de, vm-en, ...) from the apps package on the innovaphone download area, V6 Apps.
- Un-ZIP the file. This step creates a language specific sub-directory that may be copied onto the CF-card.
 
- Windows installation program
- Download the installation program for the innovaphone voicemail from the innovaphone download area.
- Start the installer program (innovaphone-voicemail-install.exe).
- The installer will be asking for a target directory. Enter c:\Inetpub\webdav\vm\. Now, the installer will copy all of the localized voicemail files into language specific sub-directories. The english files will remain under the absolute path c:\Inetpub\webdav\vm\en\.
 
Configuration
Please note, that a user's VM number is the number of the VM object, that you assigned here, plus the user's number.
Example: If a user has the number 49 and the number of the VM object is 66, then the user's corresponding VM number will be 6649.
IP Phone Configuration
V6, SR1: Recommended Configuration
A user may wish to manually activate or deactivate a CFU diversion to his VM.
- Browse to the IP phone of the user 49:test:
- Proceed to Configuration/RegistrationX/Function Keys.
- Select a free function key, choose Call Forwarding and click on new.
- A new window will open. Enter AM-on under Idle State/Text.
- Enter AM-off under Active State [1]/Text.
- Enter 6649 into Active State [1]/Text/Always/Number.
- Click on OK.
An additional function key is required to present the MWI and to quick-dial the VM:
- Proceed to Configuration/RegistrationX/Function Keys.
- Select a free function key, choose Message Waiting and click on new.
- A new window will open. Enter AM under Idle State/Text.
- Select the letter icon under Active State/Icon.
- If you desire, then choose LED/blink.
- Enter 6649 into Message Center Account/Number.
- Click on OK.
V6, SR2: Recommended Configuration
The SR2 configuration adapts to mass-deployment requirements, in such that the set of required configuration parameters can be distributed identically among all affected phones.
A user may wish to manually activate or deactivate a CFU diversion to his VM.
- Browse to the IP phone of the user 49:test:
- Proceed to Configuration/RegistrationX/Function Keys.
- Select a free function key, choose Call Forwarding and click on new.
- A new window will open. Enter AM-on under Idle State/Text.
- Enter AM-off under Active State [1]/Text.
- Enter 66 into Active State [1]/Text/Always/Number.
- Click on OK.
An additional function key is required to present the MWI and to quick-dial the VM:
- Proceed to Configuration/RegistrationX/Function Keys.
- Select a free function key, choose Message Waiting and click on new.
- A new window will open. Enter AM under Idle State/Text.
- Select the letter icon under Active State/Icon.
- If you desire, then choose LED/blink.
- Enter 66 into Message Center Account/Number.
- Activate the Append Own Number checkmark.
- Click on OK.
Deploying the MWI Function Key By An Update Script
From on V6,SR2 the MWI key configuration can be designed to be applicable for all phones. The following excerpt shows how the resulting configuration line would look alike for our example.
mod cmd PHONE USER-UI/0 fkey-edit /id 0 /fkey_id 0 /fkey_type mwi /label mwi-off /icon letter /mwi.label mwi-on /mwi.icon letter-black /mwi.led blink /mwi.e164 66 /mwi.ext on /op OK
- /mwi.e164 66 defines the MC number 66
- /mwi.ext on activates the Append Own Number checkmark
Webserver Aspects
WebDAV in Common: As stated above, WebDAV is required for the VM to work.
What is WebDAV? In its long form it reads "Web-based Distributed Authoring And Versioning" and is specified in RFC2518. Technically is WebDAV a set of protocol extensions to the HTTP protocol. These extensions allow for some file i/o operations,that aren't covered by HTTP:
- Renaming, moving, copying a file file.
- Properties: That is, information retrieval about a certain file. E.g. the file creation time.
Webserver Authentication
If HTTP Authentication is required, configure a triple of URL,User,Password underneath Configuration/General/HTTP-Client.
In our example http://192.168.0.5/webdav/ may be entered as URL. Every URL that head-matches this URL and requires authentication will be authenticated with the user,password provided here.
Apache Webserver 2.x
The Apache supports WebDAV from on version 2.0 natively.
However, WebDAV must be enabled to be run. Please find the respective documentation page at apache.org under http://httpd.apache.org/docs/2.0/mod/mod_dav.html .
Test Environment: Our test environment was a RedHat Linux 8.x. The configuration file for httpd resides under /etc/httpd/conf/httpd.conf . The voicemail is located underneath /var/www/webdav/vm/.
Open httpd.conf with a text editor.
- Ensure the modules required for WebDAV are being loaded
LoadModule dav_module modules/mod_dav.so
LoadModule dav_fs_module modules/mod_dav_fs.so
- Ensure, that WebDAV is enabled and that an alias is being created for webdav
Dav On
Alias /webdav "/var/www/webdav"
- In our test environment we didn't restrict access to the webdav directory
Options Indexes MultiViews
Allow from all
An important aspect is the fact, that we had to apply chmod -R 766 to the /var/www/webdav directory. chmod -R 666 didn't suffice.
Without doing so, i.e. granting the read-/write-/execute-access, we received Forbidden responses when e.g. trying to read the filenames within a directory.
A potential delay source can be reverse DNS lookups. A webserver is trying to retrieve a DNS name for every source address it receives requests from. The drawback is, that every HTTP request is being delayed by the amount of time it takes to complete the reverse DNS lookup.
Within httpd.conf we therefore wrote HostNameLookups Off, in order to avoid DNS requests for logging purposes.
Please note further that access restrictions with DNS names, instead of IP addresses, will bypass this setting, i.e. will make the HostNameLookups Off -setting ineffective.
Microsoft Internet Information Server (IIS), W2K
As a testbed an IIS 5.0 was utilized on a Windows 2000 server. By default WebDAV is already enabled within IIS 5.0. However, no data is published.
- To publish data simply.
Create a new virtual directory webdav within the default website by means of the IIS Admin. Allow read, write and browse operations being executed on that directory and underneath. Use the Windows Explorer to modify the security settings of the directory (and underneath) and set it to full access for everyone (It is left up to the Windows experts how to restrict this further).
Microsoft Internet Information Server (IIS6), W2003
In contrast to Windows 2000 Server, Windows Server 2003 does not come with WebDAV being already enabled. In addition File extensions with *.g711a, *.g711u and *.g729 must be configured as a new Mime-Type. You must enable WebDAV from within the IIS Admin first. Files with the extension *.g711a, *.g711u and *.g729 will not be returned.
- You must add *.g711a, *.g711u *.g729 as a Mime-Type, otherwise the audio files won't be accessible.
Pls. see: MS KB article Q326965 http://support.microsoft.com/kb/326965/en-us ,respectively http://support.microsoft.com/kb/326965/de-de for how to do this.
Browse to http://192.168.0.5/webdav/vm/ and try to download a g711a-file and a g729-file from within your browser. This step will prove, that the Mime-Types were successfully added.
Note: After the new Mime-Types were added an IIS6 restart seemed to be a MUST.
Microsoft Internet Information server (IIS7)
Two possibilities for authentication are available.
HTTPS With Basic Authentication
IIS7 does NOT support HTTP Basic Authentication without HTTPS/TLS. Therefore it is mandatory to run WebDAV towards the IIS7 on HTTPS and not on HTTP.
- Within the Voicemail object a "https://.."-URL must be configured.
- Under General/HTTP/Client a user/password tupel must be configured for the "https://.."-URL.
- Within the IIS Admin it must be ensured that Basic Authentication is allowed.
- Try calling the voicemail object. The request for the voicemail script is going to fail.
- Watch out for a rejected certificate under General/Certificates and trust that certificate.
- Try calling again the voicemail object. This time the request for the voicemail script should be succeeding.
HTTP With Digest Authentication
A user account must be configured within the Active Directory to allow it's password be cached. This is simply because the digest authentication needs to derive a challenge value from a password. That user account/password tupel must in turn be utilized for the innovaphone HTTP client.
We have had reports that digest authentication does not work with some IIS7 servers.  Evaluation has shown that these servers do require MD5-sess instead of MD5 as endpoint authentication type. 
Microsoft states For security reasons, Windows-based digest authentication only supports MD5-sess encryption over domain controllers that are running under Windows Server 2003. [1]. This suggests that authenticated HTTP access from an innovaphone box to an IIS7 using a domain account may not work at all as long as we do not support MD5-sess (which we don't do as of this writing (January 2012)). A possible fix may be to use a local server account (although this has not been tested).
Microsoft Internet Information server (IIS7.5)
Despite an allegedly configured server role WebDAV Publishing a WebDAV-connect wasn't possible until adding a WebDAV Authoring Rule by means of the IIS Admin.
- Access for Entire Content
- Grant Conten Access For All Users
- Rights Read, Source, Write
Before administrating this step a PROPFIND was always honored by a 405/Method Not Allowed.
innovaphone own WebDav Server (Compact flash card slot)
Please see Installation, CompactFlash Card below.
Testing WebDAV Access
From within the Windows Explorer go to Tools/Map Network Drive.
- Select Web folder or FTP site.
- Enter the URL http://192.168.0.5/webdav/ and proceed.
Now you may test whether you can read files, write files, delete files, create directories.
User-Related Files And Directories
Our sample user has the number 49 and the name test. When this user calls his box 6649 for the first time, the VM will create a directory for him and underneath a pair of additional directories. The new directories for the user test are:
- …/webdav/vm/test/. New voicemails will be copied here.
- …/webdav/vm/test/personal. The personal greeting message resides here.
- …/webdav/vm/test/store. When a message is stored, it is copied into this location.
If the directory creation fails, the call to the VM will be forcedly disconnected.
PIN Administration
Initially, there is a default PIN active. When being asked for a PIN, enter 8765.
The PIN can be changed by means of menu option 4.
The PIN can be reset administratively to the default by just deleting .../personal/pin.txt within a user's directory.
You should change the default PIN to a different value before installing the Voice Mail. This is done with a text editor in the vm.xml script.  Change the value 8765 in function CheckPin and function EnterPin.
URL Query String Variables
URL Query String Variables are generally passed on to a script.
The following variables control the script's behaviour and may be applied within the configured script-URL alike: http://192.168.0.5/webdav/vm/vm.xml?$_nopin=true.
Multiple variables can be combined by an ampersand (&) alike: http://192.168.0.5/webdav/vm/vm.xml?$_nopin=true&$_pbxcoder=g711a.
- $_nopin. Controls, whether a PIN must be entered.
- true: Voicemail owner doesn't need to enter a PIN when calling from his extension.
- false (default): A PIN must be entered
 
(Note: A PIN must always be entered when calling from "foreign" extensions)
- $_initdelay: Controls, whether an initial silence prompt is going to be played to a caller. From on script version [vm.xml 60096].
- 0(default): No silence prompt will be played.
- a value greater than 0: A silence prompt of N seconds is going to be played. For hosting scenarios the recommended value is '1'.
 
- $_pbxcoder. Allows to restrain the offered coder list, when executing <pbx-prompt> for files with "*.$coder" extensions.
- The internal default is: $_pbxcoder=g729,g711a,g711u,g722,opus-wb,opus-nb
 
- $_pbxfwd
- true: diversions will be executed on <pbx-fwd>
- false (default): diversions won't be executed on <pbx-fwd>
 
- $_pbxmwidir. Allows to configure a parent directory for all user sub-directories and for all MWI operations. As default there is no such directory active.
- $_pbxremhold
- true (default): Rules whether caller will be sent a REMOTE-HOLD while executing <pbx-fwd>.
- false: No REMOTE-HOLD is sent
 
- $_noctl (from on v8hotfix8)
- true: Control-calls (calls without media) will be rejected
- false (default): no rejection
 
- $_divconn (from on v9hotfix17)
- true: Auto-Connect for calls being recognized as diverted or transferred calls
- Note: Until V11r1sr2 the former default was true
 
- false(default): No automated connection for diverted/transferred calls.
 
- true: Auto-Connect for calls being recognized as diverted or transferred calls
Note: It is recommended to configure $_divconn=false in scenarios with remote media streaming(via an active registration at the VM object).
- $_trace, decimal number: Controls verbosity of tracing outputs. The following values can be added. Everything can be traced by simply entering 255 (i.e. $_trace=255).
- 1: errors, 2: interpreter, 4: parsing, 8: code, 16: store operations, 32: http operations (during <exec>), 64: <debug> statements, 128: webmedia
 
- $_leg2tweak (from on v9hotfix21) controls <pbx-getcallinfo out-leg2=".."/>
- true(default): set leg2 to <ext-nr> from <vm-nr>+<ext-nr>
- false: set leg2 according to received divertingInfoLeg2 facility
 
- $_trailhash (from on v9hotfix21) controls <pbx-getcallinfo out-cdpn=".."/>
- true: pass trailing (en-bloc) '#' into cdpn
- false(default): don't pass trailing (en-bloc) '#' into cdpn
 
- $_pbxfwdrel controls <pbx-fwd> (from on v10sr5)
- conn: release all interpreter resources after a successful connect. No further scripting affects the call.
- imm: release all interpreter resources immediately on the execution of the <pbx-fwd> statement. No further scripting affects the call.
- false(default): No tweaks apply. The script interpreter remains active.
 
- $app activates settings, necessary for the App Platform's Voicemail App (v13r1 and later only)
- on: Activate internal settings for the Voicemail App (only use this setting if the voicemail runs on the new App Platform)
- off(default): No tweaks apply.
 
- $_defaultpin configures a default pin (from on vm.xml, 60137)
- E.g. to configure the default pin 123456 http://a.b.c.d/vm.xml?$_defaultpin=123456
 
- E.g. to configure the default pin 123456 
Installation, CompactFlash Card
Instead of using a WebDAV server you may want to use the local CompactFlash card as mass storage device. This section outlines how this can be accomplished.
Installing the Voicemail on a CompactFlash Card
Please see the article Howto:Installing the voicemail on a compact flash card.
The aforementioned configuration scenario, within the above chapter: Installation, WebDav, does also apply for an installation on a CompactFlash card. Please, refer to that chapter if you look for informations on how to generally configure a basic voicemail scenario, including the affected ip phone configuration.
Advanced Configuration
Maximum Message Length
By default, voicemail messages are limited to 50 seconds each. To change the maximum length (e.g. to 5 minutes), you have to change the following code line
<pbx-record url="$vm" sec="50"/>
to
<pbx-record url="$vm" sec="300"/>
Change Filename of the Recorded Messages of Voicemail
Filename without Meta Data (< V13r1)
By default the vm.xml records the voice messages in the CF at UserBox with an Unique Name, type of GUID + Extension and this is also what is send to the user email when we set that option. Example: 2110d5f4e909d311baab0090332901b6-202.wav
We can change this filename format by editing the vm.xml approx. line 63:
replace
<store-getnew root="$sub" out-url="$vm"/> <lib-strcat string="$vm" string2="-" out-string="$vm" /> <lib-strcat string="$vm" string2="$cgpn" out-string="$vm" /> <lib-strcat string="$vm" string2=".g711a" out-string="$vm" />
with
<store-getstat root="" name="NULL" out-wday="$wday" out-mday="$mday" out-mon="$mon" out-year="$year" out-hour="$hour" out-min="$min"/> <store-get root="$sub" name="Date_" out-url="$vm"/> <lib-strcat string="$vm" string2="$year" out-string="$vm" /> <lib-strcat string="$vm" string2="_" out-string="$vm" /> <lib-strcat string="$vm" string2="$mon" out-string="$vm" /> <lib-strcat string="$vm" string2="_" out-string="$vm" /> <lib-strcat string="$vm" string2="$mday" out-string="$vm" /> <lib-strcat string="$vm" string2="_time_" out-string="$vm" /> <lib-strcat string="$vm" string2="$hour" out-string="$vm" /> <lib-strcat string="$vm" string2="_" out-string="$vm" /> <lib-strcat string="$vm" string2="$min" out-string="$vm" /> <lib-strcat string="$vm" string2="_number-" out-string="$vm" /> <lib-strcat string="$vm" string2="$cgpn" out-string="$vm" /> <lib-strcat string="$vm" string2=".g711a" out-string="$vm" />
Doing this will obtain a filename with Date, Hour, Number and CGPN.
Filename with Meta Data
From version 13r1 on the filename of the stored voice messages contains meta data which is needed by the Voicemail-App to display the caller correctly. Example: 3322f244be0c6701ce370090334209f2-cgpn=202&sip=jdo&dn=Jane%20Doe.g711a
As we simply cannot remove this meta from the filename, we can do the following:
Extend vm.xml from line 70 on, so that an extra filename (stored in '$vm-mail') is created:
<store-getnew root="$sub" out-url="$vm"/> <lib-strcat string="$vm" string2="-" out-string="$vm" /> <call name="PrepMetaData"/> <lib-strcat string="$vm" string2="$sig-meta" out-string="$vm" /> <lib-strcat string="$vm" string2=".g711a" out-string="$vm" />
<store-getstat root="" name="NULL" out-wday="$wday" out-mday="$mday" out-mon="$mon" out-year="$year" out-hour="$hour" out-min="$min"/> <store-get root="$sub" name="Date_" out-url="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$year" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$mon" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$mday" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="_" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$hour" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="-" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$min" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="_VM_from_" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2="$cgpn" out-string="$vm-mail" /> <lib-strcat string="$vm-mail" string2=".g711a" out-string="$vm-mail" /> <pbx-mwi/>
As we have just defined the desired filename to be mailed out, we need to use this when mailing. So we'll still need to adjust email.xml in two places too.
replace (line 92-94)
<if cond="$vm"> <assign out="$file" value="$vm"/> </if>
with
<if cond="$vm"> <if cond="$vm-mail"> <store-ren root="" name="$vm" new-name="$vm-mail"/> <assign out="$file" value="$vm-mail"/> </if> <else> <assign out="$file" value="$vm"/> </else> </if>
This will change the current filename in database with the desired filename to be mailed out.
add the following code, just under the second mail-attempt (line 114 and further / just before the last </if>):
<if cond="$vm-mail"> <store-ren root="" name="$vm-mail" new-name="$vm"/> </if>
This will rename the filename in the database with the previous one containing the necessary meta data.
Leave Message to the VoiceMail Box of the original called User
By default the VoiceMail stores the voice message to the Mailbox of the Object performing diversion to the VoiceMail. E.g. if "User A" creates a call forward to the VoiceMail, the Mailbox is used to store the message is from "User A". In case "User A" creates a call forward to a Waiting Queue or Call Broadcast, and than from Call Broadcast Group to the VoiceMail, the message will be stored in the Mailbox of the Call Broadcast Group.
To change this behaviour and to store the Message always to the Mailbox of the originally called User, change the vm.xml as following:
search the line:
<pbx-getcallinfo out-cgpn="$cgpn" out-cdpn="$cdpn" out-leg2="$leg2"/>
and replace them with the following
<pbx-getcallinfo out-cgpn="$cgpn" out-cdpn="$cdpn" out-leg2="$leg2" out-leg2-orig="$leg3"/>
<switch var="$leg3">
  <case not-equal="">
    <assign out="$leg2" value="$leg3"/>
    <assign out="$_pbxcdpn" value="$leg3"/>
  </case>
</switch>
Sending of additional MWIs
A comma-separated list of MWI destinations/recipients can be configured by means of a variable $_m within the script URL's query string. The Group Voicemail article outlines a configuration scheme for this functionality.
Alternatively, the How To Send Additional MWIs within a PBX describes an older solution - not integrated within the Voicemail App.
Custom Personal Announcement
Explains where to copy an externally generated personal announcement file.
A Simple Recording Solution On-Top of The innovaphone Voicemail
This article explains how a simple recording solution could be set up on-top of an innovaphone Voicemail.
Send Email MWI Notification From The innovaphone Voicemail
This functionality is available from on SR2 and allows to send MWI notifications by email.
Enable Mailbox Administration from extern
Since build 60143 the administration menu was removed. It is possible to log in into the voicemail administration with a 9 as DTMF key while leaving a message. After entering the correct PIN, you can access the voicemail administration. This may create problems, if you use an unsecure PIN, no PIN or the default PIN.
To bring back this function you have to change the following code line inside the function AnsweringMachine in your vm.xml.
<if notcond="$greeting">
  <assign out="$greeting" value="box"/>
</if>
<switch var="$greeting">
to
<if notcond="$greeting">
  <assign out="$greeting" value="box"/>
</if>
<event type="dtmf" block="false">
  <pbx-getdtmfdigit out-dtmf="$dtmf" />
  <switch var="$dtmf">
    <case equal="9">
      <call name="Voicebox"/>
    </case>
  </switch>
</event>
<switch var="$greeting">
Quick Reference For innovaphone Voicemail
The article outlines the menu structure and provides a few operational hints from a user's perspective.
Special-Purpose Script Variables, Firmware Version 13r1
From on 13r1 a few script variables with special meaning were introduced. Among others, this enables a script to read the static configuration underneath PBX/Config/Authentication/Email Verification.
- $_pbx_auth_email_server
Retrieves PBX/Config/Authentication/Email Verification/SMTP server
- $_pbx_auth_email_host
Retrieves PBX/Config/Authentication/Email Verification/Client host name
- $_pbx_auth_email_addr
Retrieves PBX/Config/Authentication/Email Verification/Email address
- $_pbx_auth_email_usr
Retrieves PBX/Config/Authentication/Email Verification/Username
- $_pbx_auth_email_pwd
Retrieves PBX/Config/Authentication/Email Verification/Password
- $_pbx_auth_email_sender
Retrieves PBX/Config/Authentication/Email Verification/Sender name
- $_pbx_version_soap
Retrieves the firmware version. E.g. "1300" for 13r1.
Known Problems
The VM makes use of V6’s media negotiation capabilities. This is why V5 endpoints are not supported.
- Support:Voicemail Calls Hanging Around In PBX Call Monitor
- Support: Voicemail: Voicebox Not Configurable With "Send Number" set
- When the voicebox is created upon the first call to the users voicemail, you must not have the Send Number property configured in the calling user object. Otherwise, the voicebox will be created for the wrong number
- Support:Voicemail Fails With "Missing Voicemail License!"
- Support:Voicemail Fails With "Authentication Required"
- Support:Webdav Access Slow From Windows 7 /Vista
- You can not have a voice mailbox for users that have a slash (/) in the Long Name. For such user, when calling the voice mail, a spoken error message an error occured is heard- de: es ist leider ein Fehler aufgetreten
 
- If the voicemail URL is a webdav server on a LinuxAP, the dns domain name of the URL must be typed in lower cases, otherwise changes to the welcome and personal message (name_greetings and personal_greetings) won't be correctly saved.
- If the voicemail is located on a webdav server on a LinuxAP make sure the folder of the voicemail has for group and owner "www-data" and not "root". Otherwise you cannot create user folders.
- Forking to a VM Object without mobility object (license required) will display the name of the forking target in the caller display and his calllist. (To prevent this behaviour, use a mobility object for the forking to doorcall-trigger)
Related Articles
Voicemail Installation
- Howto:How to setup an V6 IP Phone for innovaphone voicemail usage
- Howto:Send Email MWI Notification From The innovaphone Voicemail
- Howto:Quick Reference For innovaphone Voicemail
- Howto:Forward your Mobile's Mailbox to your innovaphone Voicemail
- Howto:MWI for DECT
Voicemail on Compact Flash
- Howto:General information for compact flash cards
- Howto:Installing the voicemail/music on hold on a compact flash card
Voicemail Customising
- Howto:Deploy A Custom Personal Announcement For the innovaphone Voicemail
- Howto:Does innovaphone voicemail support multiple announcements?
- Howto:How To Send Additional MWIs within a PBX
- Howto:Send Email from the innovaphone Voicemail without saving data on the CF
- Howto:Localize Voice Mail Messages
Voicemail Scripting
- Howto:Wiki_Sources
- Howto:Implement a simple caller notification
- Howto:Getting started with your own PBX voicemail script
- Howto:Debug_your_own_PBX_voicemail_script
- Howto:A Simple Recording Solution On-Top of The innovaphone Voicemail
- Howto:Voicemail Scripting And Projektcode, PIN, Auth Code
- Howto:Simple ACD with Voicemail XML Script
- Howto:Control Call Forward with Voicemail XML Script
- Howto:Using the Voicemail object as a post call review
- Howto:Voice_Mail_multiple_announcements_with_and_without_possibility_to_leave_a_message
- Howto:Speaking_Clock_with_Voicemail_XML_Script
- Howto:Absence_Memo_with_VoiceMail_XML_Script
Download
The voicemail product can currently be found on the apps section of the innovaphone download site. This product is suitable for PBX firmware versions 6 and up.
