SMPP Examples
This section contains one example each for the SMPP Receiver and Transmitter agents.
Receiver Agent
In this workflow example for the SMPP Receiver agent:
Receiver workflow example
The SMPP receiver agent sends DELIVER_SM UDRs to the Analysis agent, which contains the following code:
consume {
DELIVER_SM_RESP deliver_sm_resp = udrCreate(DELIVER_SM_RESP);
if ((input.sequence_number % 2) == 0) {
deliver_sm_resp.command_status = 2;
} else {
deliver_sm_resp.command_status = 0;
}
udrRoute(deliver_sm_resp);
}
With this code, the Analysis agent will:
Create a UDR of
DELIVER_SM_RESP
type called deliver_sm_resp.Check whether the sequence number in the incoming
DELIVER_SM
UDR is even or odd.If the sequence number is even, the
command_status
field in the deliver_sm_resp UDR will be set to 2, and if it is odd, the field will be set to 0.The deliver_sm_resp UDR will then be routed back to the SMPP receiver agent.
Transmitter agent
In this workflow example for the SMPP Transmitter agent:
Transmitter workflow example
The TCP/IP agent sends TCP_TI UDRs into the workflow using a decoder that defines this UDR type.
The Analysis agent contains the following code:
import ultra.SMPP;
consume {
if (instanceOf(input, TCP_TI)) {
TCP_TI tcp_udr = udrCreate(TCP_TI);
tcp_udr = (TCP_TI) input;
strToBA(tcp_udr.response, "message=" + tcp_udr.message + "\r\n");
SUBMIT_SM submit_sm = udrCreate(SUBMIT_SM);
bytearray sm;
strToBA(sm, "MESSAGE", "UTF-16BE");
submit_sm.short_message = sm;
submit_sm.data_coding = 8;
submit_sm.source_addr = "555123456";
submit_sm.destination_addr = "555987654";
udrRoute(tcp_udr, "OUT_TCP");
udrRoute(submit_sm, "OUT_SMPP");
}
}
}
which will:
Import the SMPP Ultra formats
If the received UDR is of the TCP_TI type, the UDR will be named tcp_udr, and the
response
field in the UDR will be populated with the text "message=<contents of the message field>" in bytearray format.Create a UDR of type SUBMIT_SM called submit_sm.
Create a bytearray object called sm, and populate this bytearray with the text "MESSAGE" in bytearray format with UTF-16BE encoding.
Populate the
short_message
field in the submit_sm UDR with the new bytearray.Set the data coding to 8, which equals the UTF-16BE encoding according to the specification.
Set the source address to 555123456 and the destination address to 555987654.
Route the submit_sm UDR to the SMPP transmitter agent, and the tcp_udr UDR to the TCP/IP agent.
The SMPP transmitter agent will then send SUBMT_SM_RESP
UDRs back to the Analysis agent when receiving the corresponding SUBMIT_SM_RESP
UDRs from the SMSC. The SUBMIT_SM_RESP
UDRs contain the original SUBMIT_SM
for which the SMSC has responded.