/pdu_tools

Tools for encoding and decoding GSM SMS PDUs.

Primary LanguageRubyMIT LicenseMIT

pdu_tools

Tools for encoding and decoding GSM SMS PDUs.

Usage

Encoding SMS message

encoder = PDUTools::Encoder.new recipient: "+421910100100", message: "This is a message"
pdus = encoder.encode # => [#<PDUTools::PDU:0x007fd5a4a1d908 @pdu_hex="0001000C9124910101100000001154747A0E4ACF416150BB3C9F87CF65">]

in pdus variable is array of PDUs, if the message is too long it is separated to multiple PDUs.

Decoding SMS message

decoder = PDUTools::Decoder.new "0001000C9124910101100000001154747A0E4ACF416150BB3C9F87CF65", :ms_to_sc
message_part = decoder.decode # => #<PDUTools::MessagePart:0x007fd5a503a9f8 @address="+421910100100", @body="This is a message", @timestamp=nil, @validity_period=nil, @user_data_header=nil>

in message_part variable is now MessagePart object which contains information extracted from the PDU, you can check if the message is complete using message_part.complete? to see if message was separated in multiple PDUs using User Data Header.

There is difference when PDU is comming from MS(Mobile Station) to SC(Service Center) or reverse. You need to specify the direction of PDU in decoder's second parameter: :ms_to_sc or :sc_to_ms.

This tool was build with help of this document

Features

  • Encoding 7 bit and 16 bit characters
  • Decoding 7 bit, 8 bit and 16 bit characters
  • Encoding and decoding User Data Header - used for concatenating SMS messages