C.167. SMS()
Sendet oder empfängt SMS-Nachrichten.
SMS(Warteschlange
[,Optionen
])
Regelt den Austausch von SMS-Nachrichten mit einem SMS-fähigen
Telefon oder über ein SMS-Service-Center nach dem Protokoll ETSI ES 201 912
auf analogen oder ISDN-Leitungen. Das Shell-Programm
smsq
verwendet dazu FSK[210] – dass ein Austausch über komprimierte Codecs wie GSM
funktioniert, ist daher unwahrscheinlich.Optionen:
- a
- Als antwortende Seite agieren.
- s
- Als Service-Center agieren, das mit einem Telefon kommuniziert.
Alle Sende-/Empfangswarteschlangen werden in
/var/spool/asterisk/sms/
gespeichert: die Nachrichten
vom Service-Center zum Telefon in
sc-me.Schlange
/
, die
Nachrichten vom Telefon zum SMSC in
me-sc.Schlange
/
. In
/var/log/asterisk/sms
wird ein Log
geschrieben.Beim Verbinden als Client (
a
) werden alle im
Verzeichnis me-sc.Schlange
/
wartenden Nachrichten gesendet und dann gelöscht; die empfangenen werden in
sc-me.Schlange
/
mit einem
Timestamp im Dateinamen gespeichert. Wenn wir uns als Service-Center
verbinden (s
), ist das genau umgekehrt.Die Nachrichten-Dateien haben folgendes Format, wobei ausgelassene
Parameter Default-Werte haben:
oa=Originating Address (Absendernummer)
Nationale
Telefonnummer oder internationale mit vorangehendem +
(z. B.
+49
).da=Destination Address (Empfängernummer)
Nationale
Telefonnummer oder internationale mit vorangehendem
+
.scts=Service Centre Time Stamp (Zeitstempel vom SC)
Im
Format YYYY-MM-DD HH:MM:SS
pid=Protocol Identifier (decimal octet value)
dcs=Data coding scheme (decimal octet value)
mr=Message reference (decimal octet value)
ud=Der Nachrichtentext
Wenn
andere Zeichen als 10, 13, 32–126, 128–255 (dezimal) in der Nachricht
vorkommen, wird ud=
durch ud#
ersetzt, und die
Zeichen folgen hexadezimal kodiert.srr=Status Report Request (0|1)
rp=Return Path (0|1)
vp=Validity Period (Gültigkeitsdauer in Minuten)
Beim
Senden an ein SMSC müssen nur da
und ud
verwendet
werden, oa
wird ignoriert; beim Senden an ein Telefon sind nur
oa
und ud
nötig, da
wird
ignoriert.Eine Extension zum Empfangen von Nachrichten könnte so aussehen (wenn
01930100 die Nummer des für uns zuständigen SMSC – hier T-Com –
ist):
[incoming] exten => _X.,1,GotoIf($["${CALLERIDNUM}" = "01930100"]?sms-me-in,${EXTEN},1) ; oder so: ;exten => _X./_0193010.,1,Goto(sms-me-in,${EXTEN},1) [sms-me-in] exten => _X.,1,Wait(1) exten => _X.,n,SMS(me-eingang,a) exten => _X.,n,System(handleincomingsms) exten => _X.,n,Hangup()Dabei könnte
handleincomingsms
z. B. smsq
--process=befehl
--queue=me-eingang
sein,
was für jede eingegangene Nachricht einen Befehl ausführt.Ausgehende Nachrichten sollten als Dateien geschrieben werden, können
aber auch mit folgendem (veralteten) Aufruf erzeugt werden (0193010 ist die
Nummer des SMSC – hier T-Com):
[outgoing] exten = 0193010,1,Goto(sms-me-out,${CALLERIDNUM},1) [sms-me-out] exten => _X.,1,Set(CDR(accountcode)=SMS) exten => _X.,n,Set(smsFrom=${CALLERIDNUM}) exten => _X.,n,SMS(${smsFrom},s,${EXTEN},${smsText}) ; SMS erzeugen exten => _X.,n,SMS(${smsFrom},s) ; senden exten => _X.,n,Hangup()
Weitere Informationen und viele Beispiele auf http://www.voip-info.org/wiki/view/Asterisk+cmd+Sms
und http://www.pi4tel.de/asterisk/sms.shtml.
Man kann jedoch nicht erwarten, dass
SMS()
„out of the
box“ sofort funktioniert.Asterisk-Versionen:
————————| 1.2 |————————| 1.4 |————————| 1.6 |————————
Interner Hilfetext zu dieser Applikation in Asterisk 1.4:
-= Info about application 'SMS' =-
[Synopsis]
Communicates with SMS service centres and SMS capable analogue phones
[Description]
SMS(name|[a][s]): SMS handles exchange of SMS data with a call to/from SMS capabale
phone or SMS PSTN service center. Can send and/or receive SMS messages.
Works to ETSI ES 201 912 compatible with BT SMS PSTN service in UK
Typical usage is to use to handle called from the SMS service centre CLI,
or to set up a call using 'outgoing' or manager interface to connect
service centre to SMS()
name is the name of the queue used in /var/spool/asterisk/sms
Arguments:
a: answer, i.e. send initial FSK packet.
s: act as service centre talking to a phone.
Messages are processed as per text file message queues.
smsq (a separate software) is a command to generate message
queues and send messages.
Differenz des internen Hilfetexts von Asterisk 1.2 zu 1.4:
— keine —Differenz des internen Hilfetexts von Asterisk 1.4 zu 1.6:
--- in Asterisk 1.4
+++ in Asterisk 1.6
@@ -4,16 +4,26 @@
Communicates with SMS service centres and SMS capable analogue phones
[Description]
- SMS(name|[a][s]): SMS handles exchange of SMS data with a call to/from SMS capabale
+ SMS(name,[a][s][t][p(d)][r][o],addr,body):
+ SMS handles exchange of SMS data with a call to/from SMS capable
phone or SMS PSTN service center. Can send and/or receive SMS messages.
- Works to ETSI ES 201 912 compatible with BT SMS PSTN service in UK
- Typical usage is to use to handle called from the SMS service centre CLI,
+ Works to ETSI ES 201 912; compatible with BT SMS PSTN service in UK
+ and Telecom Italia in Italy.
+ Typical usage is to use to handle calls from the SMS service centre CLI,
or to set up a call using 'outgoing' or manager interface to connect
service centre to SMS()
name is the name of the queue used in /var/spool/asterisk/sms
Arguments:
- a: answer, i.e. send initial FSK packet.
- s: act as service centre talking to a phone.
+ a - answer, i.e. send initial FSK packet.
+ s - act as service centre talking to a phone.
+ t - use protocol 2 (default used is protocol 1).
+ p(N) - set the initial delay to N ms (default is 300).
+ addr and body are a deprecated format to send messages out.
+ r - set the Status Report Request (SRR) bit.
+ o - the body should be coded as octets not 7-bit symbols.
Messages are processed as per text file message queues.
smsq (a separate software) is a command to generate message
queues and send messages.
+ NOTE: the protocol has tight delay bounds. Please use short frames
+ and disable/keep short the jitter buffer on the ATA to make sure that
+ respones (ACK etc.) are received in time.