Version

Optional Fields

Optional fields in SMPP, known as Tag-Length-Value (TLV) parameters, provide additional flexibility and functionality beyond the required fields. These parameters are not mandatory for all operations but can be included to support specific features such as delivery receipts, callback numbers, or extended message attributes.

All optional fields appear at the end of the PDU, in a designated optional parameters section. Within that section, fields can be encoded in any order. Depending on the use case, a PDU may include some, all, or none of the available optional fields. For example, a system submitting a message via submit_sm might include only a callback number TLV, while others may require multiple additional parameters.

Optional TLVs are designed to support a range of wireless technologies, including GSM, CDMA, TDMA, and iDEN, making them widely applicable across different messaging infrastructures.

Below is the full list of optional SMPP parameters (TLVs).

dest_addr_subunit Specifies a subaddress or subunit within the destination device. Used when the SMS needs to be routed to a specific component (e.g., SIM, memory module, or application) of a multi-functional device.
source_addr_subunit Same as above, but for the originating device. Useful when indicating the exact origin point within a device that supports multiple messaging components.
dest_network_type Indicates the type of wireless network the destination is using. This could be GSM, CDMA, iDEN, etc. Used by the SMSC to tailor message handling for the target network technology.
source_network_type The corresponding network type for the message originator. Like dest_network_type, this helps with routing or applying network-specific delivery rules.
dest_bearer_type Specifies the bearer service used for delivering the message to the destination—e.g., SMS over GPRS, USSD, or circuit-switched SMS.
source_bearer_type Same as above, but for the message originator. These fields are rarely used in standard SMS delivery, but may be relevant in operator-level implementations or hybrid network setups.
dest_telematics_id Identifies the specific telematics service at the destination. Used when the destination device or application is part of a vehicle system or machine-to-machine (M2M) platform requiring message classification.
source_telematics_id Same as above, but for the source. Useful in M2M communication or specialized data services where sender identity goes beyond standard phone numbers.
qos_time_to_live Defines how long the message is allowed to remain undelivered before the SMSC gives up. Unlike validity_period, this field is focused on QoS enforcement, especially for time-sensitive messages. Expressed in milliseconds. If the message isn’t delivered within this time, it’s dropped.
payload_type Indicates the format or type of content in the message payload. Typically used in MMS or data-heavy environments to classify message content (e.g., binary, multimedia, or protocol-specific formats). Helps systems downstream interpret how to handle the message.
additional_status_info_text Provides a textual description of the message status, usually in deliver_sm or data_sm_resp. Used to give more human-readable context to error codes or delivery outcomes, especially in troubleshooting or logs.
receipted_message_id Returns the original message_id for which a delivery receipt is being generated. This allows the ESME to correlate the receipt with the message it submitted. It’s critical when processing delivery reports in high-volume systems.
ms_msg_wait_facilities Used to indicate that the recipient MS (Mobile Station) has waiting messages (like voicemails or unread texts). Often included in messages that trigger a message waiting indicator (MWI) on the device. This TLV is mostly relevant in operator infrastructure or Voicemail SMS.
privacy_indicator Indicates privacy or confidentiality level. For example, it might flag a message as confidential, requiring special handling (e.g., no storage on intermediate systems). Rarely used in general SMS workflows.
source_subaddress Defines a sub-address for the message originator, allowing routing to or identification of a specific application, module, or logical endpoint on the source side. This is beyond the normal source_addr.
dest_subaddress Same as source_subaddress, but for the recipient. Used when the destination has multiple logical endpoints that need to be addressed separately (e.g., embedded systems, enterprise gateways).
user_message_reference An optional ID assigned by the ESME to track the message. This reference is echoed back in delivery reports or responses and can help match messages to application-level logic.
user_response_code A one-byte field that allows the SMSC or recipient to return a custom response code back to the ESME. Useful in application-driven messaging scenarios (e.g., status codes for interactive or session-based communication).
language_indicator Specifies the language used in the message content. Often used in combination with specific encoding schemes to support language-specific character sets or localization behavior on the receiving device.
source_port Indicates the application port number on the source side. Used in WAP push, EMS, or other binary messaging systems to route the message to a specific application on the sending device.
destination_port Specifies the port number on the destination device where the message should be delivered. Common in mobile applications that listen on specific ports for incoming data (e.g., financial apps, mobile games, system-level services).
sar_msg_ref_num Short for Segmentation and Reassembly Message Reference Number. A shared reference used to group all segments of a multipart message together.
sar_total_segments The total number of segments the original message was split into. Included in each segment so the recipient knows how many parts to expect.
sar_segment_seqnum The sequence number of this particular segment in the multipart message. Starts from 1 and increases with each part.
sc_interface_version Indicates the SMSC’s supported SMPP version. Useful for compatibility checks between the SMSC and ESME. Helps ensure that features or field expectations match between both ends of the connection.
display_time Specifies how long the message should be displayed on the recipient’s device. This is mostly device-specific and not widely supported by all networks. Often used in flash messaging scenarios.
ms_validity Indicates the validity period as understood by the mobile station (MS). This is different from the validity_period parameter, which is SMSC-based. It's relevant when the handset or network terminal enforces message expiry.
dpf_result DPF stands for Delivery Pending Flag. This field is used in delivery reports to indicate whether a message had to be stored by the SMSC before delivery (e.g., if the recipient was temporarily unavailable).
set_dpf Instructs the SMSC to set the DPF flag if the message is stored for delayed delivery. Allows the ESME to track whether delivery was real-time or deferred.
ms_availability_status Indicates whether the recipient mobile station was available at the time of message delivery attempt. Helps applications understand the context of delayed delivery or failures.
network_error_code Provides carrier-specific error codes when message delivery fails. It's structured (usually) as a 3-byte field:
    • Byte 1: Network type 
    • Byte 2: Error code group 
    • Byte 3: Specific error 
