📄 sms_user.sgml
字号:
<!-- Module User's Guide --><chapter> <chapterinfo> <revhistory> <revision> <revnumber>$Revision: 1.2 $</revnumber> <date>$Date: 2004/08/24 09:00:39 $</date> </revision> </revhistory> </chapterinfo> <title>User's Guide</title> <section> <title>Overview</title> <para> This module provides a way of communication between &sip; network (via &sip MESSAGE) and <acronym>GSM</acronym> networks (via ShortMessageService). Communication is possible from &sip; to <acronym>SMS</acronym> and vice versa. The module provides facilities like <acronym>SMS</acronym> confirmation--the gateway can confirm to the &sip; user if his message really reached its destination as a <acronym>SMS</acronym>--or multi-part messages--if a &sip; messages is too long it will be split and sent as multiple <acronym>SMS</acronym>. </para> <para> Errors occurred because of an invalid number or a too long message or because of an internal modem malfunction are reported back to the &sip; user via a &sip; message containing explanations regarding the error. </para> <section> <title>Hardware Requirements</title> <para> The <acronym>SMS</acronym> module needs a <acronym>GSM</acronym> modem to be able to send/receive the <acronym>SMS</acronym> messages. Usually, this kind of modems are externals, linked to the machine via serial cable. The modem can be a dedicated one (as the ones provided by FALCOM) or can be a <acronym>GSM</acronym> telephone that has an internal modem (as the latest mobile phones from NOKIA and ERICSSON). </para> </section> <section> <title>Numbering Plan</title> <para> The gateway accepts and advertises phone numbers in international format, more specific like: +(international code)(area code)(number). Ex: Germany, D1 = +49 170 5678181 Romania, Connex = +40 722 123456 A number in this format is expected to be placed as username into <acronym>RURI</acronym> or in the To header. If <acronym>RURI</acronym> misses the username, the To header will be consider. Also, the gateway will advertise in this format the username in Contact headers (in &sip; replies and requests) and in From headers (in &sip; requests). </para> </section> <section> <title>Address Mapping</title> <para> To identify the destination number of the <acronym>SMS</acronym>, the gateway expects to have a mobile number in username of the &sip; destination address (for example sip:+401704678811@iptel.org). For the reverse direction, because the gateway has only one <acronym>GSM</acronym> number, the destination &sip; address has to be encapsulated into the <acronym>SMS</acronym> body. The gateway expects to find a &sip; address at the beginning of the <acronym>SMS</acronym> body in <quote>sip:user.host</quote> format. Everything before the &sip; address will be discarded, the useful text begins exactly after the address (for example SMS=<quote>For sip:user@host hello world!!</quote> -> SIP=<quote>hello world</quote>) In order to facilitate replying, the gateway sends all the <acronym>SMS</acronym> messages with a header containing the source &sip; address in the following format: <quote>From sip:user@host (if you reply DONOT remove it)<new_line></quote>. When an <acronym>SMS</acronym>-reply is received having this header (all of it or truncated at the end), the header will be left out (it will not be in the &sip; message). </para> </section> </section> <section> <title>Dependencies</title> <section> <title>&ser; Modules</title> <para> The following modules must be loaded before this module: <itemizedlist> <listitem> <para> <emphasis>tm - Transaction Manager</emphasis>. </para> </listitem> </itemizedlist> </para> </section> <section> <title>External Libraries or Applications</title> <para> The following libraries or applications must be installed before running &ser; with this module loaded: <itemizedlist> <listitem> <para> <emphasis>None</emphasis>. </para> </listitem> </itemizedlist> </para> </section> </section> <section> <title>Exported Parameters</title> <section> <title><varname>modems</varname> (string)</title> <para> Define and configure one or more <acronym>GSM</acronym> modems. </para> <programlisting format="linespecific">modems_value = modem_definition *( ";" modem_definition )modem_definition = modem_name "[" list_of_params "]"list_of_params = modem_param *( ";" modem_param )modem_param = name "=" value</programlisting> <para> The following parameters can be used: </para> <itemizedlist> <listitem> <para> d=device (mandatory) - Device associated with modem (/dev/ttyS0, /dev/modem, etc.). </para> </listitem> <listitem> <para> p=pin (optional) - <acronym>SIM</acronym> <acronym>PIN</acronym> - default is NULL. </para> </listitem> <listitem> <para> m=mode (optional) - Modem working mode (<quote>ASCII</quote>,<quote>OLD</quote>,<quote>DIGICOM</quote>,<quote>NEW</quote>). Default value is <quote>NEW</quote>. </para> </listitem> <listitem> <para> c=SMS_Center (optional) - <acronym>SMS</acronym> center number for that modem. Default is the <acronym>SMS</acronym> center set on the <acronym>SIM</acronym> card. </para> </listitem> <listitem> <para> b=baudrate (optional) - Default is 19600. </para> </listitem> <listitem> <para> r=retry (optional) - How many times to try to re-send a <acronym>SMS</acronym> that reported error. Default is twice. </para> </listitem> <listitem> <para> l=looping (optional) - Time for modem to wait before performing a new check for incomimg/outgoing <acronym>SMS</acronym>/SIP_MSG. Default is 20. </para> </listitem> </itemizedlist> <para> <emphasis> No default value, the parameter is mandatory. </emphasis> </para> <example> <title>Set <varname>modems</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "modems", "Nokia [d=/dev/ttyS1;b=9600;m=new;l=30] ")modparam("sms", "modems", "Nokia[d=/dev/ttyS1];Siemens[d=/dev/ttyS2]")...</programlisting> </example> </section> <section> <title><varname>networks</varname> (string)</title> <para> Define and configure used <acronym>GSM</acronym> networks. </para> <programlisting format="linespecific">networks_value = net_definition *( ";" net_definition )net_definition = net_name "[" list_of_params "]"list_of_params = set_param *( ";" set_param )set_param = name "=" value</programlisting> <para> The following parameters can be used: </para> <itemizedlist> <listitem> <para> m=msx_sms_per_call (optional) - Maximum number of <acronym>SMS</acronym> send / received from that net in one modem loop. Default is 10. This parameter was introduced to avoid starvation. </para> <para> Example of the starvation--a modem can send <acronym>SMS</acronym> for more than 1 networks. If you have a huge number of <acronym>SMS</acronym> for the first network and the number of incoming &sip; messages is equal to the sent <acronym>SMS</acronym> per same unit of time, the modem will never get to send <acronym>SMS</acronym> for the next networks. </para> </listitem> </itemizedlist> <para> <emphasis> No default value, the parameter is mandatory. </emphasis> </para> <example> <title>Set <varname>networks</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "networks", "D1 [m=10] ;d2[ m=20]")...</programlisting> </example> </section> <section> <title><varname>links</varname> (string)</title> <para> Define from which network each modem should send <acronym>SMS</acronym>. </para> <programlisting format="linespecific">links_value = modem_assoc *( ";" modem_assoc )modem_assoc = modem_name "[" list_of_networks "]"list_of_networks = network *( ";" network )</programlisting> <para> <emphasis> No default value, the parameter is mandatory. </emphasis> </para> <example> <title>Set <varname>links</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "links", "NOKIA[D1;d2]")...</programlisting> </example> <para> The modem NOKIA will send <acronym>SMS</acronym> from D1 and D2 net (in this order !). if in a net queue are more then max_sms_per_call <acronym>SMS</acronym> the modem will <emphasis>not sleep</emphasis> before starting the next loop ! Shortly, if messages are waiting to be sent, the modem will not go in sleep. </para> </section> <section> <title><varname>default_net</varname> (string)</title> <para> The default network to use. If no one specified, the first defined network is used. This parameter is useful only if the the <quote>sms_send_msg</quote> exported function is used (see <xref linkend="sec-exported-functions">). </para> <example> <title>Set <varname>default_net</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "default_net", "D1")...</programlisting> </example> </section> <section> <title><varname>max_sms_parts</varname> (integer)</title> <para> Shows in how many parts (<acronym>SMS</acronym> messages) a &sip; message can be split. If exceeded, the &sip; message will be sent truncated and the &sip; user will get back another message containing the unsent part. </para> <para> <emphasis> Default value is 4. </emphasis> </para> <example> <title>Set <varname>max_sms_parts</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "max_sms_parts", 10)...</programlisting> </example> </section> <section> <title><varname>domain_str</varname> (string)</title> <para> Specify a fake domain name to be used by the gateway. The Contact headers and the From header from request will be construct based on this fake domain name. It's useful when the gateway is transparently hidden behind a proxy/register (located on different machines). </para> <para> <emphasis> Default is the name of the machine the gateway is running on. </emphasis> </para> <example> <title>Set <varname>domain_str</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "domain_str", "foo.bar")...</programlisting> </example> </section> <section> <title><varname>use_contact</varname> (integer)</title> <para> If a contact header should be added to the outgoing &sip; messages. Even if the &sip; draft forbids this, some &uas; require it. </para> <para> <emphasis> Default is 0 (no). </emphasis> </para> <example> <title>Set <varname>use_contact</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "use_contact", 1)...</programlisting> </example> </section> <section> <title><varname>sms_report_type</varname> (integer)</title> <para> If the modem should ask for <acronym>SMS</acronym> confirmation from the <acronym>SMS</acronym> Center. If the <acronym>SMSC</acronym> reply with an error code, the gateway will send back to &sip; user a &sip; message containing the text (or part of it) that couldn't be send. Two report mechanisms are implemented: </para> <itemizedlist> <listitem> <para> 1 - the reports are delivered by the <acronym>GSM</acronym> device as <acronym>SMS</acronym> reports (so far supported only by Nokia modems); </para> </listitem> <listitem> <para> 2 - the reports are delivered as async. <acronym>CDS</acronym> responses (supported by almost all modems, except Ericsson). </para> </listitem> </itemizedlist> <para> <emphasis> Default is 0 (no report). </emphasis> </para> <example> <title>Set <varname>sms_report_type</varname> parameter</title> <programlisting format="linespecific">...modparam("sms", "sms_report_type", 1)...</programlisting> </example> </section> </section> <section id="sec-exported-functions"> <title>Exported Functions</title> <section> <title> <function moreinfo="none">sms_send_msg_to_net(network_name)</function> </title> <para> Put the &sip; msg in the specified network queue. The function return error if the number encapsulated into &sip; message is malformed, if the content_type is incorrect or because of some internal failures. </para> <para>Meaning of the parameters is as follows:</para> <itemizedlist> <listitem> <para> <emphasis>network_name</emphasis> - Name of network. </para> </listitem> </itemizedlist> <example> <title><function>sms_send_msg_to_net</function> usage</title> <programlisting format="linespecific">...if (sms_send_msg_to_net("D1")){ if (!t_reply("202", "yes sir, SMS sent over")) { # if replying failed, retry statelessly sl_reply_error(); };} else { if (!t_reply("502", "Bad gateway - SMS error")) { # if replying failed, retry statelessly sl_reply_error(); }; break;};...</programlisting> </example> </section> <section> <title> <function moreinfo="none">sms_send_msg()</function> </title> <para> The same as the previous one, but use the default network queue. </para> <example> <title><function>sms_send_msg</function> usage</title> <programlisting format="linespecific">...if (sms_send_msg_to_net()){ if (!t_reply("202", "yes sir, SMS sent over")) { # if replying failed, retry statelessly sl_reply_error(); };} else { if (!t_reply("502", "Bad gateway - SMS error")) { # if replying failed, retry statelessly sl_reply_error(); }; break;};...</programlisting> </example> </section> </section></chapter><!-- Keep this element at the end of the fileLocal Variables:sgml-parent-document: ("sms.sgml" "Book" "chapter")End:-->
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -