Howto:Send Email MWI Notification From The innovaphone Voicemail: Difference between revisions
| m updated | |||
| (30 intermediate revisions by 10 users not shown) | |||
| Line 1: | Line 1: | ||
| =Applies To= | |||
| This information applies to | This information applies to | ||
| '''Note:  | '''Note: The required Voicemail  is not suitable for V6 SR1 environments'''. | ||
| * innovaphone PBX,  | * innovaphone PBX, V6 SR2 | ||
| * innovaphone Voicemail, Build 07- | * innovaphone Voicemail, Build 07-60049 | ||
| =More Information= | |||
| Email notifications about newly received voicemails can be sent towards the owner of a voicebox. | Email notifications about newly received voicemails can be sent towards the owner of a voicebox. | ||
| The mechanism is not reliable, because there is no spooling implemented. Currently, there will be one transmission attempt per email. | The mechanism is not reliable, because there is no spooling implemented. Currently, there will be one transmission attempt per email. | ||
| Line 14: | Line 13: | ||
| The destination email address can be taken from a file, that is to be located within the ''../personal'' directory of a voicebox. Alternatively may the email address be configured into a user's URL parameter within the corresping PBX object. | The destination email address can be taken from a file, that is to be located within the ''../personal'' directory of a voicebox. Alternatively may the email address be configured into a user's URL parameter within the corresping PBX object. | ||
| Such an email consists of a subject "You have received a new voicemail from: xxx", where ''xxx'' stands for the number of the calling party. There is  | Such an email consists of a subject "You have received a new voicemail from: xxx", where ''xxx'' stands for the number of the calling party. There is additional [[#Send Voicemail As Email Attachment|functionality]] available to attach a voicemail as a wave file (a-law, u-law encoded) to an email. | ||
| The email will be sent by means of the Simple Mail Transfer Protocol (SMTP). | The email will be sent by means of the Simple Mail Transfer Protocol (SMTP). The protocols SMTPS/SMTP over TLS/STARTTLS are supported since v13r1. | ||
| As SMTP Authentication mechanisms are supported (as of the writing of this arcticle): PLAIN, LOGIN and CRAM-MD5 | As SMTP Authentication mechanisms are supported (as of the writing of this arcticle): PLAIN, LOGIN and CRAM-MD5 | ||
| ==Installation== | |||
| Install the above mentioned  | * Install the above mentioned VoiceMail build or later as usual. | ||
| *  | * In the VoiceMail folder where vm.xml is placed you will find ''email.xml''. This file contains the SMTP configuration and must be edited to adjust it to your needs. | ||
| * Ensure that the IP configuration (Default Gateway, DNS server) is appropriate. | * Ensure that the IP configuration (Default Gateway, DNS server) is appropriate. | ||
| ==Provisioning Of Destination Email Addresses== | |||
| Email addresses must be configured manually. The script file email.xml firstly looks into a user's URL parameter and then  | Email addresses must be configured manually. The script file email.xml firstly looks into a user's E-Mail parameter (only on the first configured E-Mail). If no value found in the E-Mail parameter, the user's URL parameter is used at second place and then the user's personal file mail.txt, in order to find an email destination. Since the URL parameter may be used in other contexts, the script ensures that a non-empty URL parameter contains the '@' character as an indication that it deals with an email address. | ||
| ===By E-Mail Parameter=== | |||
| The email address can be taken from  | The email address can be taken from a user's E-Mail parameter. | ||
| Provisioning of a user's email address by  | Provisioning of a user's email address by [[Reference10:PBX/Objects|E-Mail parameter]] | ||
| *  | * Proceed to ''PBX/Objects''. | ||
| * Enter the  | * Open the desired Object GUI by clicking on it. | ||
| * Enter the email address into the ''E-Mail'' edit field. The email address may be entered raw as e.g. ''pbxuser@mycompany.com''.   | |||
| Repeat these steps for each voicebox. | Repeat these steps for each voicebox. | ||
| ===By URL Parameter=== | |||
| The email address can be taken from a user's URL parameter. | The email address can be taken from a user's URL parameter. | ||
| Line 47: | Line 45: | ||
| Repeat these steps for each voicebox. | Repeat these steps for each voicebox. | ||
| ===Configure the SMTP Agent=== | ===By File=== | ||
| The email address can be taken from the mass storage. | |||
| The destination email address can be written into a file. | |||
| Provisioning of a user's email address by file | |||
| * Within a text editor open up a new file. | |||
| * Enter the user's email address, e.g.: ''pbxuser@mycompany.com'' | |||
| * Save the file as ''...yyy/personal/mail.txt'', where ''yyy'' stands for the directory name of the user's voicebox. | |||
| Repeat these steps for each voicebox. | |||
| ==Configure the SMTP Agent, Firmware Version 13r1== | |||
| {{v13_vm_email_script_variables}} | |||
| ==Configure the SMTP Agent== | |||
| By default the email will be sent with the sender- and destination- email address being identical. In addition will the email be sent alike a Mail Transfer Agent (MTA) does. | By default the email will be sent with the sender- and destination- email address being identical. In addition will the email be sent alike a Mail Transfer Agent (MTA) does. | ||
| Line 64: | Line 75: | ||
|      <assign out="$from" value="voicemail@mycompany.com"/> |      <assign out="$from" value="voicemail@mycompany.com"/> | ||
| </pre> | </pre> | ||
| PLEASE NOTE (obsolete with V11) : if your smtp server requires authorization, you will also need to edit the following line at the end of the email.xml file: | |||
| <pre> | |||
| <exec url="mailto:$to?from=$to&subject=$subject&subject=$cgpn&srv=$server&usr=$user&pwd=$password&file=$file"/> | |||
| </pre> | |||
| to | |||
| <pre> | |||
| <exec url="mailto:$to?from=$from&amp;subject=$subject&amp;subject=$cgpn&amp;srv=$server&amp;usr=$user&amp;pwd=$password&amp;file=$file"/> | |||
| </pre> | |||
| otherwise sender address and authorization credentials won't match and you will get an "authorization failed" error | |||
| MTA-to-MTA communication may fail, depending on policies implemented within the receiving MTA. Therefore, it is desirable to turn our sending MTA into a simple MUA. That is, emails are to be sent via an SMTP provider server. Such a server is often termed as an ''Outgoing SMTP Server''. | MTA-to-MTA communication may fail, depending on policies implemented within the receiving MTA. Therefore, it is desirable to turn our sending MTA into a simple MUA. That is, emails are to be sent via an SMTP provider server. Such a server is often termed as an ''Outgoing SMTP Server''. | ||
| Line 81: | Line 102: | ||
|      <assign out="$password" value="mypassword"/> |      <assign out="$password" value="mypassword"/> | ||
| </pre> | </pre> | ||
| Note : the server value can be also with port configured like this : ''smtpserver.myprovider.com:port'' | |||
| === mailto: URL Query Arguments === | |||
| The SMTP agent is configured using query args.  The following args are recognized | |||
| ==== MS Exchange 2003 | ; from : sets the senders's email address.  Must be a valid email address thus.  E.g. <code>?from=user@company.tld</code> | ||
| ; subject : sets the email's subject.  The values of multiple occurrences of the ''subject'' query arg will be concatenated.  E.g. <code>?subject=foo&subject=bar</code> yield ''foobar'' as subject. Empty by default. | |||
| ; body : sets the email's body.  The values of multiple occurrences of the ''body'' query arg will be concatenated.  E.g. <code>?body=foo&body=bar</code> yield ''foobar'' as body. Empty by default. | |||
| ; srv : sets the SMTP server address (that is, the address of the SMTP server the mail is sent to).  Must be either an IP address or a DNS name.  Empty by default. If you need another port than 25, just add :<portnr> at then end of to the srv | |||
| ; usr : sets the user name to be used for authentication towards the SMTP server.  Empty by default. | |||
| ; pwd : sets the password to be used for authentication towards the SMTP server.  Empty by default. | |||
| ; fromname : sets the sender's display name.  ''Voicemail'' by default. | |||
| ; toname : sets the recipients's display name.  ''Voicemail User'' by default. | |||
| ; host : sets the local SMTP name (used in SMTP HELO or ELOH command).  ''[127.0.0.1]'' by default. | |||
| Please note that the mailto: URL in email.xml must be noted as valid XML code.  Special characters (most notably the ampersand ''&'') must be quoted thus, e.g. <code>?subject=foo&amp;subject=bar</code> | |||
| === MS Exchange 2003=== | |||
| An in-house test yielded the following approach, allowing to talk to the Exchange 2003 MTA-wise. | An in-house test yielded the following approach, allowing to talk to the Exchange 2003 MTA-wise. | ||
| The file email.xml was left as-is, except the following line has been set to the dotted decimal IP address of the exchange machine. | The file email.xml was left as-is, except the following line has been set to the dotted decimal IP address of the exchange machine. | ||
| <pre> | <pre> | ||
|      <assign out="$server" value="172.16.0.4"/> |      <assign out="$server" value="172.16.0.4"/> | ||
| </pre> | |||
| or when you smtp server is listening on port 2525 instead of 25 | |||
| <pre> | |||
|     <assign out="$server" value="172.16.0.4:2525"/> | |||
| </pre> | </pre> | ||
| This allowed an intranet PBX to send emails to Exchange users, where the source- destination email address were identical. | This allowed an intranet PBX to send emails to Exchange users, where the source- destination email address were identical. | ||
| ==Send Voicemail As Email Attachment== | |||
| Emails won't carry a voicemail attachment by default. The file email.xml can be edited, in order to send voicemails as wave files together with the notification email. | Emails won't carry a voicemail attachment by default. The file email.xml can be edited, in order to send voicemails as wave files together with the notification email. | ||
| Open up the file email.xml within a text editor, modify the line | Open up the file email.xml within a text editor, modify the line | ||
|  <assign out="$file" value=""/> | |||
| into | into | ||
|  <assign out="$file" value="$vm"/> | |||
| The wave files will inform about themselves as to contain a-law-, respectively u-law content. | The wave files will inform about themselves as to contain a-law-, respectively u-law content. | ||
| From on Windows XP SP2 the Mediaplayer will contain the required codecs. | From on Windows XP SP2 the Mediaplayer will contain the required codecs. | ||
| ==Testing== | |||
| * Call a user with a CFU into his/her voicebox. | * Call a user with a CFU into his/her voicebox. | ||
| * Leave a voicemail, tear down (on-hook) the call. | * Leave a voicemail, tear down (on-hook) the call. | ||
| * The owner of the voicebox should now have received an email. | * The owner of the voicebox should now have received an email. | ||
| ==Troubleshooting== | |||
| Before contacting the support, you are asked to create a trace file covering the transmission attempt for an email. | Before contacting the support, you are asked to create a trace file covering the transmission attempt for an email. | ||
| Line 127: | Line 167: | ||
| Activate the trace checkmark at the affected voicemail object. In addition should the voicemail object's trace flags be set to the value ''59'' alike: ''http://192.168.0.1/drive/CF0/vm.xml?$_trace=59''. | Activate the trace checkmark at the affected voicemail object. In addition should the voicemail object's trace flags be set to the value ''59'' alike: ''http://192.168.0.1/drive/CF0/vm.xml?$_trace=59''. | ||
| <!--  | <!--  voice mail --> | ||
| [[Category:Howto|{{PAGENAME}}]] | [[Category:Howto|{{PAGENAME}}]] | ||
Latest revision as of 15:36, 1 April 2025
Applies To
This information applies to
Note: The required Voicemail is not suitable for V6 SR1 environments.
- innovaphone PBX, V6 SR2
- innovaphone Voicemail, Build 07-60049
More Information
Email notifications about newly received voicemails can be sent towards the owner of a voicebox. The mechanism is not reliable, because there is no spooling implemented. Currently, there will be one transmission attempt per email.
The destination email address can be taken from a file, that is to be located within the ../personal directory of a voicebox. Alternatively may the email address be configured into a user's URL parameter within the corresping PBX object.
Such an email consists of a subject "You have received a new voicemail from: xxx", where xxx stands for the number of the calling party. There is additional functionality available to attach a voicemail as a wave file (a-law, u-law encoded) to an email.
The email will be sent by means of the Simple Mail Transfer Protocol (SMTP). The protocols SMTPS/SMTP over TLS/STARTTLS are supported since v13r1.
As SMTP Authentication mechanisms are supported (as of the writing of this arcticle): PLAIN, LOGIN and CRAM-MD5
Installation
- Install the above mentioned VoiceMail build or later as usual.
- In the VoiceMail folder where vm.xml is placed you will find email.xml. This file contains the SMTP configuration and must be edited to adjust it to your needs.
- Ensure that the IP configuration (Default Gateway, DNS server) is appropriate.
Provisioning Of Destination Email Addresses
Email addresses must be configured manually. The script file email.xml firstly looks into a user's E-Mail parameter (only on the first configured E-Mail). If no value found in the E-Mail parameter, the user's URL parameter is used at second place and then the user's personal file mail.txt, in order to find an email destination. Since the URL parameter may be used in other contexts, the script ensures that a non-empty URL parameter contains the '@' character as an indication that it deals with an email address.
By E-Mail Parameter
The email address can be taken from a user's E-Mail parameter.
Provisioning of a user's email address by E-Mail parameter
- Proceed to PBX/Objects.
- Open the desired Object GUI by clicking on it.
- Enter the email address into the E-Mail edit field. The email address may be entered raw as e.g. pbxuser@mycompany.com.
Repeat these steps for each voicebox.
By URL Parameter
The email address can be taken from a user's URL parameter.
Provisioning of a user's email address by URL parameter
- Proceed to Administration/PBX/Objects.
- Open the desired Object GUI by clicking on it.
- Enter the email address into the URL edit field. The email address may be entered raw as e.g. pbxuser@mycompany.com or as mailto-URL alike e.g. mailto:pbxuser@mycompany.com.
Repeat these steps for each voicebox.
By File
The email address can be taken from the mass storage. The destination email address can be written into a file.
Provisioning of a user's email address by file
- Within a text editor open up a new file.
- Enter the user's email address, e.g.: pbxuser@mycompany.com
- Save the file as ...yyy/personal/mail.txt, where yyy stands for the directory name of the user's voicebox.
Repeat these steps for each voicebox.
Configure the SMTP Agent, Firmware Version 13r1
As of 13r1, scripts that use email functionality (such as email.xml) do not need to include a definition of SMTP connection parameters. The static configuration data from PBX/Config/Authentication/Email Verification can be read in for this purpose.
The following script variables will yield those email settings when read.
- $_pbx_auth_email_server
SMTP server
- $_pbx_auth_email_host
Client host name
- $_pbx_auth_email_addr
Sender Email address
- $_pbx_auth_email_usr
Username for authentication
- $_pbx_auth_email_pwd
Password for authentication
- $_pbx_auth_email_sender
Sender name
Configure the SMTP Agent
By default the email will be sent with the sender- and destination- email address being identical. In addition will the email be sent alike a Mail Transfer Agent (MTA) does.
You can configure the content of the above mentioned file email.xml, in order to provide a different sender email address.
You can also control that emails are to be sent alike a Mail User Agent (MUA) does, or in other words: alike a regular email SMTP client does.
Open up the file email.xml within a text editor.
- In order to modify the sender email address, modify the line
<assign out="$from" value="$to"/>
into e.g.
<assign out="$from" value="voicemail@mycompany.com"/>
PLEASE NOTE (obsolete with V11) : if your smtp server requires authorization, you will also need to edit the following line at the end of the email.xml file:
<exec url="mailto:$to?from=$to&subject=$subject&subject=$cgpn&srv=$server&usr=$user&pwd=$password&file=$file"/>
to
<exec url="mailto:$to?from=$from&subject=$subject&subject=$cgpn&srv=$server&usr=$user&pwd=$password&file=$file"/>
otherwise sender address and authorization credentials won't match and you will get an "authorization failed" error
MTA-to-MTA communication may fail, depending on policies implemented within the receiving MTA. Therefore, it is desirable to turn our sending MTA into a simple MUA. That is, emails are to be sent via an SMTP provider server. Such a server is often termed as an Outgoing SMTP Server.
Open up the file email.xml within a text editor.
To configure an outgoing SMTP server, modify the lines
    <assign out="$server" value=""/>
    <assign out="$user" value=""/>
    <assign out="$password" value=""/>
into e.g.
    <assign out="$server" value="smtpserver.myprovider.com"/>
    <assign out="$user" value="myuser"/>
    <assign out="$password" value="mypassword"/>
Note : the server value can be also with port configured like this : smtpserver.myprovider.com:port
mailto: URL Query Arguments
The SMTP agent is configured using query args. The following args are recognized
- from
- sets the senders's email address.  Must be a valid email address thus.  E.g. ?from=user@company.tld
- subject
- sets the email's subject.  The values of multiple occurrences of the subject query arg will be concatenated.  E.g. ?subject=foo&subject=baryield foobar as subject. Empty by default.
- body
- sets the email's body.  The values of multiple occurrences of the body query arg will be concatenated.  E.g. ?body=foo&body=baryield foobar as body. Empty by default.
- srv
- sets the SMTP server address (that is, the address of the SMTP server the mail is sent to). Must be either an IP address or a DNS name. Empty by default. If you need another port than 25, just add :<portnr> at then end of to the srv
- usr
- sets the user name to be used for authentication towards the SMTP server. Empty by default.
- pwd
- sets the password to be used for authentication towards the SMTP server. Empty by default.
- fromname
- sets the sender's display name. Voicemail by default.
- toname
- sets the recipients's display name. Voicemail User by default.
- host
- sets the local SMTP name (used in SMTP HELO or ELOH command). [127.0.0.1] by default.
Please note that the mailto: URL in email.xml must be noted as valid XML code.  Special characters (most notably the ampersand &) must be quoted thus, e.g. ?subject=foo&subject=bar
MS Exchange 2003
An in-house test yielded the following approach, allowing to talk to the Exchange 2003 MTA-wise. The file email.xml was left as-is, except the following line has been set to the dotted decimal IP address of the exchange machine.
<assign out="$server" value="172.16.0.4"/>
or when you smtp server is listening on port 2525 instead of 25
<assign out="$server" value="172.16.0.4:2525"/>
This allowed an intranet PBX to send emails to Exchange users, where the source- destination email address were identical.
Send Voicemail As Email Attachment
Emails won't carry a voicemail attachment by default. The file email.xml can be edited, in order to send voicemails as wave files together with the notification email.
Open up the file email.xml within a text editor, modify the line
<assign out="$file" value=""/>
into
<assign out="$file" value="$vm"/>
The wave files will inform about themselves as to contain a-law-, respectively u-law content.
From on Windows XP SP2 the Mediaplayer will contain the required codecs.
Testing
- Call a user with a CFU into his/her voicebox.
- Leave a voicemail, tear down (on-hook) the call.
- The owner of the voicebox should now have received an email.
Troubleshooting
Before contacting the support, you are asked to create a trace file covering the transmission attempt for an email.
The following lines in the configuration must be changed manually, from:
config change DNS0 config change SMTP0
into
config change DNS0 /trace config change SMTP0 /trace
Activate the trace checkmark at the affected voicemail object. In addition should the voicemail object's trace flags be set to the value 59 alike: http://192.168.0.1/drive/CF0/vm.xml?$_trace=59.