Used in troubleshooting and analytics to classify failure reasons beyond the general command_status.
message_payload A TLV alternative to the short_message field, used when sending large or binary content. Unlike short_message, this can exceed the usual 140-byte limit and is commonly used for long or concatenated messages.
delivery_failure_reason Returned in delivery receipts to explain why a message failed. While not standardized across all implementations, this field can provide more actionable insight than just a generic error code.
more_messages_to_send A flag used in deliver_sm to indicate that more messages are queued for delivery in the current session. Helps optimize throughput by letting the ESME know to expect additional PDUs without re-requesting them.
message_state Returns the current status of a message, typically used in query_sm_resp or delivery receipts. Values include:
    • 0x01 – Enroute 
    • 0x02 – Delivered 
    • 0x03 – Expired 
    • 0x05 – Undeliverable 
    • 0x08 – Rejected
This TLV is often included alongside receipted_message_id.
callback_num A phone number the recipient can use to call or message back. Used in service-oriented SMS (e.g., two-way chat or customer support) to indicate a return contact point.
callback_num_pres_ind Controls how the callback_num should be presented (e.g., allowed, restricted, or unavailable). Works similarly to CLI (Caller Line Identification) presentation in voice networks.
callback_num_atag An alphanumeric string associated with the callback_num. Typically used to display friendly names or tags (e.g., "Customer Support") alongside the number.
number_of_messages Indicates the number of messages waiting for the recipient (e.g., unread SMS or voicemails). May be used in deliver_sm to update a user’s message waiting indicator (MWI) status.
sms_signal Controls device-specific alert behavior (e.g., vibration, light, sound) when the message arrives. Support is device-dependent and uncommon in general messaging.
alert_on_message_delivery Triggers a special alert on the recipient device when the message is delivered. Similar to a flash SMS or urgent notification. Not widely supported across all networks or devices.
its_reply_type Used to indicate how a terminal (e.g., a smart card or SIM-based app) should respond to a message, especially in interactive or SIM toolkit-based sessions.
its_session_info Contains session-related metadata for ITS (Intelligent Terminal Support) applications. Helps maintain session context between the SMSC and a smart terminal.
ussd_service_op Defines the USSD operation type (e.g., request, response, notification). This TLV is used in SMS-over-USSD gateways or applications that bridge SMPP with USSD interfaces.

 

Start innovating with Mobius

What's next? Let's talk!

Mobius Software

As a company you'll get:

  • Get started quickly

  • Support any business model

  • Join millions of businesses

Questions? websupport@mobius.com