The document discusses Diafaan SMS Server and how to configure gateways and connectors to send and receive SMS messages.
Gateways are used to connect to SMS providers and send/receive SMS, while connectors are used to integrate with other systems to send/receive messages.
Gateways that can be added include GSM Modem, Clickatell, SMPP, Paging, Scripting, and Hypermedia SMS PRO.
2009-2014 Diafaan communication software
Diafaan SMS Server 2.1.5
Manual Diafaan SMS Server 2.1.5 Manual 2 2009-2014 Diafaan communication software Table of Contents Part I Welcome to Diafaan SMS Server 5 Part II Getting started 7 ................................................................................................................................... 10 1 Gateways and connectors ................................................................................................................................... 12 2 Add a gateway .......................................................................................................................................................... 14 Add a GSM Modem gateway .......................................................................................................................................................... 16 Add a Clickatell gateway .......................................................................................................................................................... 17 Add an SMPP gateway .......................................................................................................................................................... 18 Add a Paging Gateway .......................................................................................................................................................... 21 Add a Scripting gateway .......................................................................................................................................................... 22 Add a Hypermedia SMS PRO gateway ................................................................................................................................... 23 3 Add a connector .......................................................................................................................................................... 25 Add a Web connector .......................................................................................................................................................... 27 Add an Email connector .......................................................................................................................................................... 29 Add an SQL connector .......................................................................................................................................................... 32 Add a Scripting connector Part III How to... 34 ................................................................................................................................... 34 1 Route messages ................................................................................................................................... 37 2 Use message types ................................................................................................................................... 39 3 Use number templates ................................................................................................................................... 40 4 Use HTTP callbacks ................................................................................................................................... 44 5 Send pictures and ringtones ................................................................................................................................... 46 6 Connect to Microsoft Exchange Server ................................................................................................................................... 52 7 Access your database .......................................................................................................................................................... 57 Microsoft SQL Server (Express) .......................................................................................................................................................... 59 MySQL database .......................................................................................................................................................... 62 Oracle database .......................................................................................................................................................... 65 Microsoft Access .......................................................................................................................................................... 68 PostgreSQL database ................................................................................................................................... 71 8 Scripting examples .......................................................................................................................................................... 71 Gateway scripting examples ......................................................................................................................................................... 71 BulkSMS.com script ......................................................................................................................................................... 71 Dispatch SMS to gateways ......................................................................................................................................................... 72 Send messages to e-mail .......................................................................................................................................................... 75 Connector scripting examples ......................................................................................................................................................... 75 Auto reply SMS messages Part IV Reference 78 ................................................................................................................................... 78 1 General options ................................................................................................................................... 83 2 Gateway properties .......................................................................................................................................................... 84 GSM Modem gateway 3 Contents 3 2009-2014 Diafaan communication software .......................................................................................................................................................... 89 Clickatell gateway .......................................................................................................................................................... 91 SMPP gateway .......................................................................................................................................................... 96 Paging gateway .......................................................................................................................................................... 99 Scripting gateway .......................................................................................................................................................... 101 Hypermedia SMS PRO gateway ................................................................................................................................... 104 3 Connector properties .......................................................................................................................................................... 106 Web connector ......................................................................................................................................................... 111 HTTP API specifications ......................................................................................................................................................... 113 Commandline client .......................................................................................................................................................... 116 Email connector .......................................................................................................................................................... 121 SQL connector .......................................................................................................................................................... 125 Scripting connector Index 127 I Welcome to Diafaan SMS Server Welcome to Diafaan SMS Server 5 2009-2014 Diafaan communication software 1 Welcome to Diafaan SMS Server Diafaan SMS Server makes it easy to send and receive SMS text messages from and to a web server, email, SQL database or C#/Visual Basic .NET script. Simply attach a GSM modem to your PC/server or set up a connection to an online SMS- or paging operator, use a wizard to add the SMS gateway and connections to the database, web server or email and your SMS gateway is ready for use. Getting started Study Getting started to familiarize yourself with the basics of the program. Check out the How to pages for scripting examples and instructions for specific database software like Microsoft SQL Server (Express), MySQL, Oracle, PostgreSQL or Microsoft Access. Advanced features Get an overview of all available Gateway and Connector features in the Reference section. See how to integrate with web applications using the HTTP API specifications. Send messages from the Windows command line with the Commandline client. II Getting started Getting started 7 2009-2014 Diafaan communication software 2 Getting started After installing Diafaan SMS Server and starting up the program for the first time the installation wizard enables you to add an SMS gateway and the default HTTP web interface. You can create additional SMS gateways and Connectors later. Enter the administrator password The installation wizard asks for a password of the administrator (admin) account. This password is required to log in to the web application of Diafaan SMS Server. Add a GSM Modem Gateway Click Search to get a list of all installed GSM modems. Select the GSM modem from the list. If the SIM card needs a PIN code, enter it in the PIN code field. Click Test to test the GSM modem and retrieve all information necessary to send and receive SMS messages with the modem. If required enter the GSM number and SMSC number of the SIM card. or Add an SMPP Gateway Enter the SMPP host name or IP number, SMPP server port, user name and password. Click Test to test the connection to the SMPP server or Add a Clickatell Gateway Diafaan SMS Server 2.1.5 Manual 8 2009-2014 Diafaan communication software Create a Clickatell HTTP account on the Clickatell website. Enter the Clickatell HTTP API id, user name and password. Click Test to test the connection to Clickatell Send your first message Start a web browser and use the web application on http://localhost:9710/ to log in to Diafaan SMS Server. Log in to Diafaan SMS Server with the user name admin and the password you entered in the setup wizard. In the To field you can enter multiple mobile numbers, separated by comma's. Important! It is good practice to enter all mobile numbers in Diafaan SMS Server in international number format, starting with a '+'. Not all mobile operators accept numbers in other formats. Short numbers or other special numbers can be prefixed with a '#' (national address type) or an '*' (unknown address type). Getting started 9 2009-2014 Diafaan communication software Diafaan SMS Server 2.1.5 Manual 10 2009-2014 Diafaan communication software 2.1 Gateways and connectors Gateways Diafaan SMS Server uses gateways to interface with SMS and other messaging services. The following gateways are supported: All editions: GSM Modem gateway Diafaan SMS Server can use GSM modems and SIM boxes to send and receive SMS messages. This includes a broad range of devices like the Sierra Wireless Fastrack, Cinterion, Wavecom, Siemens, Nokia, Huawei or Option GSM modems and a large number of normal GSM phones. Clickatell gateway Clickatell is a world leading communication provider specializing in bulk messaging services and SMS gateway connectivity. Diafaan SMS Server makes use of the Clickatell HTTP interface to send SMS messages. Basic- and full editions only SMPP gateway SMPP is a high performance two-way SMS protocol that is supported by a large number of online SMS providers. Use the SMPP Gateway to send and receive SMS messages with an SMS operator over an Internet connection. The SMPP Gateway supports SMPP version 3.3 or 3.4. Paging gateway Send messages to pagers and GSM phones with an analog or ISDN modem or an Internet connection. The Paging Gateway supports the IXO/TAP and UCP 01 protocols over a modem connection and the SNPP, SMTP (email), WCTP and UCP 01 protocols over an Internet connection. Scripting gateway Use the scripting gateway to send and receive messages to messaging services like email, SMS or internet services. The scripting gateway is also used to change the recipient, message text etc. and to dispatch the message to a different gateway. The scripting gateway supports scripts in C# and Visual Basic .NET. Hypermedia SMS PRO gateway Send and receive SMS messages with the Hypermedia HG-7000. The Hypermedia HG-7000 SMS PRO gateway is a professional multi-port wireless SMS gateway device with support for 4 - 32 GSM modem modules. Connectors Connectors are used to connect Diafaan SMS Server with other software. This can be a database, email system, web server and more. The following connectors are supported: Web connector The Web connector uses a built-in web server to send SMS messages and query the status of previously sent messages. The web connector can also be used to post received messages to webpages. It has a built-in web application to make sending and receiving SMS messages very easy. Email connector Getting started 11 2009-2014 Diafaan communication software Email is converted into SMS messages with a built-in SMTP server or with a connection to an external POP server. The email connector can also forward SMS messages to an email address. SQL connector The SQL connector provides the connection to the database you want to use. It supports three database tables, one for messages to send (MessageOut), one to store received messages (MessageIn) and a table to log sent or failed calls (MessageLog). Scripting connector Use a script to send SMS messages and process received messages. A simple script might send an SMS response to a received SMS message. The scripting connector supports scripts in C# and Visual Basic .NET. Diafaan SMS Server 2.1.5 Manual 12 2009-2014 Diafaan communication software 2.2 Add a gateway Add gateway wizard Start the Add gateway wizard and select the gateway type. If the Add gateway option is not available in the Actions list, you have to remove one or more gateways first. Select one of the available gateway GSM Modem gateway Clickatell gateway SMPP gateway (basic and full editions only) Paging gateway (basic and full editions only) Scripting gateway (basic and full editions only) Assign the connectors If you have installed more than one connector you can select the connectors you want to use with the new gateway. Getting started 13 2009-2014 Diafaan communication software Diafaan SMS Server 2.1.5 Manual 14 2009-2014 Diafaan communication software 2.2.1 Add a GSM Modem gateway Prepare the SIM card It is strongly advised to remove the PIN code from the SIM card before you use it with the GSM modem. You can enter the PIN code in Diafaan SMS Server and it will use this before logging on to the GSM network. However, if you provide the wrong PIN code to the software or change the SIM card afterwards the SMS software might repeatedly try to enter the wrong PIN code, resulting in a blocked SIM card. When this happens you need to reset the SIM card on a GSM phone using the PUC (Personal Unblocking Code, also known as PUK) you got with the SIM card. Search modem Click on the Search button to find all the GSM modems attached to the PC. If you already know the serial port where your GSM modem is connected you can skip this step, just select the serial port and click on the Test button to test the GSM modem. TCP/IP modems The GSM Modem Gateway can directly use GSM modems connected over an Internet TCP/IP connection, without the need for additional drivers. The GSM Modem Gateway cannot find TCP/IP modems automatically, to add the modem manually select TCP/IP from the GSM modem port list and enter the host name or IP number and the attached port number. The GSM Modem Gateway can use a raw TCP/IP connection or a Telnet connection to the modem. Test the GSM modem Before going to the next wizard page you have to click the Test button to test the GSM modem. The wizard will query the GSM Modem to find the SMSC number, the GSM number and check if a PIN code is required. If one of this numbers is not found you can enter them manually. Advanced options Sometimes it is necessary to change an advanced parameter in order to get the GSM Modem to work. Getting started 15 2009-2014 Diafaan communication software You can do this later in the GSM Modem Gateway Properties dialog box. If the GSM modem is not found you can still add the GSM Modem gateway by finishing the wizard. Diafaan SMS Server 2.1.5 Manual 16 2009-2014 Diafaan communication software 2.2.2 Add a Clickatell gateway Get a Clickatell HTTP API id After creating a Clickatell account on the Clickatell website you also have to add an HTTP connection to the Clickatell account. You end up with an HTTP API ID, user name and password that must be used in the wizard page. Sender Id's After you set up the Clickatell account and sent your first messages you will notice that the sender id of the messages is a +44xxxxxxxx number. Clickatell supports using your own numeric or alphanumeric sender id, but to prevent id spoofing you have to register the sender id list before you can use them. Log in to Clickatell Central and select My Settings and Manage Sender IDs. Here you can add and delete ids to your sender id list. Since the ids are approved manually it can take some time before you can use them. You may use existing mobile phone numbers as the sender id if you want the replies to go to your mobile phone. In the Clickatell Gateway Properties you must add the approved sender ID list. On the Advanced tab page click on the ApprovedFromList button and fill in the sender id list, one sender id on each line. You can also specify the DefaultFrom value, this sender id will be used if the sender has not specified the sender id or if that sender id is not in the approved list. Getting started 17 2009-2014 Diafaan communication software 2.2.3 Add an SMPP gateway Only available in Diafaan SMS Server - basic and full editions. SMPP is a high performance SMS protocol that is supported by a large amount of online SMS providers, SMPP stands for Short Message Peer to Peer protocol. In the SMPP server setup wizard you can enter the account information supplied by your SMS provider. Source address Some SMPP operators require that you send a source address or sender id with each message. The default source address will be used for each message where the user does not provide a source address. If the SMPP operator only allows a limited number of valid source addresses it is possible to disable user specific source addresses or to add a list of valid source addresses in the advanced settings. Performance After initial installation, the SMPP gateway uses a conservative setting that is compatible with most SMPP servers. If your SMS provider supports advanced features like asynchronous (windowed) operation enabling the AsyncModeWindowSize option in the advanced settings can increase the sending speed considerably. Diafaan SMS Server 2.1.5 Manual 18 2009-2014 Diafaan communication software 2.2.4 Add a Paging Gateway Only available in Diafaan SMS Server - basic and full editions. With Diafaan SMS Server you can send messages to pagers and GSM phones with an analog or ISDN modem or an Internet connection. The Paging Gateway supports the IXO/TAP and UCP 01 protocols over a modem connection and the SNPP, SMTP (email), WCTP and UCP 01 protocols over an Internet connection. Multiple services Each Paging Gateway can contain multiple paging or SMS services, you can add new services to the Paging Gateway in the Paging Gateway Properties. Services that use the same modem port must be grouped in one Paging Gateway, other services can also be combined in the same Paging Gateway but this is not necessary. Find the service settings Before you set up the connection to the paging service you have to find the proper settings for the service you want to add. You can get the proper settings from your paging company or mobile operator. Supported protocols Protocol Connection Description IXO/TAP Modem IXO/TAP is an industry standard and is the predominant communications protocol for paging over a modem connection in the US, Canada, South America, Australia, and the majority of Europe. UCP 01 Modem and Internet Universal Computer Protocol (UCP), is a protocol primarily used to connect to short message service centres (SMSCs) for mobile telephones. SNPP Internet Simple Network Paging Protocol (SNPP) is a protocol that defines a method by which a pager can receive a message over the Internet SMTP (email) Internet Email is a widely used method to send messages to pagers and mobile phone. Since the email system is not time sensitive it is not ideal for use with urgent paging or SMS messages. The SMTP service can also be used to send messages to normal email users. WCTP Internet Wireless Communication Transfer Protocol (WCTP) is a protocol that supports sending messages to pagers and mobile phones over a plain (http://)or secured (https://) HTTP connection. Add a modem service Getting started 19 2009-2014 Diafaan communication software To add a new Paging Gateway with a modem dial-in service just provide the correct protocol, phone number of the service, an optional password and the modem properties. Then click on the Test button to send a test message to the service and see if the settings you entered are correct. Modem settings Most TAP services use a connection with 7 data bits, 1 stop bit and even parity. Most UCP services use a connection with 8 data bits, 1 stop bit and no parity. If the connection to the pager service does not work and additional modem settings are required to set up the connection, you can change them later in the Paging Gateway Properties. Character set Most paging services will accept basic ASCII characters only, for those services you can choose Alphanumeric Paging as the character set. Numeric Paging can be used if you want the service to send messages to numeric pagers only. Some SMS dial-in services accept the full SMS Default Alphabet, if you are unsure if your SMS service uses the SMS Default Alphabet, you can test this by sending an email address to the pager or mobile phone. If the "@" character is shown correctly on the pager or mobile phone you chose the right character set. In the Paging Gateway Properties you can specify additional character sets for some protocols. Add an Internet service Diafaan SMS Server 2.1.5 Manual 20 2009-2014 Diafaan communication software To add a new Paging Gateway with an Internet service just provide the correct protocol, host name or URL of the service and an optional user id and password. Then click on the Test button to send a test message to the service and see if the settings you entered are correct. If the connection to the pager service does not work and additional settings are required to set up the connection, you can change them later in the Paging Gateway Properties. Getting started 21 2009-2014 Diafaan communication software 2.2.5 Add a Scripting gateway Only available in Diafaan SMS Server - basic and full editions. Select scripting language Diafaan SMS Server supports two scripting languages, Visual Basic .NET or C#. After adding the scripting gateway a default skeleton script is installed that provides the basic messaging functions. This skeleton script can be adapted in the Scripting Gateway Properties dialog. Diafaan SMS Server 2.1.5 Manual 22 2009-2014 Diafaan communication software 2.2.6 Add a Hypermedia SMS PRO gateway Only available in Diafaan SMS Server - basic and full editions. Hypermedia systems provides a range of wireless voice and SMS hardware gateways aimed at the banking sector, health care, manufacturing, governments, mobile service operators and other demanding markets. The Hypermedia SMS PRO Gateway is a professional multi-port wireless SMS gateway device with support for 4 - 32 ports. Client ID The Client ID can be freely chosen. If another client logs in with the same ID as an existing client then the new client will cause the disconnection of the old client and a message will be sent to each indicating this, therefore it is recommended that each new client that connects to the gateway should use a unique ID. Note that if no ID is given, a unique ID will be generated for the client by the gateway. SIM card routing The SIM card routing options can be used to assign a specific SIM card in the Hypermedia SMS PRO Gateway to this Gateway. It is also possible to assign a GSM number to the SIM card that is used as the To field for messages that are received on this SIM card. In the Hypermedia SMS PRO gateway properties you can assign more than one SIM card to the Gateway. Getting started 23 2009-2014 Diafaan communication software 2.3 Add a connector Add connector wizard Start the Add connector wizard and select the gateway type. If the Add connector option is not available in the Actions list, you will have to remove one or more connectors first. Select one of the available connectors Web connector Email connector SQL connector Scripting connector Assign the gateways If you have installed more than one gateway you can select the gateways you want to use with the new connector. For each available gateway you can choose if you want to use the gateway to send and receive messages, send or receive only or not at all. You can assign the gateway as a primary gateway or a backup gateway. Diafaan SMS Server will first try to send the message with one of the assigned primary gateways. If sending the message failed it will be repeated with a maximum of Max send attempts for each primary gateway. If sending the message is still not successful on all primary gateways, the same procedure is used with the assigned backup gateway(s). Diafaan SMS Server 2.1.5 Manual 24 2009-2014 Diafaan communication software Receive messages If a gateway receives an SMS message, it is forwarded to all connectors that have the receive messages option enabled for that gateway. This means that one received message may be processed by more than one connector. Override the assigned gateways With most connectors you can use the Gateway field to specify a gateway list for each message. The gateway list can be a single gateway name or multiple gateway names separated by semicolons, e.g.: GSM Modem Gateway or GSM Modem Gateway;Clickatell Gateway. Only gateways that are assigned to the connector can be used, other gateway names are ignored. If a gateway is assigned as backup gateway it will still be used as a backup gateway. Please note that the gateway name must be an exact match, otherwise it will be ignored. Getting started 25 2009-2014 Diafaan communication software 2.3.1 Add a Web connector Enable the HTTP Web server The Web connector starts an HTTP web server on the provided port. The HTTP Server enables access to the the SMS Web Application Client and the HTTP API. See the HTTP API specifications for an overview of the HTTP commands. If the Limit inbox and send log to option is selected, the number of log items per user in the Send Log and the Inbox/Receive Log is limited to a fixed number of records. If the log database is getting too large, viewing the logs will get gradually slower and a fixed log limit helps to prevent this. Access the SMS Web Application Client On the computer where Diafaan SMS Server is installed, you can access the web application client on url http://localhost:9710 with the user name admin and the password you entered in the setup wizard. If the web application can be accessed from the local computer but not from the rest of the network there might be a problem with the firewall. Diafaan SMS Server sets an exception to the Windows firewall on installation but it is possible that other firewalls block access to the HTTP server. Diafaan SMS Server 2.1.5 Manual 26 2009-2014 Diafaan communication software Getting started 27 2009-2014 Diafaan communication software 2.3.2 Add an Email connector Forward email to SMS Diafaan SMS Server can receive email in one of two ways, with a built-in SMTP server or with a connection to an external POP box. In the Add Email connector wizard you can choose which method you want to use or if you do not want to forward email to SMS. SMTP Server By default, the new SMTP Server will start on port 25. You can change the SMTP port number in the Email connector properties. It is also possible to change the message template, the parts of the email messages that are converted to SMS. The to address of the mail message is converted into the number and an optional message type, e.g.:
[email protected] is sent to number +44xxxxxxxxx. [email protected] is also sent to number +44xxxxxxxxx. [email protected] is sent to number +44xxxxxxxxx with message type sms.text. POP3 Client The Email connector can retrieve email from a POP box and convert the mail to an SMS message. After installing the connector, the email is forwarded to the GSM number (list) you entered. You can change the message template and add the option to extract the GSM number (list) from the mail subject or body in the Email connector properties. Forward received SMS message to email Enable the Forward received SMS messages to email to convert received SMS messages to one or more email messages. Diafaan SMS Server 2.1.5 Manual 28 2009-2014 Diafaan communication software After installing the connector, the message is forwarded to the email address (list) you entered. You can change the email template and add the option to extract the email address from the SMS message or to reply to a previously sent email message in the Email connector properties. Getting started 29 2009-2014 Diafaan communication software 2.3.3 Add an SQL connector The SQL connector provides the connection to the database you want to use. It supports three database tables, one for messages to send (MessageOut), one to store received messages (MessageIn) and a table to log sent or failed calls (MessageLog). Connect to the database If you use a Microsoft SQL Server (Express) database you can provide the information necessary to connect to the database in the dialog box. For other database programs you have to enter the ODBC or OLE DB connection string for your database. Diafaan SMS Server 2.1.5 Manual 30 2009-2014 Diafaan communication software Create the database The wizard lets you create a Microsoft SQL Server (Express) automatically, if you want to use a different database you have to create the database tables manually. On the following pages you can find the database table definitions for some popular database programs. Create a MySQL database Create an Oracle database Create a Microsoft Access database Create a PostgreSQL database Use an existing database If you used the wizard to create the Microsoft SQL Server (Express) database you are done. However if you use another database program or want the SQL connector to use an existing database with a different table layout you have to provide the table and field names manually. Getting started 31 2009-2014 Diafaan communication software For each SMS message field you can enter the corresponding database field name. In the Send SMS tab page you can also use double quotes to indicate fixed values. In the example below the To part of the SMS message is not retrieved from the database but all messages are sent to number +44xxxxxxxxxx. The SQL connector can use more fields, like the SMS message type or the gateway name you want to use to send the messages. These fields can be entered in the advanced properties of the SQL Connector Properties. Diafaan SMS Server 2.1.5 Manual 32 2009-2014 Diafaan communication software 2.3.4 Add a Scripting connector Select scripting language Diafaan SMS Server supports two scripting languages, Visual Basic .NET or C#. After adding the scripting connector a default skeleton script is installed that provides the basic messaging functions. This skeleton script can be adapted in the Scripting Connector Properties dialog. III How to... Diafaan SMS Server 2.1.5 Manual 34 2009-2014 Diafaan communication software 3 How to... 3.1 Route messages Connector specific routing The main routing procedure in Diafaan SMS Server is connector specific routing. For each connector you can choose if you want to use the available gateways to send and receive messages, send or receive only or not at all. Each gateway can be designated as a primary gateway or as a backup gateway. Diafaan SMS Server will first try to send the message with one of the assigned primary gateways. If sending the message failed it will be repeated with a maximum of Max send Attempts for each primary gateway. If sending the message is still not successful on all primary gateways, the same procedure is used with the assigned backup gateway(s). Message specific routing using the To Address or Message Type For each Gateway in the Connector Properties you can specify whether you want to use the Gateway for all messages or only for specific messages. Messages can be routed depending on the to address or the message type of the message. The routing filter can consist of one or more wildcards, separated by semicolons or comma's, or a regular expression match when the filter starts with the text "regex:". If the routing filter starts with a minus character (-), the message is routed through the gateway when the to address or message type does not match the filter. How to... 35 2009-2014 Diafaan communication software Routing examples for the "to address" filter Use this gateway for messages with numbers starting with 07 or +447: 07*;+447* Do not use this gateway for messages with numbers starting with 07 or +447: -07*;+447* Use this gateway for messages with British mobile numbers, using a regular expression: regex:^(07|\+447)[0-9]{9}$ Do not use this gateway for messages with British mobile numbers, using a regular expression: -regex:^(07|\+447)[0-9]{9}$ Message specific routing using the Gateway field With most connectors you can use the Gateway field to specify a gateway list for each message. The gateway list can be a single gateway name or multiple gateway names separated by semicolons. Only gateways that are enabled in the connector specific routing options can be used, other gateway names are ignored. If a gateway is assigned as backup gateway it will still be used as a backup gateway. In the example above you can use the GSM Modem on COM1 as a primary gateway and the Clickatell Gateway as the backup gateway by setting the Gateway field to GSM Modem on COM1;Clickatell Gateway. The gateway GSM Modem on COM10 is not used for this message. Using message specific routing in the Web Connector: http://localhost:9710/http/send-message?to=%2B44xxx&message=Message&gateway=GSM+Modem +on+COM1%3BClickatell+Gateway Advanced routing Only available in Diafaan SMS Server - basic and full editions. The most flexible way to route messages is with a gateway script. Depending on the destination address, message type or message text a different gateway (list) can be used to send the messages. It is also possible to change the destination address, message type and message text before it is sent. In the gateway skeleton script the message is routed with the PostDispatchMessage method. private void PostDispatchMessage( string recordId, string toAddress, string fromAddress, string message, string messageType, string gateway, string backupGateway) The gateway name list is set in the gateway and backupGateway parameters. An optional value can be added after the gateway name to specify the maximum number of send attempts that is used for that gateway, GSM Modem on COM10:4 for a maximum of 4 send attempts. E.g.: Diafaan SMS Server 2.1.5 Manual 36 2009-2014 Diafaan communication software private void OnMessageToSend(string recordId, string toAddress, string fromAddress, string message, string messageType) { PostDispatchMessage( recordId, toAddress, fromAddress, "Dispatched: " + message, messageType, "GSM Modem on COM1;Clickatell Gateway", "GSM Modem on COM10:4"); } See for a routing example the Dispatch SMS to gateway script. How to... 37 2009-2014 Diafaan communication software 3.2 Use message types Message types are used to specify what the message means and how it should be sent. Message types are gateway specific, not all messages types will be understood by all gateways. In those cases the gateway will resort to its default message handling to send the message. In the Paging Gateway the message type is used to select which service is used to send the message. The following message types are the standard message types used in Diafaan SMS Server. Text messages Text messages can be split and later recombined into multiple SMS messages to increase the message length. Splitting the messages takes a couple of character spaces from each message. The maximum number of characters sent in each SMS message also depends on the character set used for the message. sms.automatic If possible the text is sent in the default GSM SMS alphabet. If the message contains characters that are not in the default alphabet the text is sent as unicode. Since an SMS unicode message has a maximum length of 70 characters and a text in the default GSM SMS alphabet has a maximum of 160 characters the number of characters that are sent to the phone will depend on the characters that are used in the message. sms.text The default GSM SMS alphabet is always used to send the message. Characters that are not available in the default GSM SMS alphabet are converted to question marks. The message length of a message place of two normal characters and will decrease the maximum message length. sms.unicode The message will always be sent in unicode text. This means that the maximum amount of characters in one message is always 70 characters, even if the message contains only characters from the default GSM SMS alphabet. Flash message If implemented on the GSM phone, flash messages are displayed directly on the phone's screen instead of being stored in the message inbox. You can send a flash message with one of the message types: sms.automatic.flash sms.text.flash sms.unicode.flash Binary messages Binary message can contain up to 140 bytes per SMS message. In Diafaan SMS Server all bytes of the binary messages are encoded in two uppercase hexadecimal digits, for example the 'A' byte is encoded to 41. In addition to the data itself, a binary message can also contain a User Data Header. This UDH usually defines the purpose of the data. sms.binary Binary message can be sent in five ways: data only, with user data header, with data coding scheme, with user data length or with protocol identifier. Diafaan SMS Server 2.1.5 Manual 38 2009-2014 Diafaan communication software Data only: <Data> 3C3C6E0000F01CF00C User Data Header plus Data: <UDH>,<Data> 78FA0B5293,3C3C6E0000F01CF00C Only available for GSM Modem Gateways: Data Coding Scheme plus User Data Header plus Data: Usable for data or unicode messages <DCS>,<UDH>,<Data> 00,78FA0B5293,3C3C6E0000F01CF00C Data Coding Scheme plus User Data Length plus User Data Header plus Data: Usable for data, text or unicode messages <DCS>,<UDL>,<UDH>,<Data> 00,24,78FA0B5293,3C3C6E0000F01CF00C Data Coding Scheme plus Protocol Identifier plus User Data Length plus User Data Header plus Data: Usable for data, text or unicode messages with a special protocol identifier <DCS>,<PID>,<UDL>,<UDH>,<Data> 00,00,24,78FA0B5293,3C3C6E0000F01CF00C See Send pictures and ringtones for examples of binary messages. sms.pdu Only available for GSM Modem Gateways GSM modems send SMS messages as binary data strings called Packet Data Units. If you use the sms.pdu message type you can send a fully customized PDU. USSD commands USSD is a standard for transmitting information over GSM signaling channels. It is mostly used as a method to query the available balance and other similar information in pre-paid GSM services. The function that is triggered when sending USSD is network-dependent and depends on the specific services the operator is offering. gsm.ussd Only available for GSM Modem Gateways The USSD code should be sent in the to field of the message. The response is sent back as a received SMS message. Example USSD codes: * *101# * *109*72348937857623# How to... 39 2009-2014 Diafaan communication software 3.3 Use number templates Number templates are used to translate the To address from one format to another. You can use a number template if the gateway accepts only specific number formats (e.g. only numbers in international number format) and the source of the messages might generate the numbers in other formats. Number templates can also be used if you use different gateways to send the messages and if each gateway accepts numbers in a slightly different format. For instance when you use a GSM modem as a primary gateway to send the messages and a Paging Gateway with an email service as a backup gateway. Since the email service only accepts an email address as a valid recipient address you can use a number template to translate the GSM phone number to a valid email address. Number template format The number template uses a simple format to check if the number confirms to the template and to translate the number from one format to another. # The hash tag character is used for each number or character that is available in the source address and should be sent to the gateway. [...] Everything in brackets is not used to check if the number matches the number format but is inserted in the resulting recipient address. Other characters All other characters are used to check if the number matches the number format but are removed from the resulting recipient address. The number template field can contain multiple number templates, each one separated by a semicolon, e.g.: 07[+447]#########;447[+447]######### The number template also supports regular expression replacement if the field conforms to the following format: regex:<regular expression>replace:<replacement> If the number does not conform to the template format it is not translated to a different number format but sent "as is". Examples Translate local UK GSM numbers to international format: 07[+447]######### translates "07848000000" to "+447848000000". Translate UK GSM number to an international format starting with 00: 07[00447]#########;+447[00447]######### translates "07848000000" and "+447848000000" to "00447848000000". Translate a pager phone number to a 5 digit PIN: +124812#####;024812##### translates "+12481234567" and "02481234567" to "34567" Translate a national GSM number to an email address: 0[0]##########[@t-mobile.de] translates "01511111111" to "[email protected]" Translate national German GSM numbers to international format: regex:^01(?=[0-9]{9,13}$)replace:+441 Diafaan SMS Server 2.1.5 Manual 40 2009-2014 Diafaan communication software 3.4 Use HTTP callbacks Only available in Diafaan SMS Server - basic and full editions. Diafaan SMS Server can use HTTP callbacks to send information about the message flow in Diafaan SMS Server to a web server. The web server can use this information for message and user accounting. For messages to send (action message_out) or for received messages (action message_in) it is also possible to block the messages completely or to change the message fields with the web server script. The response of the HTTP callback should be a URL (percentage) encoded query string. The minimum response for all callbacks is 'result=1', this means that the message will be handled normally by Diafaan SMS Server. It is important that the response from the HTTP server is as fast as possible since the handling of other messages in the Gateway or Connector is blocked until the HTTP callback is finished. When the HTTP callback takes more than 5 seconds, the message is rejected. Message out HTTP callback The message out callbacks are sent from each individual connector, just before the message is added to the message queue of Diafaan SMS Server. The message can be discarded with the response 'result=0' and most of the messages fields can be changed in the HTTP response query string.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "message_out". user_id User ID of the user sending the message. ip_number The IP number of the sender, if applicable. from The source number or name to be sent with the message. to The destination address of the message. message The message text of the message. message_type The message type for the message user_info The optional user info field. priority The priority of the message, default 0 gateway The name of the gateway(s) that are allowed to send the message. tlv_list Optional TLV list when the message is sent with an SMPP server example: http://host.com/?source=SQL +Connector&action=message_out&user_id=&ip_number=&from=%2B44xxxxxxxx&to=% 2B44xxxxxxxx&message=Message+text The HTTP response may contain the following parameters, the optional parameters should only be used if you want to change one or more of the message fields result M "0" (reject message) or "1" (accept message) user_id O User ID of the user sending the message. from O The source number or name to be sent with the message. to O The destination address of the message. message O The message text of the message. message_type O The message type for the message user_info O The optional user info field. priority O The priority of the message, default 0 gateway O The name of the gateway(s) that are allowed to send the message. tlv_list O Optional TLV list when the message is sent with an SMPP server example: result=1&user_id=64535&from=%2B4400000000&to=%2B4411111111&message=Changed +message+text How to... 41 2009-2014 Diafaan communication software Message in HTTP callback The message in callbacks are sent from each individual gateway, just before the message is added to the message queue of Diafaan SMS Server. The message can be discarded with the response 'result=0' and most of the messages fields can be changed in the HTTP response query string.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "message_in". from The source number or name to be sent with the message. to The destination address of the message. sms_central The SMSC number of the SMSC that delivered the message. message The message text of the message. message_type The message type for the message. message_part The message part number when an incomplete multi-part message is received. message_parts_received The received number of message parts when an incomplete multi-part message is received. message_parts_total The total amount of messages parts of this message. send_time The send date and time of the message. receive_time The date and time the message is received by Diafaan SMS Server. pdu The PDU of the message. tlv_list The TLV list of the SMPP message (only for messages from an SMPP Gateway) example: http://host.com/?source=GSM+Modem+Gateway&action=message_in&from=% 2B44xxxxxxxx&to=%2B44xxxxxxxx&message=Message+text The HTTP response may contain the following parameters, the optional parameters should only be used if you want to change one or more of the message fields result M "0" (reject message) or "1" (accept message) user_id O User ID of the user sending the message. from O The source number or name to be sent with the message. to O The destination address of the message. message O The message text of the message. message_type O The message type for the message. connector_list O The list of connectors that may receive the message. example: result=1&user_id=64535&from=%2B4400000000&to=%2B4411111111&message=Changed +message+text Message log HTTP callback The message log callbacks are sent from each individual connector when the initial send result of the message is received.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "message_log". user_id User ID of the user sending the message. from The source number or name to be sent with the message. to The destination address of the message. message The message text of the message. message_type The message type for the message Diafaan SMS Server 2.1.5 Manual 42 2009-2014 Diafaan communication software message_id The message ID that was returned by the gateway. message_parts The number of sent message parts for the message. gateway The name of the gateway that has sent the message. status_code 200 (message sent) or 300 (message failed) status_text The status text of the message error_code The error code that was returned by the gateway error_text The error text that was returned by the gateway send_time The date and time the message was sent user_id User ID of the user sending the message. user_info The optional user info field. pdu The PDU or comma separated PDU list of the sent message result_trace An error trace of the message, this field can give an indication of the reliability of the gateways The HTTP response is ignored by Diafaan SMS Server Message log update HTTP callback The message log update callbacks are sent from each individual connector when an update is received for a previous message log callback. This callback is usually received after a delivery confirmation is received for one of the messages.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "message_log_update". message_id The message ID that was returned by the gateway. status_code 201 (message received on phone) or 301 (message could not be delivered to the phone) status_text The status text of the message error_code The error code that was returned by the gateway error_text The error text that was returned by the gateway receive_time The date and time the message was received on the phone (only when status_code is 201) user_id User ID of the user sending the message. user_info The optional user info field. receipt The receipt text of the delivery report (only for receipts from an SMPP Gateway) tlv_list The TLV list of the SMPP receipt (only for receipts from an SMPP Gateway) The HTTP response is ignored by Diafaan SMS Server Validate user HTTP callback Validate the user name or password, depending on the type of connector this callback is sent once for every connection or every time a message has to be send. Connectors that do not support user/ password logon, like the SQL Connector, don't send this callback at all.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "validate_user". user_id User ID of the user sending the message. ip_number The IP number of the sender, if applicable. user_name The login user name. How to... 43 2009-2014 Diafaan communication software password The login password. example: http://host.com/?source=Web +Connector&action=validate_user&user_id=&ip_number=127%2E0%2E0% 2E1&user_name=User&password=Password The HTTP response may contain the following parameters, the optional parameters should only be used if you want to change the user ID. result M "0" (reject username and password) or "1" (accept user name and password) user_id O User ID of the user sending the message. example: result=1&user_id=64535 Accept connection HTTP callback This callback is called when a client wants to connect to an IP server based Connector, like the SMPP Connector. The connection can be refused if the response is 'result=0'.
HTTP query parameters source The name of the connector that is sending the HTTP callback. action "accept_connection". user_id User ID of the user sending the message. ip_number The IP number of the sender, if applicable. example: http://host.com/?source=SMPP +Connector&action=accept_connection&user_id=&ip_number=127%2E0%2E0%2E1 The HTTP response may contain the following parameters, the optional parameters should only be used if you want to change the user ID. result M "0" (reject connection) or "1" (accept connection) user_id O User ID of the user sending the message. example: result=1&user_id=64535 Diafaan SMS Server 2.1.5 Manual 44 2009-2014 Diafaan communication software 3.5 Send pictures and ringtones Send binary messages You can send a binary message with the sms.binary message type. Below are some examples of binary messages, the first one is a picture message and the second a ringtone. Since the picture message is too large to fit in one SMS message it is split in three separate SMS messages. If you send a binary message, make sure that the message data does not contain any new line or space characters, if it does the message will fail. Send a picture message Part 1 0B0003CB03010504158A0000,3002010000481C01000000000000000000000000004000000000000 00000E00000000000000001F00000000000000003F80000000000000007FC000000000000000FFE0 000000000FFFFF07C0000000000FFFFF8780000000000FFFFFC700000000000FFFFFE600000000 000FFFFFF400000000000FFFFFF800000000000FFFF Part 2 0B0003CB03020504158A0000,FF800000000000FFFFFF800000000000FFFFFF800000000000FF9F FF878000000000FF9FFF8C0000000000FF9FFF8C0000000000F810F09F3C3C6E0000F01CF00C3 E3E7F0000F39CFE0C0606730000F39CE00C7E7E630000F39CC00CFEFE630000F39CCE0CC6C 6630000F39CCE0CC6C6630000F810200C7E7E63000000000000 Part 3 0B0003CB03030504158A0000,00000000 Send a ringtone How to... 45 2009-2014 Diafaan communication software Axel F 06050415810000,024A3A5585E195B198040042D9049741A69761781B6176156174288B525D85E0 A26C24C49A617628930BB125E055856049865885D200 Diafaan SMS Server 2.1.5 Manual 46 2009-2014 Diafaan communication software 3.6 Connect to Microsoft Exchange Server Your entire organization can send and SMS messages from Outlook and receive SMS messages in their Outlook Inbox if you connect Diafaan SMS Server with your Microsoft Exchange Server 2007, 2010 or 2013. Diafaan SMS Server uses standard internet protocols to connect with Exchange Server. Step 1: Install Diafaan SMS Server Diafaan SMS Server can be installed on the server where Microsoft Exchange Server 2007 or 2010 is installed or on a separate server or PC in your network. When you choose to install Diafaan SMS Server on the machine where Microsoft Exchange Server is installed, you have to perform an extra step to ensure that the SMTP servers in Diafaan SMS Server and Exchange Server do not interfere with each other. Older versions of Microsoft Exchange Server can also be connected with Diafaan SMS Server, but only when the two programs are installed on different servers in your network. Step 2: Add an Email Connector to Diafaan SMS Server The second step in the integration with Microsoft Exchange Server is to add an Email Connector in Diafaan SMS Server. You can select the default options in the setup wizard, specific options necessary to integrate with your Exchange Server installation can be changed later in the Email Connector Properties. Step 3: Add a Send Connector to Exchange Exchange uses Send Connectors to forward email to an external email server. You can add a new Send Connector in the Exchange Management Console. Send Connector Address Space How to... 47 2009-2014 Diafaan communication software The address space defines which email messages will be forwarded to Diafaan SMS Server. In this example the address space is set to gsm.network. This means that all email messages to the domain gsm.network (e.g. [email protected]) will be sent through Diafaan SMS Server. Send Connector Smart Host In the Network Settings you can specify the location of the Diafaan SMS Server Email Connector. In the picture below the location is set to localhost, the same computer where Exchange is installed. If Diafaan SMS Server is installed on another computer you can enter the IP address or fully qualified domain name of the computer. Diafaan SMS Server 2.1.5 Manual 48 2009-2014 Diafaan communication software Step 3a: Change Diafaan SMTP Port In the installation example in step 3 there is an obvious conflict between Diafaan SMS Server and Exchange. Since both programs are installed on the same computer and both use an SMTP Server on the same SMTP port one of the SMTP Servers will not work (probably the SMTP Server used by Diafaan SMS Server). To solve this conflict the SMTP port in the Email Connector of Diafaan SMS Server should be set to an unused port, for example 26. You can also change the message template to define which parts of the email messages are sent as the SMS message. How to... 49 2009-2014 Diafaan communication software The same port number must now be set in the Send Connector in Exchange. Since this is not possible in the Exchange Management Console, you have to do this with a shell command in the Exchange Management Shell: Set-SendConnector -identity "DiafaanSMSServer" -Port:26 Sending SMS messages from one of the Outlook clients should now work, you can try it out by sending an email message to email address <gsm-number>@gsm.network, (depending on the address space for the Send Connector you supplied). Step 4: Use the Receive Connector in Exchange If you want to use Diafaan SMS Server to forward received SMS messages to email users you can use (one of) the SMTP Server in Exchange. The default SMTP Server in Exchange accepts email from an SMTP Client with basic authentication after TLS encryption is enabled. Diafaan SMS Server can use basic authentication in plain text or over a TLS encrypted connection. Diafaan SMS Server 2.1.5 Manual 50 2009-2014 Diafaan communication software Check to see if Basic Authentication is enabled. Set the email properties In the Receive SMS tab page you can specify what Diafaan SMS Server should do with the received How to... 51 2009-2014 Diafaan communication software SMS messages. In the example below the SMS message is replied to a previously sent email message (if available) Set the Exchange SMTP Server If Exchange Server is installed on the same computer as Diafaan SMS Server you can set the server to localhost. If it is installed on another server, you have to enter the IP address or Fully qualified Domain Name of the computer where Exchange is installed. If your Exchange Server accepts email over a TLS encrypted connection you should also set encryption to STARTTLS. To change the format of the email message, select Edit email template for received SMS messages on the Email templates page. The From Address Template can be set to [from]@gsm.network (depending on the address space for the Send Connector) to allow receivers of the SMS message to reply to the message. That is all, forwarding received SMS messages to email should now work. You can test it by sending an SMS message to the GSM modem. Diafaan SMS Server 2.1.5 Manual 52 2009-2014 Diafaan communication software 3.7 Access your database Learn how to send and receive SMS messages using an existing SQL database with Diafaan SMS Server. Get instructions about the installation of the ODBC or OLE DB driver, how to connect to the database with a connection string and use the database tables and fields of your database. Connect to an existing database Install the driver Diafaan SMS Server supports three driver models to connect to your database, Microsoft SQL Server, ODBC and OLE DB. Database drivers for some databases like Microsoft SQL Server or dBase are already installed by default in Windows but for most databases you will have to install the ODBC or OLE DB driver for your specific database. Usually you can find the right drivers on the website of the database manufacturer. Create the connection string All information necessary to connect to the database is stored in the connection string. The format of the connection string is different for each ODBC/OLE DB driver and database. Examples of connection strings to connect to a large number of databases can be found on the website http:// www.connectionstrings.com. In the example below you can see that the connection string contains information about the server on which the database runs, the name of the database and the name and password needed to connect to the database. You can use the Test button to test if the connection string is set up right. Use the database tables and fields Database tables How to... 53 2009-2014 Diafaan communication software The SQL connector supports three database tables, one for messages to send (MessageOut), one to store received messages (MessageIn) and a table to log sent or failed calls (MessageLog). For each database table you can provide the table name of your database and each database field name you want to use. Send SMS table Diafaan SMS Server polls the Send SMS table for new records and uses the information to send SMS messages. After the records are read in Diafaan SMS Server either deletes the record or updates one of the fields to a fixed value to prevent that messages are sent more than once. The only required field for the Send SMS table is Index which should have a unique value, without this field Diafaan SMS Server does not know which records should be deleted or updated. example 1 If you have a database table ProcessErrors with three fields, a unique Id field, a Mobile field that contains a GSM number and an ErrorMessage field that contains the text that should be sent to the mobile number you can enter these table and field names as in the screenshot below: example 2 If you have a database with the same database table but without the Mobile field it is also possible to use a fixed value instead of a database field name by enclosing the text in double quote characters. In this case all messages will be sent to GSM number +44xxxxxxxx. Quoted strings can be used in all values for the Send SMS table except the Index and Change field to values. Diafaan SMS Server 2.1.5 Manual 54 2009-2014 Diafaan communication software Receive SMS table In the Receive SMS tab page the database table name and field names where received SMS messages are stored can be added. All fields are optional, you can choose to add only the information about the received SMS message you are interested in to the database. SMS Log table Messages that are sent or failed to send can be stored in the SMS Log database table. All fields are optional but when the Index and Message Id fields are not used, the status of the message cannot be updated. Status updates occur when a the status of a previously sent message changes. This happens for example when the message is received on the GSM phone or if the message could not be delivered on the GSM phone because it was switched off. How to... 55 2009-2014 Diafaan communication software The Message Status Code field stores the message result. Status codes between 200 and 299 indicate that the message is sent successfully. Status codes between 300 and 399 means that the message failed. status codes 200 Message sent and accepted by the gateway. 201 Message received on the GSM phone. 300 Message failed or rejected by the gateway. 301 Status error received after the message was accepted by the gateway Advanced database fields In the advanced tab page you can specify additional database fields that you might wand to use. The purpose of most fields should be clear, but some might need explaining. Send SMS database fields Diafaan SMS Server 2.1.5 Manual 56 2009-2014 Diafaan communication software SMSOutGateway Use this field if you want to send the message through one or more specific gateways. See Route messages for more information about routing options. SMSOutUserId and SMSOutUserInfo These two fields are not used by Diafaan SMS Server, but are transparent and written without change in the SMSLogUserId and SMSLogUserInfo fields of the MessageLog database table. The fields can be used to track the messages you send or to add your own information to the log database table. How to... 57 2009-2014 Diafaan communication software 3.7.1 Microsoft SQL Server (Express) Learn how to send and receive SMS messages using a Microsoft SQL Server (Express) database with Diafaan SMS Server. Let Diafaan SMS Server create the database tables or create the database tables manually with an SQL script. Microsoft SQL Server Microsoft SQL Server is Microsoft's high performance SQL Server relational database management system. Drivers to access the database are built-in in Microsoft Windows so it is not necessary to install any additional drivers to use the database. Microsoft SQL Server Express Microsoft SQL Server Express is a freely-downloadable and distributable version of Microsoft's SQL Server relational database management system. For all intent and purposes it is compatible with the regular version of Microsoft SQL Server and uses the same drivers. The only practical difference is that \SQLEXPRESS should be added to the data source (server) name in the connection string. Create the SMSServer database You can use the setup wizard to create the database tables and fields for the MessageOut, MessageIn and MessageLog tables. The setup wizard creates a database with the following table and field layout: CREATE DATABASE SMSServer; CREATE TABLE MessageOut ( Id int IDENTITY (1,1) PRIMARY KEY, MessageTo nvarchar(80), MessageFrom nvarchar(80), MessageText nvarchar(max), MessageType nvarchar(80), Diafaan SMS Server 2.1.5 Manual 58 2009-2014 Diafaan communication software Gateway nvarchar(80), UserId nvarchar(80), UserInfo nvarchar(max), Priority int, Scheduled datetime, IsSent bit NOT NULL DEFAULT 0, IsRead bit NOT NULL DEFAULT 0); CREATE INDEX IDX_IsRead ON MessageOut (IsRead); CREATE TABLE MessageIn ( Id int IDENTITY (1,1) PRIMARY KEY, SendTime datetime NOT NULL DEFAULT getdate(), ReceiveTime datetime, MessageFrom nvarchar(80), MessageTo nvarchar(80), SMSC nvarchar(80), MessageText nvarchar(max), MessageType nvarchar(80), MessagePDU nvarchar(max), Gateway nvarchar(80), UserId nvarchar(80)); CREATE TABLE MessageLog ( Id int IDENTITY (1,1) PRIMARY KEY, SendTime datetime NOT NULL DEFAULT getdate(), ReceiveTime datetime, StatusCode int, StatusText nvarchar(80), MessageTo nvarchar(80), MessageFrom nvarchar(80), MessageText nvarchar(max), MessageType nvarchar(80), MessageId nvarchar(80), ErrorCode nvarchar(80), ErrorText nvarchar(80), Gateway nvarchar(80), MessagePDU nvarchar(max), UserId nvarchar(80), UserInfo nvarchar(max)); CREATE INDEX IDX_MessageId ON MessageLog (MessageId, SendTime); How to... 59 2009-2014 Diafaan communication software 3.7.2 MySQL database Learn how to send and receive SMS messages using a MySQL database with Diafaan SMS Server. Get instructions about the installation of the ODBC driver, create the database with an SQL script and how to connect to the database with the connection string for MySQL. MySQL MySQL is one of the most popular database programs available. Diafaan SMS Server can use an ODBC driver to connect to MySQL. For this article MySQL version 5.0.88 was used with the MyODBC 5.1 driver. Install the MyODBC driver Before Diafaan SMS Server can send and receive SMS messages from the database you have to make sure the MyODBC 5.1 driver is installed on the computer running Diafaan SMS Server. You can find the MyODBC driver on the MySQL website. Note: Diafaan SMS Server is a 32-bit program and requires the 32-bit version of the ODBC driver, the 64-bit ODBC driver will not work. Windows supports both 32-bits and 64-bits versions of the ODBC drivers at the same time. The 32-bit version of the Windows ODBC manager is located at "% systemdrive%\Windows\SysWoW64\Odbcad32.exe" on 64-bit versions of Windows. Create the SMSServer database You can use the MySQL command line client to create the database tables. Of course it is also possible to use an existing database, but if you want to be sure you can use all options available in Diafaan SMS Server you may use the SQL commands below necessary to create the database tables to send and receive SMS messages and to keep the send log. CREATE DATABASE SMSServer DEFAULT CHARACTER SET utf8; CREATE TABLE MessageOut ( Id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, MessageTo VARCHAR(80), MessageFrom VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), Gateway VARCHAR(80), UserId VARCHAR(80), UserInfo TEXT, Priority INT, Scheduled DATETIME, IsSent TINYINT(1) NOT NULL DEFAULT 0, IsRead TINYINT(1) NOT NULL DEFAULT 0) CHARACTER SET utf8; CREATE INDEX IDX_IsRead ON MessageOut (IsRead); CREATE TABLE MessageIn ( Id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, SendTime DATETIME, ReceiveTime DATETIME, MessageFrom VARCHAR(80), MessageTo VARCHAR(80), SMSC VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), Diafaan SMS Server 2.1.5 Manual 60 2009-2014 Diafaan communication software MessagePDU TEXT, Gateway VARCHAR(80), UserId VARCHAR(80)) CHARACTER SET utf8; CREATE TABLE MessageLog ( Id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, SendTime DATETIME, ReceiveTime DATETIME, StatusCode INT, StatusText VARCHAR(80), MessageTo VARCHAR(80), MessageFrom VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), MessageId VARCHAR(80), ErrorCode VARCHAR(80), ErrorText VARCHAR(80), Gateway VARCHAR(80), MessagePDU TEXT, UserId VARCHAR(80), UserInfo TEXT) CHARACTER SET utf8; CREATE INDEX IDX_MessageId ON MessageLog (MessageId, SendTime); Add the SQL Connector Now you can add the new database to Diafaan SMS Server. First create a new SQL Connector with the connector wizard and select ODBC as the database type. On the next page you can provide the ODBC connection string, the following connection string should be adapted for your database installation: Driver={MySQL ODBC 5.1 Driver};Server=myServerAddress;charset=UTF8;Database=myDataBase;User=myUsername; Password=myPassword;Option=3; How to... 61 2009-2014 Diafaan communication software Select the database fields On the next wizard pages you can select the database tables and fields you want Diafaan SMS Server to use. You can only select the most used fields here. Additional database fields can be selected later on the advanced tab page in the connector properties dialog. For more information see Access your database. It is a good idea to change the database flavor option on the same advanced tab page to MySQL. This will instruct Diafaan SMS Server to use a specific SQL syntax for MySQL enhancing performance somewhat. Diafaan SMS Server 2.1.5 Manual 62 2009-2014 Diafaan communication software 3.7.3 Oracle database Learn how to send and receive SMS messages using an Oracle database with Diafaan SMS Server. Get instructions about the installation of the OLE DB driver, create the database with an SQL script and how to connect to the database with the connection string for Oracle. Oracle database Diafaan SMS Server can use OLE DB to connect to the Oracle database. For this article Oracle 10g Express Edition was used with the Oracle 10g Provider for OLE DB. Install the Oracle OLE DB provider Before Diafaan SMS Server can send and receive SMS messages from the database you have to make sure the OLE DB provider is installed on the computer running Diafaan SMS Server. You can get the Oracle OLE DB provider software on the Oracle website. Create the SMSServer database On the database home page of your Oracle server you can use the SQL commands to create the database tables. Of course it is also possible to use an existing database, but if you want to be sure you can use all options available in Diafaan SMS Server you may use the SQL commands below. Since Oracle does not support auto increment fields in the CREATE TABLE statements, a number of sequences and triggers must be created to provide the same functionality. CREATE DATABASE SMSServer; CREATE TABLE MessageOut ( Id NUMBER(19) NOT NULL PRIMARY KEY, MessageTo NVARCHAR2(80), MessageFrom NVARCHAR2(80), MessageText NCLOB, MessageType NVARCHAR2(80), Gateway NVARCHAR2(80), UserId NVARCHAR2(80), UserInfo NCLOB, Priority NUMBER, Scheduled DATE, IsSent NUMBER(1) DEFAULT 0, IsRead NUMBER(1) DEFAULT 0); CREATE INDEX IDX_IsRead ON MessageOut (IsRead); CREATE SEQUENCE MessageOutSequence START WITH 1 INCREMENT BY 1 NOMAXVALUE; CREATE TRIGGER MessageOutTrigger BEFORE INSERT ON MessageOut FOR EACH ROW BEGIN SELECT MessageOutSequence.NEXTVAL INTO :NEW.Id FROM DUAL; END; CREATE TABLE MessageIn ( Id NUMBER(19) NOT NULL PRIMARY KEY, SendTime DATE, ReceiveTime DATE, MessageFrom NVARCHAR2(80), How to... 63 2009-2014 Diafaan communication software MessageTo NVARCHAR2(80), SMSC NVARCHAR2(80), MessageText NCLOB, MessageType NVARCHAR2(80), MessagePDU NCLOB, Gateway NVARCHAR2(80), UserId NVARCHAR2(80)); CREATE SEQUENCE MessageInSequence START WITH 1 INCREMENT BY 1 NOMAXVALUE; CREATE TRIGGER MessageInTrigger BEFORE INSERT ON MessageIn FOR EACH ROW BEGIN SELECT MessageInSequence.NEXTVAL INTO :NEW.Id FROM DUAL; END; CREATE TABLE MessageLog ( Id NUMBER(19) NOT NULL PRIMARY KEY, SendTime DATE, ReceiveTime DATE, StatusCode NUMBER, StatusText NVARCHAR2(80), MessageTo NVARCHAR2(80), MessageFrom NVARCHAR2(80), MessageText NCLOB, MessageType NVARCHAR2(80), MessageId NVARCHAR2(80), ErrorCode NVARCHAR2(80), ErrorText NVARCHAR2(80), Gateway NVARCHAR2(80), MessagePDU NCLOB, UserId NVARCHAR2(80), UserInfo NCLOB); CREATE INDEX IDX_MessageId ON MessageLog (MessageId, SendTime); CREATE SEQUENCE MessageLogSequence START WITH 1 INCREMENT BY 1 NOMAXVALUE; CREATE TRIGGER MessageLogTrigger BEFORE INSERT ON MessageLog FOR EACH ROW BEGIN SELECT MessageLogSequence.NEXTVAL INTO :NEW.Id FROM DUAL; END; Add the SQL Connector Now you can add the new database to Diafaan SMS Server. First create a new SQL Connector with the connector wizard and select OLE DB database as the database type. On the next page you can provide the connection string, the connection string below is an example of a connection string for the OLE DB provider and can be adapted to suit your database installation: Connection string with TNS: Diafaan SMS Server 2.1.5 Manual 64 2009-2014 Diafaan communication software Provider=OraOLEDB.Oracle;Data Source=myOracleDB;User Id=myUsername;Password=myPassword; Connection string without TNS: Provider=OraOLEDB.Oracle;Data Source=(DESCRIPTION=(CID=GTU_APP)(ADDRESS_LIST= (ADDRESS=(PROTOCOL=TCP)(HOST=myServerAddress)(PORT=1521)))(CONNECT_DATA= (SID=myOracleSID)(SERVER=DEDICATED)));User Id=myUsername;Password=myPassword; Select the database fields On the next wizard pages you can select the database tables and fields you want Diafaan SMS Server to use. You can only select the most used fields here. Additional database fields can be selected later on the advanced tab page in the connector properties dialog. For more information see Access your database. It is a good idea to change the database flavor option on the same advanced tab page to Oracle. This will instruct Diafaan SMS Server to use a specific SQL syntax for Oracle, enhancing performance somewhat. How to... 65 2009-2014 Diafaan communication software 3.7.4 Microsoft Access Learn how to send and receive SMS messages using a Microsoft Access database with Diafaan SMS Server. Get instructions about the OLE DB driver, create the database with an SQL script and how to connect to the database with the connection string for Microsoft Access. Microsoft Access Microsoft Access is not optimized for multi-user configurations and therefore it is not the best database for high-volume messaging. For low to medium message volume however it is an excellent database, especially if you already have your contact data stored in an Access database. Using the Access database connector makes it easy to add SMS functionality to your Microsoft Access or Visual Basic applications. Use the Microsoft JET OLE DB provider If you have Microsoft Access installed on the computer where Diafaan SMS Server is running, the OLE DB provider is already installed with it. If not, you might have to download the provider from the Microsoft website. Create the database You can use Microsoft Access to create the database file. The tables and fields can be entered manually in the Access user interface or with the SQL commands below. Of course it is also possible to use an existing database, but if you want to be sure you can use all options available in Diafaan SMS Server you may use the SQL commands below. You can find an empty Access database (SMSServer.mdb) with this layout in the Examples folder of Diafaan SMS Server. CREATE TABLE MessageOut ( Id AUTOINCREMENT, MessageTo TEXT, MessageFrom TEXT, MessageText MEMO, MessageType TEXT, Gateway TEXT, UserId TEXT, UserInfo MEMO, Priority NUMBER, Scheduled DATE, IsSent YESNO, IsRead YESNO); CREATE UNIQUE INDEX MessageOutNDX ON MessageOut (Id); CREATE INDEX IDX_IsRead ON MessageOut (IsRead); CREATE TABLE MessageIn ( Id AUTOINCREMENT, SendTime DATE, ReceiveTime DATE, MessageFrom TEXT, MessageTo TEXT, SMSC TEXT, MessageText MEMO, MessageType TEXT, Diafaan SMS Server 2.1.5 Manual 66 2009-2014 Diafaan communication software MessagePDU MEMO, Gateway TEXT, UserId TEXT); CREATE UNIQUE INDEX MessageInNDX ON MessageIn (Id); CREATE TABLE MessageLog ( Id AUTOINCREMENT, SendTime DATETIME, ReceiveTime DATETIME, StatusCode NUMBER, StatusText TEXT, MessageTo TEXT, MessageFrom TEXT, MessageText MEMO, MessageType TEXT, MessageId TEXT, ErrorCode TEXT, ErrorText TEXT, Gateway TEXT, MessagePDU MEMO, UserId TEXT, UserInfo MEMO); CREATE UNIQUE INDEX MessageLogNDX ON MessageLog (Id); CREATE INDEX IDX_MessageId ON MessageLog (MessageId, SendTime); Add the SQL Connector Now you can add the new database to Diafaan SMS Server. First create a new SQL Connector with the connector wizard and select OLE DB database as the database type. On the next page you can provide the connection string, the connection string below is an example of a connection string for the OLE DB provider and can be adapted to suit your database configuration: Connection string for Access 2010 and older: Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\smsserver.accdb;User Id=myUserId;Password=myPassword; Alternative connection string for Access 2002 and Access 2003: Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:\smsserver.mdb;User Id=myUserId;Password=myPassword; Select the database fields On the next wizard pages you can select the database tables and fields you want Diafaan SMS Server to use. You can only select the most used fields here. Additional database fields can be selected later on the advanced tab page in the connector properties dialog. For more information see Access your database. Important note If you want to keep the messages in the MessageOut table you can select the Change field: .. to .. option. In Microsoft Access the YES value of a YESNO field is -1. Other values have unpredictable results and may cause repeated sending of the messages. For the database layout in this article this How to... 67 2009-2014 Diafaan communication software would mean Change field: IsSent to -1. It is a good idea to change the database flavor option on the same advanced tab page to Microsoft. This will instruct Diafaan SMS Server to use a specific SQL syntax for Microsoft, enhancing performance somewhat. Diafaan SMS Server 2.1.5 Manual 68 2009-2014 Diafaan communication software 3.7.5 PostgreSQL database Learn how to send and receive SMS messages using a PostgreSQL database with Diafaan SMS Server. Get instructions about the installation of the ODBC driver, create the database with an SQL script and how to connect to the database with the connection string for PostgreSQL. PostgreSQL PostgreSQL is an open source database server. Diafaan SMS Server can use an ODBC driver to connect to PostgreSQL. For this article PostgreSQL version 8.4.2 was used with the psqlODBC 8.4.2 driver. Install the psqlODBC driver Before Diafaan SMS Server can send and receive SMS messages from the database you have to make sure the psqlODBC driver is installed on the computer running Diafaan SMS Server. You can find the psqlODBC driver on the PostgreSQL website. Note: Diafaan SMS Server is a 32-bit program and requires the 32-bit version of the ODBC driver, the 64-bit ODBC driver will not work. Windows supports both 32-bits and 64-bits versions of the ODBC drivers at the same time. The 32-bit version of the Windows ODBC manager is located at "% systemdrive%\Windows\SysWoW64\Odbcad32.exe" on 64-bit versions of Windows. Create the SMSServer database You can use the PostgreSQL SQL shell to create the database tables. Of course it is also possible to use an existing database, but if you want to be sure you can use all options available in Diafaan SMS Server you should use the SQL commands below necessary to create the database tables to send and receive SMS messages and to keep the send log. CREATE DATABASE SMSServer WITH ENCODING 'UTF8'; CREATE SEQUENCE messageout_seq; CREATE TABLE MessageOut ( Id INTEGER NOT NULL PRIMARY KEY DEFAULT nextval('messageout_seq'), MessageTo VARCHAR(80), MessageFrom VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), Gateway VARCHAR(80), UserId VARCHAR(80), UserInfo TEXT, Priority INTEGER, Scheduled TIMESTAMP, IsSent SMALLINT NOT NULL DEFAULT 0, IsRead SMALLINT NOT NULL DEFAULT 0); CREATE INDEX IDX_IsRead ON MessageOut (IsRead); CREATE SEQUENCE messagein_seq; CREATE TABLE MessageIn ( Id INTEGER NOT NULL PRIMARY KEY DEFAULT nextval('messagein_seq'), SendTime TIMESTAMP, ReceiveTime TIMESTAMP, MessageFrom VARCHAR(80), How to... 69 2009-2014 Diafaan communication software MessageTo VARCHAR(80), SMSC VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), MessagePDU TEXT, Gateway VARCHAR(80), UserId VARCHAR(80)); CREATE SEQUENCE messagelog_seq; CREATE TABLE MessageLog ( Id INTEGER NOT NULL PRIMARY KEY DEFAULT nextval('messagelog_seq'), SendTime TIMESTAMP, ReceiveTime TIMESTAMP, StatusCode INTEGER, StatusText VARCHAR(80), MessageTo VARCHAR(80), MessageFrom VARCHAR(80), MessageText TEXT, MessageType VARCHAR(80), MessageId VARCHAR(80), ErrorCode VARCHAR(80), ErrorText VARCHAR(80), Gateway VARCHAR(80), MessagePDU TEXT, UserId VARCHAR(80), UserInfo TEXT); CREATE INDEX IDX_MessageId ON MessageLog (MessageId, SendTime); Add the SQL Connector Now you can add the new database to Diafaan SMS Server. First create a new SQL Connector with the connector wizard and select ODBC as the database type. On the next page you can provide the ODBC connection string, the following connection string should be adapted for your database installation: Driver={PostgreSQL UNICODE};Server=192.168.0.0;Port=5432;Database=smsserver;Uid=postgres;Pwd=password; Diafaan SMS Server 2.1.5 Manual 70 2009-2014 Diafaan communication software Select the database fields On the next wizard pages you can select the database tables and fields you want Diafaan SMS Server to use. You can only select the most used fields here. Additional database fields can be selected later on the advanced tab page in the connector properties dialog. For more information see Access your database. It is a good idea to change the database flavor option on the same advanced tab page to MySQL (PostgreSQL is not available but MySQL has the same syntax). This will instruct Diafaan SMS Server to use a specific SQL syntax for PostgreSQL enhancing performance somewhat. How to... 71 2009-2014 Diafaan communication software 3.8 Scripting examples 3.8.1 Gateway scripting examples 3.8.1.1 BulkSMS.com script The BulkSMS.com gateway script provides a connection to the bulksms.com SMS gateway. The script offers support for sending text, unicode and flash SMS messages. Status update requests are also supported, making it possible to see when a message is received on the GSM phone. You can find the BulkSMS.com.cs script in the Examples folder of Diafaan SMS Server. References The script makes use of the System.Web assembly so System.Web.dll has to be added to the ReferenceList property in the Advanced tab page. Script Before you can use the script you have to change the userName and password variables in the top of the script. Sending the message In the OnMessageToSend event method the query string is built with different parameters depending on the message type. The binary message type is not supported but it will not be very difficult to implement this as well. The query string is sent with a POST method to the url using an HttpWebRequest. If the response indicates that the message is successfully sent, the script calls PostSendResult with a positive status code, the last parameter of this call is set true. This instructs Diafaan SMS Server to fire the OnStatusRequest event one or more times depending on the message status. If the response does not indicate that the message is successfully sent, the script calls PostSendResult with a negative status code. If you make any change to the script make sure that the PostSendResult is always called, even if an exception is caused. Otherwise the script will only continue with the next message after a timeout of several minutes. Handling status updates Status updates are handled in the OnStatusRequest event. The script sends an HTTP query to BulkSMS.com and calls PostSendResultUpdate if the response indicates that the message was received on the GSM phone. In this case OnStatusRequest is not called again. If the response does not indicate that the message was received on the GSM phone the OnStatusRequest event will be called a couple of times more, each time with a larger time interval. Permanent errors are not handled in the example script, but it is possible to use PostSendResultUpdate for permanent errors as well. 3.8.1.2 Dispatch SMS to gateways Learn how to use a C# or Visual Basic .NET script with Diafaan SMS Server to send an SMS message through a specific gateway, depending on the GSM number. Diafaan SMS Server 2.1.5 Manual 72 2009-2014 Diafaan communication software Scenario In this scenario three gateways are defined, GSM Modem 1, GSM Modem 2 and Clickatell. SMS messages to British GSM numbers should be sent with GSM Modem 1 and messages to French GSM numbers to GSM Modem 2. All messages to other destinations should be rejected. For both destinations the Clickatell gateway is used as a backup gateway. The maximum send attempts on both GSM modems is 2, this is indicated in the script with "GSM Modem 1:2" and "GSM Modem 2:2". Script The only adaptation to the skeleton script is in the OnMessageToSend event: C# script: private void OnMessageToSend(string recordId, string toAddress, string fromAddress, string message, string messageType) { if (toAddress.StartsWith("+44")) { PostDispatchMessage(recordId, toAddress, fromAddress, message, messageType, "GSM Modem 1:2", "Clickatell"); } else if (toAddress.StartsWith("+33")) { PostDispatchMessage(recordId, toAddress, fromAddress, message, messageType, "GSM Modem 2:2", "Clickatell"); } else { PostSendResult(recordId, "", StatusCode.SendError, "Error: Invalid country destination", "", "", false); } } Visual Basic .NET script: Private Sub OnMessageToSend(recordId As String, toAddress As String, _ fromAddress As String, message As String, _ messageType As String) If toAddress.StartsWith("+44") Then PostDispatchMessage(recordId, toAddress, fromAddress, message, messageType, _ "GSM Modem 1:2", "Clickatell") ElseIf toAddress.StartsWith("+33") Then PostDispatchMessage(recordId, toAddress, fromAddress, message, messageType, _ "GSM Modem 2:2", "Clickatell") Else PostSendResult(recordId, "", StatusCode.SendError, _ "Error: Invalid country destination", "", "", False) End If End Sub If you make any change to the script make sure that the PostSendResult or PostDispatchMessage is always called, even if an exception is caused. Otherwise the script will only continue with the next message after a timeout of several minutes. MaximumBatchSize To enhance performance when a large amount of messages is sent, you can set the MaximumBatchSize in the Advanced properties to a higher value. 3.8.1.3 Send messages to e-mail Learn how to use a C# or Visual Basic .NET script with Diafaan SMS Server to send an email message. This simple script uses the System.Net.Mail namespace to send messages to the How to... 73 2009-2014 Diafaan communication software email address in the toAddress field of the message. Script The only adaptation to the skeleton script is in the headers and the OnMessageToSend event: C# script: using System.Net.Mail; private void OnMessageToSend(string recordId, string toAddress, string fromAddress, string message, string messageType) { string smtpHostName = "smtp.host.com"; string defaultFromAddress = "[email protected]"; string defaultFromName = "Sender Name"; string[] messageLines; SmtpClient smtpClient; MailAddress from; MailAddress to; MailMessage emailMessage;
try { smtpClient = new SmtpClient(smtpHostName); if (fromAddress == "") { from = new MailAddress(defaultFromAddress, defaultFromName, System.Text.Encoding.UTF8); } else { from = new MailAddress(fromAddress, fromAddress, System.Text.Encoding.UTF8); } to = new MailAddress(toAddress); emailMessage = new MailMessage(from, to); messageLines = message.Split(new char[] {'\n','\r'}, StringSplitOptions.RemoveEmptyEntries); if (messageLines.Length > 0) emailMessage.Subject = messageLines[0]; emailMessage.SubjectEncoding = System.Text.Encoding.UTF8; emailMessage.Body = message; emailMessage.BodyEncoding = System.Text.Encoding.UTF8; smtpClient.Send(emailMessage); PostSendResult(recordId, "", StatusCode.Sent, "Success: Message accepted by the SMTP server", "", "", false); } catch (Exception e) { PostSendResult(recordId, "", StatusCode.SendError, "Error: " + e.Message, "", "", false); } } Visual Basic .NET script: Imports Microsoft.VisualBasic Imports System.Net.Mail Private Sub OnMessageToSend(recordId As String, toAddress As String, _ fromAddress As String, _ message As String, messageType As String) Dim smtpHostName As String = "smtp.host.com" Dim defaultFromAddress As String = "[email protected]" Dim defaultFromName As String = "Sender Name" Dim messageLines As String() Diafaan SMS Server 2.1.5 Manual 74 2009-2014 Diafaan communication software Dim smtpClient As SmtpClient Dim from As MailAddress Dim [to] As MailAddress Dim emailMessage As MailMessage Try smtpClient = New SmtpClient(smtpHostName) If fromAddress = "" Then from = New MailAddress(defaultFromAddress, defaultFromName, _ System.Text.Encoding.UTF8) Else from = New MailAddress(fromAddress, fromAddress, System.Text.Encoding.UTF8) End If [to] = New MailAddress(toAddress) emailMessage = New MailMessage(from, [to]) messageLines = message.Split(New Char() {ControlChars.Lf, ControlChars.Cr}, _ StringSplitOptions.RemoveEmptyEntries) If messageLines.Length > 0 Then emailMessage.Subject = messageLines(0) End If emailMessage.SubjectEncoding = System.Text.Encoding.UTF8 emailMessage.Body = message emailMessage.BodyEncoding = System.Text.Encoding.UTF8 smtpClient.Send(emailMessage) PostSendResult(recordId, "", StatusCode.Sent, _ "Success: Message accepted by the SMTP server", _ "", "", False) Catch e As Exception PostSendResult(recordId, "", StatusCode.SendError, "Error: " & e.Message, _ "", "", False) End Try End Sub If you make any change to the script make sure that the PostSendResult is always called, even if an exception is caused. Otherwise the script will only continue with the next message after a timeout of several minutes. How to... 75 2009-2014 Diafaan communication software 3.8.2 Connector scripting examples 3.8.2.1 Auto reply SMS messages Learn how to use a C# or Visual Basic .NET script with Diafaan SMS Server to send an automatic reply to a received SMS message. This simple script sends a reply message every time an SMS message is received. Script The only adaptation to the skeleton script is in the OnMessageReceived event: C# script: private void OnMessageReceived(string fromAddress, string toAddress, string message, string messageType, string messageId, string smsc, string pdu, string gateway, DateTime sendTime, DateTime receiveTime) { PostSendMessage(fromAddress, "", "We have received your message.", "sms.text", "", "", ""); } Visual Basic .NET script: Private Sub OnMessageReceived(fromAddress As String, toAddress As String, _ message As String, messageType As String, _ messageId As String, smsc As String, _ pdu As String, gateway As String, _ sendTime As DateTime, receiveTime As DateTime) PostSendMessage(fromAddress, "", "We have received your message.", _ "sms.text", "", "", "") End Sub If you want to be sure the message is sent with the same (GSM Modem) gateway that received the message, add the gateway name to the PostSendMessage method: C# script: private void OnMessageReceived(string fromAddress, string toAddress, string message, string messageType, string messageId, string smsc, string pdu, string gateway, DateTime sendTime, DateTime receiveTime) { PostSendMessage(fromAddress, "", "We have received your message.", "sms.text", gateway, "", ""); } Visual Basic .NET script: Private Sub OnMessageReceived(fromAddress As String, toAddress As String, _ message As String, messageType As String, _ messageId As String, smsc As String, _ pdu As String, gateway As String, _ sendTime As DateTime, receiveTime As DateTime) PostSendMessage(fromAddress, "", "We have received your message.", _ Diafaan SMS Server 2.1.5 Manual 76 2009-2014 Diafaan communication software "sms.text", gateway, "", "") End Sub IV Reference Diafaan SMS Server 2.1.5 Manual 78 2009-2014 Diafaan communication software 4 Reference 4.1 General options Administrator Set the full name and/or password for the administrator (admin) account. The admin account is used in the web application and the HTTP API of the Web Connector. Localization In the localization settings the date and time format that is used in Diafaan SMS Server can be changed. The Date and time format is used in all situations where the date and time is used in combination. The Date format and Time format values are used for date only and time only fields. Reference 79 2009-2014 Diafaan communication software Email alerts Log error events to email Check this option if you want to receive an email alert if an error is added to the event log. To prevent an avalanche of email messages after repeated errors are generated, the number of emails can be limited to one email in a predefined time span. Event log filter In the Email Message Template the email fields for the alert email can be changed and a filter can be set to limit the events for which an email alert is sent. The Event(s) field filters on the event text and the Source(s) field filters on the name of the gateway or connector. Both fields can contain multiple filters Diafaan SMS Server 2.1.5 Manual 80 2009-2014 Diafaan communication software with wildcards (separated by semicolons) and it is possible to use a regular expression when the field starts with the keyword regex: (when a match is found) or -regex: (when no match is found). Examples for the Event(s) field Allow events that contain the text "Timeout" (wildcard filters are case insensitive): *timeout* Allow events that contain the text "Timeout" or "Reset": *timeout*;*reset* Allow events that do not contain the text "Timeout" or "Reset": -*timeout*;*reset* Allow events that start with the text "Reset" using a regular expression (regex filters are case sensitive): regex:^Reset.* HTTP callbacks Only available in Diafaan SMS Server - basic and full editions. See Use HTTP callbacks for the HTTP specifications Enable HTTP callbacks Check this option to enable HTTP callbacks in Diafaan SMS Server. This setting enables all HTTP callbacks for individual messages and events and also enables user authentication callbacks when the connector supports it. HTTP Client Use the full HTTP client only when the HTTP callbacks don't work with the minimal HTTP client. The minimal HTTP client is much faster but lacks advanced features like automatic proxy server detection and may not be compatible with all web servers. Message out Use an HTTP callback for each outgoing message before it is added to the message queue. Reference 81 2009-2014 Diafaan communication software Message in Use an HTTP callback for each received message before it is added to the message queue. Message log Use an HTTP callback for each message result and message result update or delivery report. Event log items Use an HTTP callback for all event log items.
Logging Log database maintenance If the Limit to option is selected the number of log items in the Send Log, Receive Log and Event Log is limited to a fixed number of records. If the internal log database, and specifically the send log table, is getting too large, updating and viewing the logs will get gradually slower and a fixed log limit helps to prevent this. An alternative to a fixed log length is to periodically remove older items from the database. If the remove log items option is checked, the oldest items are cleared from the database once a day. If you send tens of thousands of messages a day and are not very interested in the log, the time period can be set on 7 days or less. If you do not send large amounts of messages a day, the time period can be set to 6 months or one year. You can make a backup copy of the removed records by checking the save removed items option. Advanced Diafaan SMS Server 2.1.5 Manual 82 2009-2014 Diafaan communication software Resend wait time If the message failed, wait x seconds before it is send again. Re-assign gateways Check this option if you want to re-assign the (possible) gateways to all messages in the send queue after each configuration change. If the option is not enabled then the new gateway configuration will only be applied to new messages. If there are a large number of messages in the send queue it may take a long time to assign the new gateway list to each message after each time the gateway- or connector properties are changed. It is advised to use this option only for situations where the number of messages in the send queue is limited. Gateway unavailability timeout Set the timeout, in minutes, when a gateway that is (temporarily) down is considered as permanently unavailable. When the gateway is unavailable, messages that are routed through this gateway are flagged as failed. When the gateway is down but not yet unavailable, the pending messages are kept in the send queue until the gateway is working again. Reference 83 2009-2014 Diafaan communication software 4.2 Gateway properties General properties The gateway name is used to identify the gateway and to route messages through a specific gateway. If you want to temporarily disable the gateway or set the gateway to send or receive only you can set the appropriate options here. Gateway specific properties GSM Modem gateway Clickatell gateway SMPP gateway (basic and full editions only) Paging gateway (basic and full editions only) Scripting gateway (basic and full editions only) Diafaan SMS Server 2.1.5 Manual 84 2009-2014 Diafaan communication software 4.2.1 GSM Modem gateway GSM Modem properties COM Port Select the name of the serial port where the GSM modem is connected. If the GSM modem is connected to a USB port you must select the name of the virtual COM port of the USB port driver. Baudrate Select the baudrate (speed) for the serial port. Often the baudrate is detected automatically by the GSM modem but some GSM modems require a fixed baudrate. TCP/IP connected modems The GSM Modem Gateway can directly use GSM modems connected over an Internet TCP/IP connection, without the need for additional drivers. To use a TCP/IP connected GSM modem select TCP/IP from the COM port list and enter the host name or IP number and the attached port number. The GSM Modem Gateway can use a raw TCP/IP connection or a Telnet connection to the modem. PIN code Type the PIN code of the SIM card. Using a PIN code on your SIM card is not recommended. If your SIM card does not have a PIN code you can leave this field empty. Advanced properties LogCommunicationToFile Log all modem communication to file. Use this option only if you encounter problems with the GSM modem. If enabled, the status windows of the GSM modem provides a link to the location on you hard disk where the file is stored. MaximumBatchSize The maximum number message this gateway will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the gateway loads multiple messages concurrently. This can increase the speed in which the messages are processed but it also might prevent normal load balancing for multiple GSM modems. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. NumberWhiteList List of allowed mobile numbers for received SMS messages, messages from other numbers are blocked. When the list does not have any items received SMS messages from all numbers are allowed. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. CompatibilityMode Besides Normal Mode, two other compatibility mode options are available when you encounter problems with the operation of your GSM modem, Basic PDU Mode and Basic Text Mode. Basic PDU Mode is a minimal implementation of the GSM 07.05 PDU standard. Only the necessary Reference 85 2009-2014 Diafaan communication software modem commands are used and options like delivery confirmation or signal quality are not supported. In this mode you will have to set the value for the SMSC number manually since the software will not query the GSM modem for the right SMSC number. Basic Text Mode is a minimal implementation of the GSM 07.05 text mode standard. Support for unicode characters or binary messages is not available. Use this mode only if your GSM modem does not support PDU mode, some CDMA modems for instance can send and receive SMS messages in text mode only. ModemInitializationBeginning Additional modem initialization. This modem command is sent to the GSM modem before the rest of the initialization. A possible use for this property is the modem command to select the GSM operator you want to use. E.g. if the network operator code is 26202 (Vodafone Germany) the modem command is: AT+COPS=1,2,26202 ModemInitializationEnd Additional modem initialization. This modem command is sent to the GSM modem after the rest of the initialization. ModemLogon Logon parameters for TCP/IP modems that require a clear text logon procedure before it can be used to send and receive SMS messages. The logon parameter consist of multiple pairs of a trigger and response text separated by semicolons, the trigger and response parameter is separated by a "@" character. The GSM modem gateway waits for the trigger and sends the response when the trigger is received. If all triggers are handled, the modem is expected to be available to send and receive SMS messages. An example ModemLogon for the PORTech MV-370 modem is: username:@voip;password:@1234;]@module1;got!! This means: Wait for "username:" and send "voip" to the modem. Wait for "password:" and send "1234" to the modem. Wait for "]" and send "module1" to the modem. Wait for "got!!", the modem is now available to send and receive SMS messages. ModemReboot The modem reboot command, default value is the AT+CFUN=1,1 command for a full reboot. Not all modems support a full reboot of the modem. ModemRebootTime After a modem reboot command the GSM modem needs some time for the reboot to complete and to reconnect to the mobile network. The ModemRebootTime specifies the number of seconds before the GSM Modem Gateway sends the next command. PermitModemCommandMesasages Permit messages with message type "modem.command", the text of the message is executed as an AT command on the modem. RebootAfterNetworkFailure If the GSM modem gateway is active, every 10 minutes the gateway queries the signal strength and network status of the GSM modem. If RebootAfterNetworkFailure is enabled the gateway sends a hard reset to the GSM modem when no GSM network is detected (rssi 99) or when it is not logged on to the GSM network. RebootAfterNetworkRoaming Reboot GSM modem when the modem reports it is not logged on to the home network but is roaming on another network. Diafaan SMS Server 2.1.5 Manual 86 2009-2014 Diafaan communication software RebootAfterReceiveError Send the reboot command to the GSM modem if an error is reported after a receive SMS or delete received SMS command. This is often an indication of a network or GSM modem problem and can sometimes be resolved by a modem reboot. RebootAfterSendError Send the reboot command to the GSM modem if an error is reported after a send SMS command. This is often an indication of a network or GSM modem problem and can sometimes be resolved by a modem reboot. RebootAfterTimeout Send the reboot command to the GSM modem if no valid response to a modem command was received after a certain timeout. If supported by the GSM modem it will restart the connection to the GSM network. RebootBeforeInitialization Send the reboot command to the GSM modem every time the modem is initialized. This setting is useful if the modem sometimes does not recover from an internal error state. RebootDaily Send the reboot command to the GSM modem once every day. Use this only if the GSM modem starts getting problems when it runs for long periods. ReceivePollAfterMaximumSendBatch The maximum number of SMS messages that are sent immediately after each other before the GSM modem is checked for new received messages. ReceivePollIntervalTime The time (in seconds) between each check for new received messages when the GSM modem is not sending a message. ReportCallerIdentification Get the caller identification of normal (voice) phone calls to the modem and forward them as received SMS messages with message type gsm.cli. ReportCallerIdentificationHangup Send a hangup command (ATH0) to the modem when an incoming phone call is detected. SendDelayTime Time (in seconds) between sending two consecutive SMS messages. This option can be used to delay sending of the messages if the mobile network is not able to process the messages fast enough. SendLimit The maximum number of message parts the GSM Modem Gateway sends per whole hour, day, week or month. 100H means 100 message parts per hour, 300D 300 message parts per day, 1000W 1000 message parts per week and 1000M 1000 message parts per month. When the maximum number of messages is reached, the GSM Modem Gateway will pause message sending until the start of the next time period. The Gateway is not considered down during this period and messages are still received by the gateway. SMSOverGPRS Some GSM operators support sending SMS messages over a GPRS connection. If enabled this will speed up the sending messages considerably. Most GSM operators do not support SMS over GPRS or have only limited support. Sending messages will fail if this option is enabled and the GSM operator does not support it. Reference 87 2009-2014 Diafaan communication software DataBits Serial port data bits. default is 8. FlowControl Serial port flow control, default is None. Parity Serial port parity. default is no parity. StopBits Serial port stop bits. default is 1. GSMNumber The mobile phone number of the SIM card (optional). This number is only used to identify which GSM modem received an SMS message. If this value is set, it overrides the GSM number found on the SIM card. SMSCNumber The SMS Central number is the address of the SMS Central of your GSM operator. This number must be in international format, e.g. +491722270333 for the German Vodafone SMSC and is necessary if you want to send SMS messages. If this value is set, it overrides the SMSC number found on the SIM card. CombineMultiPartMessage If enabled, partial messages received on the GSM modem are combined to the original message length. Since delivery of some message parts might be delayed this could mean that the delivery of the whole message will be delayed. If, after a certain timeout, not all message parts are received, the partial messages are delivered individually. If disabled the partial messages are delivered individually. CombineMultipartMessages can also be set to Binary. In this mode the received messages are not decoded and combined but forwarded as message type sms.binary with the message field set to <DCS>,<PID>,<UDL>,<UDH>,<Data>. This may be useful if you intend to use Diafaan SMS Server to retransmit the messages unaltered to one or more alternative receivers. DefaultAddressType The address type used for mobile numbers that do not start with a + (international), # (national) or * (unknown). Most mobile operators prefer numbers in the International number format address type. DeliveryConfirmation Require status updates for the SMS messages after it is sent to the SMSC. If you do not need to know if the SMS messages are delivered on the GSM phone or if the status updates causes errors sending the messages you can disable status updates. MaxMessageParts Messages to send that are longer than 160 characters or 70 characters for unicode messages can be split in multiple SMS messages that are recombined to one message on the handset of the receiver. The MaxMessagePart property limits the amount of partial messages that the gateway sends with a long message. If the message is longer than can be sent with the maximum message parts, the rest of the message is discarded. MaxShortCodeLength The maximum number length where the number is regarded as a short code, short codes are encoded as Network Specific numbers. MessageType The message type is the default value for the SMS message encoding, the default value may be Diafaan SMS Server 2.1.5 Manual 88 2009-2014 Diafaan communication software replaced with the message type specified by the sending Connector. The gateway uses four possible value for the default message type: Automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. StandardText The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. Unicode All messages are sent in Unicode 16-bit encoding. Data All messages are sent in binary 8-bit encoding. The GSM Modem gateway supports the following custom message types: sms.automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode The message is sent in Unicode 16-bit encoding. sms.binary The message is sent in binary 8-bit encoding. sms.automatic.flas h Flash SMS, standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text.flash Flash SMS, the default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode.flash Flash SMS, all messages are sent in Unicode 16-bit encoding. gsm.ussd Send a USSD command to the GSM operator (e.g. *101#). The response is sent as a received SMS message. ValidityPeriod The validity period of sent messages, specified in number of days (1-30) or as hexadecimal value (0x00-0xFF). The hexadecimal values translate to the following validity period: 0x00 - 0x8F (Value + 1) x 5 minutes (i.e. 5 minutes intervals up to 12 hours) 0x90 - 0xA7 12 hours + ((Value -143) x 30 minutes) 0xA8 - 0xC4 (Value - 166) x 1 day 0xC5 - 0xFF (Value - 192) x 1 week *Value is the decimal value of the hexadecimal number Reference 89 2009-2014 Diafaan communication software 4.2.2 Clickatell gateway Clickatell properties API id The HTTP API ID of your Clickatell http account. Username The user name of your Clickatell account. Password The password of your Clickatell account. Advanced properties ApprovedFromList Clickatell supports both numeric and text sender id's. To prevent spoofing, Clickatell requires that sender id's have to be approved by them before you can use them. To use an originator you have to list them here, one originator per line. All originator addresses that are not in this list are filtered out by the Clickatell gateway. DefaultFrom If no originator is supplied or the originator is not in the ApprovedFromList this default originator will be used. HttpHost The Clickatell host name. Both secure and unsecured connections are supported. https://api.clickatell.com secure Clickatell host. http://api.clickatell.com unsecured Clickatell host. HttpParameters Optional extra parameters that are used when sending an SMS message to Clickatell. An example is the parameter MO=1, an indication that the message is Mobile Originated and that the receiver can send a response back. LogCommunicationToFile Log all internet communication to file. Use this option only if you encounter problems with the connection to your Clickatell account. If enabled, the status windows of the Clickatell gateway provides a link to the location on you hard disk where the file is stored. MaximumBatchSize The maximum number of messages this gateway will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the gateway loads multiple messages concurrently. This increases the speed in which the messages are sent. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. Diafaan SMS Server 2.1.5 Manual 90 2009-2014 Diafaan communication software MaxMessageParts Messages to send that are longer than 160 characters or 70 characters for Unicode messages can be split in multiple SMS messages that are recombined to one message on the handset of the receiver. The MaxMessagePart property limits the amount of partial messages that the gateway sends with a long message. If the message is longer than can be sent with the maximum message parts, the rest of the message is discarded. MessageType The message type is the default value for the SMS message encoding, the default value may be replaced with the message type specified by the sending Connector. The gateway uses four possible value for the default message type: Automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. StandardText The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. Unicode All messages are sent in Unicode 16-bit encoding. Data All messages are sent in binary 8-bit encoding. The Clickatell gateway supports the following custom message types: sms.automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode The message is sent in Unicode 16-bit encoding. sms.binary The message is sent in binary 8-bit encoding. sms.automatic.flas h Flash SMS, standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text.flash Flash SMS, the default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode.flash Flash SMS, all messages are sent in Unicode 16-bit encoding. Reference 91 2009-2014 Diafaan communication software 4.2.3 SMPP gateway Only available in Diafaan SMS Server - basic and full editions. SMPP server properties Host or IP number The host name or IP number of the SMPP server. Server port The port number of the SMPP server. Port number 2775 is the default port for the SMPP protocol but other port numbers are also common. SMPP version Most SMPP servers support both version 3.3 and 3.4 of the SMPP protocol. Some advanced features of the protocol are only supported in version 3.4 but basic messaging is the same for both versions. . User name The user name (or System ID) of your SMPP account. Password The password of your SMPP account. Default source address Some SMPP operators require that you send a source address or sender id with each message. The default source address will be used for each message where the user does not provide a source address. Users can override the default source address If you do not want users to send their own source addresses with the messages you can disable this option here. Some SMPP operators block messages with an unapproved source address, in the ApprovedSourceAddress property in the advanced settings you can provide a list with valid source addresses. Diafaan SMS Server 2.1.5 Manual 92 2009-2014 Diafaan communication software Advanced properties LogCommunicationToFile Log all internet communication to file. Use this option only if you encounter problems with the connection to your SMPP account. If enabled, the status windows of the SMPP gateway provides a link to the location on you hard disk where the file is stored. MaximumBatchSize The maximum number of messages this gateway will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the gateway loads multiple messages concurrently. This increases the speed in which the messages are sent. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. NumberWhiteList List of allowed mobile numbers for received SMS messages, messages from other numbers are blocked. When the list does not have any items received SMS messages from all numbers are allowed. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. AsyncModeWindowSize If this property is set to a value higher than 1, the SMPP gateway does not wait for a response from the SMPP server before the next message is sent. This can increase message throughput considerably but if the AsyncModeWindowSize is set too high or if the SMPP server does not support asynchronous mode properly it can lead to overloading of the SMPP server. CharacterSetReceive The character set that the SMPP server uses for incoming text messages (not used for Unicode or data messages). Use ISO-8859-1 or ISO-8859-15 when the '@' character is not displayed properly. Reference 93 2009-2014 Diafaan communication software CharacterSetSend The character set for outgoing text messages. Use IA5, ISO-8859-1 or ISO-8859-15 when the '@' character is not displayed properly. CharacterSetSendDCS The Data Coding Scheme (DCS) for outgoing text messages. Default value is 0 for the default character set, 3 for ISO-8859-1/ISO-8859-15. HexMessageId Assume hexadecimal Message ID field for SMPP 3.4. Setting this option to True will translate the Message ID from a hexadecimal value to a numeric value and treat the Message ID in a receipt as a numeric value. KeepAliveInterval The SMPP Gateway sends an enquire_link message to the SMPP server after a period of inactivity to keep the connection to the SMPP server intact. If the SMPP server keeps breaking the connection after a certain time the timeout interval can be set here. MaxMessagesPerMinute The MaxMessagesPerMinute property limits the amount of messages that the SMPP Gateway will send each minute. Some SMPP servers enforce a strict message throttling and sending more messages then are allowed might actually decrease message throughput. SystemType The system type is a text that the SMPP Gateway sends to the SMPP server to signal what sort of service it is. Some SMPP servers require a specific system type value. TransceiverMode By default, the SMPP Gateway starts up two connections to the SMPP server., one for sending messages and one for receiving messages. SMPP version 3.4 supports a transceiver mode where one connection is used for both sending and receiving messages. UsePayloadTLV In SMPP version 3.3 long SMS messages must be broken up in multiple segments before they are sent to the SMPP server. SMPP version 3.4 supports an additional Payload parameter that can be used to send a long SMS message in one segment. Not all SMPP servers support the Payload parameter, even when they do support SMPP version 3.4. ValidityPeriod The validity period of sent messages, specified as a relative date and time in the format YYMMDDhhmmss000R. E.g. 000003000000000R specifies a validity period of 3 days. Leave empty for the default validity period of the SMPP server. ApprovedSourceAddressList SMPP supports both numeric and text source addresses. To prevent spoofing, some SMPP operators require that source addresses have to be approved before you can use them. the ApprovedSourceAddressList can contain a list of valid source addresses, if the source address is not in the list the default source address is used instead. If the ApprovedSourceAddressList is empty all source addresses are valid. CombineMultiPartMessage If enabled, partial received messages are combined to the original message length. Since delivery of some message parts might be delayed this could mean that the delivery of the whole message will be delayed. If, after a certain timeout, not all message parts are received, the partial messages are delivered individually. If disabled, the partial messages are delivered individually. Diafaan SMS Server 2.1.5 Manual 94 2009-2014 Diafaan communication software CombineMultipartMessages can also be set to Binary. In this mode the received messages are not decoded and combined but forwarded as message type sms.binary.smpp with the message field set to <DCS>,<PID>,<ESMCLASS>,<UDH>,<Data>. This may be useful if you intend to use Diafaan SMS Server to retransmit the messages unaltered to one or more alternative receivers. DefaultAddressType The address type (TON) that is used when no specific address type is detected. The detection of the address type is as follows: If the address starts with a + it is regarded as an international phone number (TON 1 and NPI 1). If characters are detected it is an alphanumeric source address (TON 5 and NPI 0) If it has less than MaxShortCodeLength numbers it is a shortcode (TON 3 and NPI 1) The default address type value is used with NPI 1. DeliveryConfirmation Require status updates for the SMS messages after it is sent to the SMSC. If you do not need to know if the SMS messages are delivered on the mobile phone you can disable status updates here. MaxMessageParts Messages to send that are longer than 160 characters or 70 characters for unicode messages can be split in multiple SMS messages that are recombined to one message on the handset of the receiver. The MaxMessagePart property limits the amount of partial messages that the gateway sends with a long message. If the message is longer than can be sent with the maximum message parts, the rest of the message is discarded. MaxShortCodeLength The maximum number length where the number is regarded as a short code, short codes are encoded as Network Specific numbers. MessageType The message type is the default value for the SMS message encoding, the default value may be replaced with the message type specified by the sending Connector. The gateway uses four possible value for the default message type: Automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. StandardText The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. Unicode All messages are sent in Unicode 16-bit encoding. Data All messages are sent in binary 8-bit encoding. The GSM Modem gateway supports the following custom message types: sms.automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode The message is sent in Unicode 16-bit encoding. sms.binary The message is sent in binary 8-bit encoding. sms.automatic.flas h Flash SMS, standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text.flash Flash SMS, the default 7-bit GSM SMS character set is used, all other characters are converted to question marks. Reference 95 2009-2014 Diafaan communication software ReceiptHandling This option changes the way SMPP receipts for previously sent messages are handled. Default Only set the Status Code, Status Text and, in case of an error, Error Code and readable Error Text. WriteToErrorText The same as Default, in case of error, write the full receipt to the Error Text . HandleAsReceived Message Handle the receipt as a received SMS message with message type smpp.receipt. HandleAsReceived MessageWithTLV Handle the receipt as a received SMS message with message type smpp.xml.receipt and formatted as an XML message with all TLV parameters of the SMPP packet. Diafaan SMS Server 2.1.5 Manual 96 2009-2014 Diafaan communication software 4.2.4 Paging gateway Only available in Diafaan SMS Server - basic and full editions. Service list In the Service list tab page you can add, edit or remove the paging services. If one of the services uses a modem you must also provide the COM port where the modem is connected to. Default All services must have a different Message Type. The Message Type is used to determine which service is used to send the message. The Default button can be used to change the default service that is used to send the message when no corresponding Message Type is found within the message. Service Each service must have a Name and a Message Type. The Message Type is only relevant if the Paging Gateway has more than one service. Number template The number template can be used to translate the number from one format to another. For more information see Use number templates. TAP over modem Access Number The Access Number is the phone number used to connect to the TAP service. Password Some TAP Services require a password to accept messages. Reference 97 2009-2014 Diafaan communication software Limit to This value limits the number of messages sent within 1 phone call. If you know that the TAP service accepts more messages per connection you can change this number. Modem settings Most TAP services need a connection with 7 data bits, 1 stop bit and even parity. Sometimes it is necessary to set the baudrate to a lower value of 300, 1200 or 2400. UCP over modem Access Number The Access Number is the phone number used to connect to the UCP service. Password Some UCP Services require a password to accept messages. Limit to This value limits the number of messages sent within 1 phone call. If you know that the UCP service accepts more messages per connection you can change this number. Modem settings Most UCP services need a connection with 8 data bits, 1 stop bit and no parity. UCP over the Internet Host name or IP The host name or IP number used to connect to the UCP service. Port Enter the port number of the UCP service here, there is no standard port number for UCP services. Password Some UCP Services require a password to accept messages. Limit to This value limits the number of messages sent within 1 phone call. If you know that the TAP service accepts more messages per connection you can change this number. SMTP over the Internet Host name or IP The host name or IP number used to connect to the email service. Port Enter the port number of the email service here, the standard SMTP port is 25. User name and Password If the SMTP server requires a user name and password you can enter them here. Start TLS and SSL If the SMTP server requires a secure connection you can enter them here. Password Some UCP Services require a password to accept messages. SNPP over the Internet Host name or IP Diafaan SMS Server 2.1.5 Manual 98 2009-2014 Diafaan communication software The host name or IP number used to connect to the SNPP service. Port Enter the port number of the SNPP service here, the standard SNPP port is 444. Login ID and Password If the SNPP server requires a user name and password you can enter them here. Limit to This value limits the number of messages sent within 1 phone call. If you know that the SNPP service accepts more messages per connection you can increase this number. WCTP over the Internet Host URL Provide the full URL of the WCTP host. Diafaan SMS Server supports both unsecure (http://) and secure (https://) connections. Sender ID and Password If the WCTP server requires a user name and password you can enter them here. Some WCTP servers require a password in the miscInfo field and some in the securityCode field. DTD URL If the WCTP server requires a specific DTD URL you can enter it here. Modem command The Modem command is not a real protocol but can be used to send a specific AT command to the modem. It can be used to query the modem state or to send a specific instruction to the modem (for instance a watchdog command). When you send a message to the Modem command service the To field must contain the AT command. The modem response is stored in the Status Text of the result. Advanced properties LogCommunicationToFile Log all internet communication to file. Use this option only if you encounter problems with one of the services. If enabled, the status windows of the Paging gateway provides a link to the location on you hard disk where the file is stored. SendFromAddress Allow sending the from address with the messages if the protocol supports a sender ID. ModemInitialization The AT modem command used to initialize the modem. If a special initialization command for only one of the services you can add an extra initialization in the Paging or SMS Service properties. ModemReset The AT modem command used to reset the modem. Reference 99 2009-2014 Diafaan communication software 4.2.5 Scripting gateway Only available in Diafaan SMS Server - basic and full editions. Edit gateway script Click on the Edit C# Script or Edit Visual Basic .Net Script link to edit the script. Use the Compile button to check if the script has syntax errors. If the script uses functions that are not in the System.dll assembly, a reference to the required assembly DLL must be added in the Advanced ReferenceList property. Advanced properties LogCommunicationToFile Log all trace log communication to file. You can use this option in combination with the PostTraceLog script function to debug your script. If enabled, the status windows of the Scripting gateway provides a link to the location on the hard disk where the file is stored. MaximumBatchSize The maximum number of messages this gateway will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the gateway loads multiple messages concurrently. This increases the speed in which the messages are sent. Leave the MaximumBatchSize on 1 if the script is processor heavy or takes a long time to send a message (more than a few seconds). For small scripts you can increase this value to speed up handling multiple messages. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. ReferenceList A list of all assembly DLL's required by the script. For the skeleton script, only the System.dll assembly is loaded. Possible useful .NET assemblies are: Diafaan SMS Server 2.1.5 Manual 100 2009-2014 Diafaan communication software System.Web.dll Classes for web or html functions. System.Data.dll Classes to handle database requests. System.XML.dll Classes to handle XML files. Gateway skeleton script The gateway skeleton script that is installed after adding the gateway makes it easier to handle events and provides a number of methods you can use to send messages, enter received messages and add log entries. Events OnMessageToSend is called when there is a message the script should send out. OnStatusRequest is called when the script should query the status of a previously sent message. Methods PostSendResult sets the send result of a previous handled OnMessageToSend message. PostSendResultUpdate updates the send result of a previously handled OnMessageToSend message. PostDispatchMessage dispatches the OnMessageToSend message to a different gateway. PostReceiveMessage adds a new received message. PostEventLog adds a line to the event log. PostTraceLog Adds a line to the communication file. Reference 101 2009-2014 Diafaan communication software 4.2.6 Hypermedia SMS PRO gateway Only available in Diafaan SMS Server - basic and full editions. SMS PRO Gateway properties Host or IP number Enter the host name or IP number of the Hypermedia SMS PRO gateway. Server port The port number of the Hypermedia SMS PRO gateway. Port number 63333 is the default port for the device. Client ID A unique Client ID (user name), the Client ID can be freely chosen by the user. If another client logs in with the same ID as an existing client then the new client will cause the disconnection of the old client and a message will be sent to each indicating this, therefore it is recommended that each new client that connects to the gateway should use a unique ID. Note that if no ID is given, a unique ID will be generated for the client by the gateway. Password The password of the Hypermedia SMS PRO gateway. SIM card routing properties Use all SIM cards in the SMS PRO Gateway Use all SIM cards in the SMS PRO Gateway to send and receive SMS messages. Use SIM cards: Enter a list with all SIM cards in the Hypermedia SMS PRO Gateway you want to use to send and receive SMS messages. Click the Update button to refresh the available SIM card list. The SIM card list may contain multiple SIM cards separated by semicolons, e.g. <21#1>;<21#2> You can assign a GSM number to each SIM card that is inserted in the To field of received messages, e.g. +11111111111 <21#1>;+22222222222 <21#2> Advanced properties LogCommunicationToFile Log all internet communication to file. Use this option only if you encounter problems with the connection to your SMPP account. If enabled, the status windows of the SMPP gateway provides a link to the location on you hard disk where the file is stored. MaximumBatchSize The maximum number of messages this gateway will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the gateway loads multiple messages concurrently. This increases the speed in which the messages are sent. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. NumberWhiteList List of allowed mobile numbers for received SMS messages, messages from other numbers are blocked. When the list does not have any items received SMS messages from all numbers are allowed. Diafaan SMS Server 2.1.5 Manual 102 2009-2014 Diafaan communication software EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. DeliveryConfirmation Require status updates for the SMS messages after it is sent to the SMSC. If you do not need to know if the SMS messages are delivered on the GSM phone or if the status updates causes errors sending the messages you can disable status updates. MaxMessageParts Messages to send that are longer than 160 characters or 70 characters for unicode messages can be split in multiple SMS messages that are recombined to one message on the handset of the receiver. The MaxMessagePart property limits the amount of partial messages that the gateway sends with a long message. If the message is longer than can be sent with the maximum message parts, the rest of the message is discarded. MessageType The message type is the default value for the SMS message encoding, the default value may be replaced with the message type specified by the sending Connector. The gateway uses four possible value for the default message type: Automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. StandardText The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. Unicode All messages are sent in Unicode 16-bit encoding. Data All messages are sent in binary 8-bit encoding. The GSM Modem gateway supports the following custom message types: sms.automatic Standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text The default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode The message is sent in Unicode 16-bit encoding. sms.binary The message is sent in binary 8-bit encoding. sms.automatic.flas h Flash SMS, standard Text encoding is the default, Unicode encoding will be used only if the message contains characters that are not in the default GSM SMS character set. sms.text.flash Flash SMS, the default 7-bit GSM SMS character set is used, all other characters are converted to question marks. sms.unicode.flash Flash SMS, all messages are sent in Unicode 16-bit encoding. ValidityPeriod The validity period of sent messages, specified in number of days (1-30) or as hexadecimal value (0x00-0xFF). The hexadecimal values translate to the following validity period (Value is the decimal value): 0x00 - 0x8F (Value + 1) x 5 minutes (i.e. 5 minutes intervals up to 12 hours) 0x90 - 0xA7 12 hours + ((Value -143) x 30 minutes) 0xA8 - 0xC4 (Value - 166) x 1 day 0xC5 - 0xFF (Value - 192) x 1 week Reference 103 2009-2014 Diafaan communication software AdditionalMessageParameters List of additional Hypermedia SMS PRO API message parameters, separated by semicolons. The parameter consists of a parameter name and a value, separated by a colon (':'). The value is a hexadecimal encoded representation of the information, for example '1' must be encoded as '31' and 'abcd' must be encoded as '61626364'. Examples: Set priority to 1: priority:31 Set queue type to 'master': queue_type:6d6173746572 Set both options: priority:31;queue_type:6d6173746572 Diafaan SMS Server 2.1.5 Manual 104 2009-2014 Diafaan communication software 4.3 Connector properties General properties If you want to temporarily disable the connector or set the connector to send or receive only you can set the appropriate options here. Gateway routing properties For each available gateway you can choose if you want to use the gateway to send and receive messages, send or receive only or not at all. You can assign the gateway as a primary gateway or as a backup gateway. Diafaan SMS Server will first try to send the message with one of the assigned primary gateways. If sending the message failed it will be repeated with a maximum of Max send Attempts for each primary gateway. If sending the message is still not successful on all primary gateways, the same procedure is used with the assigned backup gateway(s). Reference 105 2009-2014 Diafaan communication software Connector specific properties Web connector Email connector SQL connector Scripting connector Diafaan SMS Server 2.1.5 Manual 106 2009-2014 Diafaan communication software 4.3.1 Web connector HTTP server properties Check Enable HTTP Server to start the web server on the requested port. Enable Web Application API The Web Application API gives access to the SMS client web application. With the web application one (light edition) or more (basic- and full editions) users can send SMS messages, view received SMS messages and maintain a contact list using any modern Internet browser. It is possible use the HTML files in the data folder of the Web Connector instead of the built-in HTML files. This makes it possible to translate the web application or to apply the styling of your company. Select Show folder to see the HTML folder of the Web Connector and Refresh files to (over)write the internal files to the HTML folder. Translation to other languages All language dependent information for the web application is located in the index.html file. This is the only file that needs to be changed when you want to translate the web application in another language. If you want to support multiple languages you can copy the index.html file and give each language its own html file with another name (e.g. index-de.html, index-sp.html etc.). Be careful with changes to the HTML tags of the index.html file since this may interfere with the proper functioning of the web application . Enable HTTP API The HTTP API provides a simple way to send messages and to view received messages from a browser or external application. See the HTTP API specifications for more information about the HTTP API. If Anonymous HTTP API requests is enabled messages can be sent with the HTTP API without user name and password. In the basic and full edition of Diafaan SMS Server it is also possible to use HTTP callbacks instead of the user list from the Web Application for user verification. Reference 107 2009-2014 Diafaan communication software Receive SMS properties Forward received SMS messages to user inbox Received SMS messages can be forwarded to the inbox of the administrator and also to other users of the web application. When you create a new user in the web application you can also specify that the user will see all received messages in his or her inbox. When Reply to user is selected the web connector looks if there was a previous message sent to the mobile phone number. If there is a mobile number match, the message is sent as a reply to the inbox of the last sender of the message to that particular mobile number. Forward received SMS messages to website Enter the web page and HTTP method where you want to deliver the received SMS messages. You should also edit the query string template to indicate what parts of the received SMS messages are forwarded to the web server. Handle HTTP response The HTTP response from the web page can be used to send a reply back to the sender of the message. This option makes it possible to use PHP, ASP.NET or another web server script language to perform powerful database driver SMS queries. If the HTTP response is an empty text, no response will be sent back. The HTTP response can also be used to determine if the web page accepts the message. The Web connector will repeat the HTTP command a number of times if the supplied text is not in the HTTP response. Diafaan SMS Server 2.1.5 Manual 108 2009-2014 Diafaan communication software User privileges In situation where multiple people need to monitor the same sent- and received messages, like small call centers or customer support departments it can be useful to log in to the same user account at the same time. If you check Allow concurrent logins with the same user name and password this is possible. All information, like the sent- and received messages and the contact list are synchronized on all web browser that are logged in to the same account. For all three user types, users, supervisors and administrators, you can set the privileges that the user will have. There is no inherent difference between the three user types. you can enable or disable the same options for each user type. Reference 109 2009-2014 Diafaan communication software Maintenance Received messages that are stored in one of the inboxes and messages sent with the Web Connector are stored in a database. To limit the number of records in the database you can check the remove inbox and log items option. If checked, the oldest database records are removed once a day. You can make a backup copy of the removed records by checking the save removed items option. If the Limit inbox and send log to option is selected, the number of log items per user in the Send Log and the Inbox/Receive Log is limited to a fixed number of records. If the log database is getting too large, viewing the logs will get gradually slower and a fixed log limit helps to prevent this. Diafaan SMS Server 2.1.5 Manual 110 2009-2014 Diafaan communication software Advanced properties LogCommunicationToFile Log all internet communication to file. Use this option only if you encounter problems with the connection to the Web connector or to the external web server. If enabled, the status windows of the Web connector provides a link to the location on you hard disk where the file is stored. MaximumBatchSize The maximum number of messages this connector will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the connector loads multiple messages concurrently. This increases the speed in which the messages are processed. SendPriorityAPI Default message send priority for the HTTP API, set to 0 to allow a custom priority for individual messages. A higher number ensures that messages are placed higher in the message send queue and are sent before messages with a lower priority. SendPriorityWebApp Message send priority for the Web Application. A higher number ensures that messages are placed higher in the message send queue and are sent before messages with a lower priority. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. HTTPClientSendAttempts Maximum number of times the HTTP Client tries to deliver a received message. 2nd attempt after at least 30 seconds 3rd attempt after at least 5 minutes Reference 111 2009-2014 Diafaan communication software 4th attempt after at least 30 minutes 5th attempt after at least 1 hour 6th and further attempts after at least 12 hour HTTPServerBacklog The number of incoming HTTP connection the server accepts before denying subsequent connections. HTTPServerCertificatePassword The password of the X509 certificate used for SSL (https://) connections. HTTPServerSSLCertificate The full path and filename of the X509 (OpenSSL) certificate required to enable secure connections to the HTTP server. 4.3.1.1 HTTP API specifications HTTP commands HTTP commands can be sent with both GET or POST methods, the POST method requires a url- encoded BODY with content-type 'application/x-www-form-urlencoded '. In this manual the GET method is used for all examples. send-message Send one or more messages. parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user to required One or more phone/pager numbers, separated by semicolons contact-name required One or more contact names and/or groups from the user's contact list, separated by semicolons from optional Sender id message optional Message text message-type optional Message type to indicate if the message is text, Unicode, flash etc. gateway optional One or more gateway names, separated by semicolons, that may be used to send the message priority optional A higher number ensures that the message is placed higher in the message send queue and is sent before messages with a lower priority. returns OK: message-id or ERROR:error-code error-message If multiple messages are sent this command returns one response line per message in the order at which the numbers are located in the to and contact-name fields. Since numbers may be blocked and the contact-name can be a group, the number of return lines may be different from the number of to or contact-name entries. example http://localhost:9710/http/send-message?username=admin&password=&to=%2B44xxxxxxxx&message- type=sms.automatic&message=Message+Text request-status-update Get the status of a previously sent message. Diafaan SMS Server 2.1.5 Manual 112 2009-2014 Diafaan communication software parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user message-id mandatory Message id of the previously sent message returns STATUS:status-code status-message or ERROR:error-code error-message example http://localhost:9710/http/request-status-update?username=admin&password=&message-id=c3b0c20a- b63e-4bbf-919f-3d4251a8b9c0 remove-queued-message Remove a previously sent message from the send queue. parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user message-id mandatory Message id of the previously sent message returns OK: status-message or ERROR: error-message example http://localhost:9710/http/remove-queued-message?username=admin&password=&message- id=c3b0c20a-b63e-4bbf-919f-3d4251a8b9c0 request-server-status Get the status of the Diafaan SMS Server and all the Gateways and Connectors statistics. parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user returns An XML file with the status and statistics of Diafaan SMS Server. or ERROR:error-code error-message example http://localhost:9710/http/request-server-status?username=admin&password= request-received-messages Get a list of received messages in the inbox. parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user limit optional The maximum number of messages returned Reference 113 2009-2014 Diafaan communication software remove optional Set to "1" to remove the returned messages from the database order optional Set to "newest" to get newest messages first, otherwise oldest messages are displayed first. returns An XML file with a list of the requested messages. or ERROR:error-code error-message example http://localhost:9710/http/request-received-messages? username=admin&password=&limit=10&order=newest <?xml version='1.0' encoding='UTF-8'?> <MessageList Count="2"> <Message> <From>+44xxxxxx</From> <To /> <MessageText>Message text 1</MessageText> <MessageType>sms.text</MessageType> <MessageId>ae97a8b7-5336-445a-ae67-e658aa8f6aed</MessageId> <MessagePart>-1</MessagePart> <ReceivedMessageParts>1</ReceivedMessageParts> <TotalMessageParts>1</TotalMessageParts> <SendTime>20100219200855</SendTime> <ReceiveTime>20100219200848</ReceiveTime> <Gateway>GSM Modem Gateway</Gateway> <SMSC>+44xxxxxxxxx</SMSC> <PDU>079458560488019539B53F50000012091028055400DD47719649987CD25D87506</PDU> <IsRemoved>0</IsRemoved> </Message> <Message> <From>+33xxxxxxxx</From> <To /> <MessageText>Message text 2</MessageText> <MessageType>sms.text</MessageType> <MessageId>ae97a8b7-5336-445a-ae67-e658aa8f6aed</MessageId> <MessagePart>-1</MessagePart> <ReceivedMessageParts>1</ReceivedMessageParts> <TotalMessageParts>1</TotalMessageParts> <SendTime>20100219200855</SendTime> <ReceiveTime>20100219200848</ReceiveTime> <Gateway>GSM Modem Gateway</Gateway> <SMSC>+33xxxxxxxxx</SMSC> <PDU>07474523460488019539B53F50000012091028055400DD47719649987CD25D87506</PDU> <IsRemoved>0</IsRemoved> </Message> </MessageList> 4.3.1.2 Commandline client Commandline client Diafaan SMS Server includes a commandline client that makes use of the Web connector. It has the same functionality as the HTTP API but a different syntax. Diafaan SMS Server 2.1.5 Manual 114 2009-2014 Diafaan communication software Usage: dmscmnd.exe "key1:value1" "key2:value2" "key3:value3" ... keys: host mandatory The host name and port number of the Web Connector. Use multiple host keys/value combination for redundancy support. e.g. "host:host1:9710" "host:host2:9710" command mandatory HTTP page name, e.g. "command:send-message" Commands send-message Send one or more messages. keys username optional The name of the user, if omitted the guest account is used password optional The password of the user to required One or more phone/pager numbers, separated by semicolons contact-name required One or more contact names and/or groups from the user's contact list, separated by semicolons from optional Sender id message optional Message text message-type optional Message type to indicate if the message is text, Unicode, flash etc. gateway optional One or more gateway names, separated by semicolons, that may be used to send the message. priority optional A higher number ensures that the message is placed higher in the message send queue and is sent before messages with a lower priority. returns OK: message-id or ERROR:error-code error-message If multiple messages are sent this command returns one response line per message in the order at which the numbers are located in the to field. example dmscmnd.exe host:localhost:9710 command:send-message username:admin password: to:+44xxxxxxxx message-type:sms.automatic "message:Message Text" example with redundant host: dmscmnd.exe host:host1:9710 host:host2:9710 command:send-message username:admin password: to:+44xxxxxxxx message-type:sms.automatic "message:Message Text" request-status-update Get the status of a previously sent message. keys username optional The name of the user, if omitted the guest account is used password optional The password of the user message-id mandatory Message id of the previously sent message Reference 115 2009-2014 Diafaan communication software returns STATUS:status-code status-message or ERROR:error-code error-message example dmscmnd.exe host:localhost:9710 command:request-status-update username:admin password: message-id:c3b0c20a-b63e-4bbf-919f-3d4251a8b9c0 request-server-status Get the status of the Diafaan SMS Server and all the Gateways and Connectors statistics. parameters username optional The name of the user, if omitted the guest account is used password optional The password of the user returns An XML file with the status and statistics of Diafaan SMS Server. or ERROR:error-code error-message example dmscmnd.exe host:localhost:9710 command:request-server-status username:admin password: request-received-messages Get a list of received messages in the inbox. keys username optional The name of the user, if omitted the guest account is used password optional The password of the user limit optional The maximum number of messages returned remove optional Set to "1" to remove the returned messages from the database order optional Set to "newest" to get newest messages first, otherwise oldest messages are displayed first. returns An XML file with a list of the requested messages. or ERROR:error-code error-message example dmscmnd.exe host:localhost:9710 command:request-received-messages username:admin password: limit:10 order:newest Diafaan SMS Server 2.1.5 Manual 116 2009-2014 Diafaan communication software 4.3.2 Email connector Send SMS properties Check Start SMTP Server to start the SMTP server on the requested port. Check Get email from a POP server when you want to get the email messages from an external POP server instead. SMTP Server By default, the new SMTP Server will start on port 25. You can change the SMTP port number if it interferes with an existing SMTP server. It is also possible to change the message template, the parts of the email messages that are converted to SMS. The to address of the mail message is converted into the number and an optional message type, e.g.:
[email protected] is sent to number +44xxxxxxxxx. [email protected] is also sent to number +44xxxxxxxxx. [email protected] is sent to number +44xxxxxxxxx with message type sms.text. Some email environments might have trouble with a plus sign in the email address, to overcome this problem you can use a p character instead. POP3 Client The Email connector can retrieve email from a POP box and convert the mail to an SMS message. After installing the connector, the email is forwarded to the GSM number (list) you entered. You can change the message template and add the option to extract the GSM number (list) from the mail subject or body. If Extract from Subject, Body, To address or From address is enabled, the Email connector will try to find the GSM numbers in the email subject, body or the email address. If multiple numbers are detected in the subject or mail body the message will be sent to all those numbers. If no number is found the default number (list) is used. A number can only be detected in the subject or message body if it contains 4-20 digits with an optional leading '+' (e.g. +4400000000). All retrieved messages from the POP server are deleted after retrieval. Reference 117 2009-2014 Diafaan communication software Edit message template The message template defines what part(s) of the email message is forwarded to the SMS message. You can insert fields from the mail message in the template and limit the amount of characters of the message. Receive SMS properties Enable the Forward received SMS messages to email option to convert received SMS messages to one or more email messages. If Extract from SMS message is enabled the Email connector tries to find a valid email address in the SMS message text. If no email address is found the default address (list) is used. When Reply to email is selected the email connector looks if there was a previous email message forwarded to the mobile phone number. If there is a GSM number match, the message is sent as an email reply to the sender of the original email. If there is no match, the message is sent to the default address (list). If Reply to email is selected in combination with the Extract from SMS message option, the procedure to forward the SMS message to email is as follows: If an email address is found in the SMS message, the email is sent to this email address. If no email address is found in the SMS message and there is a GSM number match from a previous email message, the email is sent as a reply to the original email message. If no email address is found in the SMS message and there is no GSM number match, the email is sent to the default address list. Diafaan SMS Server 2.1.5 Manual 118 2009-2014 Diafaan communication software Email templates Edit email template for received SMS messages The email template defines the layout of the email message. For each email field you can use one or more parts of the received SMS message. Edit email template for SMS reply to email This template is only used if the email is a reply to a previously sent email message. It supports a Reference 119 2009-2014 Diafaan communication software number of fields from the original email message, like the To name, To address and the email Subject. Check the Reply when send SMS failed if you want to send a reply when the SMS message could not be sent. If you also want to send a reply when the SMS messages was sent you can check Reply when SMS is sent. Advanced properties MaximumBatchSize The maximum number of messages this connector will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the connector loads multiple messages concurrently. This increases the speed in which the messages are processed. SendPriority Message send priority, a higher number ensures that messages are placed higher in the message send queue and are sent before messages with a lower priority. EmailWhiteList List of allowed email addresses, messages from other email addresses are blocked. Leave empty to allow all sender addresses. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. POP3CheckMailInterval The interval time, in minutes, to check the POP server for new mail. SMTPServerIPBinding local IP address where the SMTP Server should bind to. If this value is empty the SMTP server binds to all available IP addresses. SMTPServerIPWhiteList List of allowed IP numbers, messages from other IP numbers are blocked. Leave empty to allow all IP numbers. SMTPServerMaximumConnections The maximum number of concurrent connections to the SMTP server. SMTPServerMaximumTransactions The maximum number of email transactions (messages) per connection to the SMTP server. SMTPClientPassword Password used to connect to the SMTP server. SMTPClientSendAttempts Maximum number of times the SMTP Client tries to deliver a received message. 2nd attempt after at least 30 seconds Diafaan SMS Server 2.1.5 Manual 120 2009-2014 Diafaan communication software 3rd attempt after at least 5 minutes 4th attempt after at least 30 minutes 5th attempt after at least 1 hour 6th and further attempts after at least 12 hour SMTPClientStartTLS Start TLS encryption after connecting to the SMTP server. SMTPClientUserName Username used to connect to the SMTP server. SMTPClientUseSSLConnection Use a secured SSL connection to the external SMTP server. Reference 121 2009-2014 Diafaan communication software 4.3.3 SQL connector Database properties Select the database driver type and connection string to the database you want to use. Diafaan SMS Server supports three database driver types, Microsoft SQL Server (Express), ODBC and OLE DB. Send SMS properties In the Send SMS tab page you can enter the table name and the basic database field names of the database table that is polled for new messages to send. After the database records are read in, the records are either removed from the database or one of the database fields is set to a fixed value. Records where this value is set are not read anymore in successive database pollings. If large numbers of messages will be sent it is better to remove the records from the database, leaving a large number of records in the database might have an impact on the database performance. Diafaan SMS Server 2.1.5 Manual 122 2009-2014 Diafaan communication software In the Send SMS tab page you can also use double quotes to indicate fixed values. In the example below the To part of the SMS message is not retrieved from the database but all messages are sent to number +44xxxxxxxxxx. This enables you to use database tables where no GSM number is available. The only required database field is the Index, all other fields are optional. Scheduled messages The Advanced settings offers support for an SMSOutScheduled date/time database field. If this database field is used individual messages are not read from the database before the specified date and time. Receive SMS properties Reference 123 2009-2014 Diafaan communication software Use the values in the Receive SMS tab page to specify the database table name and basic database field names where received messages are stored. More fields from the received message can be specified in the Advanced properties. SMS Log properties The SMS Log database table is used to store the result of message send attempts. Specify the database table name and basic database field names where the message logs are stored. More fields can be specified in the Advanced properties. The Message Status Code field stores the message result. Status codes between 200 and 299 indicate that the message is sent successfully. Status codes between 300 and 399 means that the message failed. status codes 200 Message sent and accepted by the gateway. 201 Message received on the GSM phone. 300 Message failed or rejected by the gateway. 301 Status error received after the message was accepted by the gateway The message status can be updated, this means that a message with status code 200 (accepted by the gateway) can change to status code 301 if the GSM network cannot deliver the message. Advanced properties DatabaseCheckInterval The time interval in seconds between two queries of the Send SMS database table. MaximumBatchSize The maximum number of database records this connector will process in one batch. If this value is higher than one and a number of messages are sent at the same time, the connector loads multiple messages concurrently. This increases the speed in which the messages are processed considerably. SendPriority Default message send priority, set to 0 to allow a custom priority for individual messages. A higher number ensures that messages are placed higher in the message send queue and are sent before messages with a lower priority. NumberTemplate The number template can be used to translate the number from one format to another. For more information see Use number templates. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. SQLFlavor The type of database that is used, changing this value causes small changes in the SQL query strings to optimize performance. database types AnsiSQL92 Standard ANSI SQL Microsoft Implements the TOP keyword Oracle Implements the ROWNUM keyword Diafaan SMS Server 2.1.5 Manual 124 2009-2014 Diafaan communication software MySQL Implements the LIMIT keyword Database field names Additional database field names can be entered to query or store more parts of the sent or received message fields. Reference 125 2009-2014 Diafaan communication software 4.3.4 Scripting connector Edit connector script Click on the Edit C# Script or Edit Visual Basic .Net Script link to edit the script. Use the Compile button to check if the script has syntax errors. If the script uses functions that are not in the System.dll assembly, a reference to the required assembly DLL must be added in the ReferenceList of the Advanced properties. Advanced properties LogCommunicationToFile Log all trace log communication to file. You can use this option in combination with the PostTraceLog script function to debug your script. If enabled, the status windows of the Scripting connector provides a link to the location on the hard disk where the file is stored. EnableHTTPCallbacks Enable or disable HTTP callbacks for this gateway. ReferenceList A list of all assembly DLL's required by the script. For the skeleton script, only the System.dll assembly is loaded. Possible useful .NET assemblies are: System.Web.dll Classes for web or html functions. System.Data.dll Classes to handle database requests. System.XML.dll Classes to handle XML files. Connector skeleton script The connector skeleton script that is installed after adding the gateway makes it easier to handle events and provides a number of methods you can use to send messages and add log entries. Diafaan SMS Server 2.1.5 Manual 126 2009-2014 Diafaan communication software Events OnMessageReceived is called when an SMS message is received. OnSendMessageResult is called when a message result is received from a previously sent message. OnSendMessageResultUpdate is called when a message result update was received. Methods PostSendMessage initiate sending an SMS message. PostEventLog adds a line to the event log. PostTraceLog Adds a line to the communication file. Index 127 2009-2014 Diafaan communication software Index - 3 - 3G Modem add gateway 14 edit gateway properties 84 search 14 TCP/IP 14, 84 - A - Access 65 Admin 25, 106 Admin password 78 Administrator 78 Administrator inbox 106 API id 16, 89 ApprovedFromList 89 Assemblies 99, 125 Auto reply 75 Automatic 37, 84, 89 - B - Baudrate 84 BulkSMS.com 71 - C - C# 21, 32, 71, 99, 125 CDMA 84 Clickatell add gateway 7, 16 edit gateway properties 89 COM Port 84 Command 113 Commandline client 113 CompatibilityMode 84 Connection string 52, 121 Connector specific routing 34 Connectors add 23 edit properties 104 overview 10 CSharp 21, 71, 99 - D - Data 37, 84, 89 Database 29, 121 Database fields 52 Database maintenance 78 Database tables 52 DatabaseCheckInterval 121 DataBits 84 DefaultFrom 89 DeliveryConfirmation 84 Dispatch SMS 71 dmscmnd.exe 113 dotNET 21, 32, 99, 125 - E - Email add connector 27 edit connector properties 116 E-mail 18, 96 E-mail alerts 78 Exchange Server 2007 46 Exchange Server 2010 46 - F - Fields 52 Flash 37, 84, 89 - G - Gateway 34 gateway script 34, 71 Gateways add 12 edit properties 83 overview 10 GET 106 GSM Modem add gateway 7, 14 edit gateway properties 84 search 14 TCP/IP 14, 84 Diafaan SMS Server 2.1.5 Manual 128 2009-2014 Diafaan communication software gsm.ussd 37, 84 GSMNumber 84 Guest inbox 106 Guest login 25, 106 - H - HTTP 25, 106 HTTP commands 111 HttpHost 89 - L - Line 113 LogCommunicationToFile 84, 89, 99, 106, 125 - M - MaximumBatchSize 89, 99, 106, 116, 121 MaxMessageParts 84, 89 Message specific routing 34 MessageType 37, 84, 89, 91 Automatic 37, 84, 89, 91 Data 37, 84, 89, 91 Flash 37, 84, 89, 91 gsm.ussd 37, 84, 91 sms.automatic 37, 84, 89, 91 sms.automatic.flash 37, 84, 89, 91 sms.binary 37, 84, 89, 91 sms.pdu 37 sms.text 37, 84, 89, 91 sms.text.flash 37, 84, 89, 91 sms.unicode 37, 84, 89, 91 sms.unicode.flash 37, 84, 89 StandardText 37, 84, 89, 91 Unicode 37, 84, 89, 91 USSD 37, 84 Microsoft Access 65 Microsoft Access database 29, 121 Microsoft Exchange Server 46 Microsoft SQL Server 57 Microsoft SQL Server (Express) 29, 121 Microsoft SQL Server Express 57 ModemInitialization 84 MySQL 59 MySQL database 29, 121 - N - Number format 39 Number template 39 - O - ODBC 29, 52, 59, 68, 121 OLE BD 62 OLE DB 29, 52, 65, 121 OnMessageReceived 75 OnMessageToSend 71 Oracle 62 Oracle database 29, 121 - P - Pager 18, 96 Paging 18, 96 Parity 84 Password 78, 89 PDU mode 84 Picture message 44 PIN code 14, 84 POP 116 POP3 27 POP3CheckMailInterval 116 POP3UseSSLConnection 116 POST 106 PostDispatchMessage 34, 71 PostgreSQL 68 PostSendMessage 75 PostSendResult 71 - R - ReceiveMultiPartMessage 84 Recipient address 39 ReferenceList 99, 125 request-received-messages limit 111, 113 order 111, 113 password 111, 113 remove 111, 113 username 111, 113 request-status-update Index 129 2009-2014 Diafaan communication software request-status-update message-id 111, 113 password 111, 113 username 111, 113 ResetAfterNetworkFailure 84 ResetAfterTimeout 84 Ringtone 44 Route messages 34 - S - Script 34, 75 add connector 32 add gateway 21 edit connector properties 125 edit gateway properties 99 Send your first message 7 send-message from 111, 113 gateway 111, 113 message 111, 113 message-type 111, 113 password 111, 113 to 111, 113 username 111, 113 SIM box 14 SMPP 17, 91 sms.automatic 37, 84, 89 sms.automatic.flash 37, 84, 89 sms.binary 37, 44, 84, 89 sms.pdu 37 sms.text 37, 84, 89 sms.text.flash 37, 84, 89 sms.unicode 37, 84, 89 sms.unicode.flash 37, 84, 89 SMSC number 14 SMSCNumber 84 SMSOutGateway 52 SMSOutUserId 52 SMSOutUserInfo 52 SMSOverGPRS 84 SMTP 18, 27, 96, 116 SMTPClientUseSSLConnection 116 SMTPServerIPBinding 116 SMTPServerMaximumConnections 116 SMTPServerMaximumTransactions 116 SNPP 18, 96 Source address 17, 91 SQL add connector 29 edit connector properties 121 Microsoft Access database 65 Microsoft SQL Server database 57 Microsoft SQL Server Express database 57 MySQL database 59 Oracle database 62 PostgreSQL database 68 SQL Connector 52, 57, 59, 62, 65, 68 SQLFlavor 121 StandardText 37, 84, 89 Status Code 121 StopBits 84 System type 91 System.Data.dll 99, 125 System.Web.dll 99, 125 System.XML.dll 99, 125 - T - Tables 29, 52, 121 TAP 18, 96 TCP/IP GSM modem 14 modem 14 template e-mail 116 message 116 Text mode 84 - U - UCP 18, 96 Unicode 37, 84, 89 URL 25, 106 Username 89 USSD 37, 84 - V - Visual Basic .NET 21, 32, 71, 99, 125 - W - WCTP 18, 96 Web server Diafaan SMS Server 2.1.5 Manual 130 2009-2014 Diafaan communication software Web server add connector 25 edit connector properties 106