• Features
  • Services
    • Email Authentication
    • Agency Partnerships
    • Email Training
    • Inbox Brand Visibility
    • Deliverability
  • Resources
    • Knowledge Base
    • API documentation
    • Blog
    • Status
    • BIMI inspector
  • About us
    • Contact
    • Terms and Conditions
    • Privacy Policy
    • Privacy recommendations
  • Features
  • Services
    • Email Authentication
    • Agency Partnerships
    • Email Training
    • Inbox Brand Visibility
    • Deliverability
  • Resources
    • Knowledge Base
    • API documentation
    • Blog
    • Status
    • BIMI inspector
  • About us
    • Contact
    • Terms and Conditions
    • Privacy Policy
    • Privacy recommendations
  • Login
    EN CS
Mailkit logo
  • Features
  • Services
    • Email Authentication
    • Agency Partnerships
    • Email Training
    • Inbox Brand Visibility
    • Deliverability
  • Resources
    • Knowledge Base
    • API documentation
    • Blog
    • Status
    • BIMI inspector
  • About us
    • Contact
    • Terms and Conditions
    • Privacy Policy
    • Privacy recommendations
  • Features
  • Services
    • Email Authentication
    • Agency Partnerships
    • Email Training
    • Inbox Brand Visibility
    • Deliverability
  • Resources
    • Knowledge Base
    • API documentation
    • Blog
    • Status
    • BIMI inspector
  • About us
    • Contact
    • Terms and Conditions
    • Privacy Policy
    • Privacy recommendations
  • Login
    EN CS
EN CS
Login
  • Mailkit
  • Resources
  • API documentation
  • Campaign delivery
  • mailkit.sendsms
    API Introduction
  • Campaign management (11)
    mailkit.campaigns.list mailkit.campaigns.create mailkit.campaigns.update mailkit.campaigns.single.schedule mailkit.campaigns.schedule.list mailkit.campaigns.schedule.timezone mailkit.campaigns.schedule.cancel mailkit.campaigns.messages mailkit.campaigns.messages.last mailkit.campaigns.messages.test mailkit.campaigns.history
  • Mailing list management (18)
    mailkit.mailinglist.list mailkit.mailinglist.create mailkit.mailinglist.delete mailkit.mailinglist.adduser mailkit.mailinglist.edituser mailkit.mailinglist.import mailkit.mailinglist.getstatus mailkit.mailinglist.unsubscribed mailkit.mailinglist.engagement mailkit.email.getstatus mailkit.email.getstatus.history mailkit.email.move mailkit.email.delete mailkit.email.unsubscribe mailkit.email.unsubscribe.getstatus mailkit.email.revalidate mailkit.email.topics mailkit.email.wipe
  • Campaign delivery (4)
    mailkit.sendmail mailkit.sendmail_mass mailkit.sendmail_mass.results mailkit.sendsms
  • Reporting (11)
    mailkit.report mailkit.report.campaign mailkit.report.message mailkit.report.message.recipients mailkit.report.message.feedback mailkit.report.message.links mailkit.report.message.links.visitors mailkit.report.message.bounces mailkit.report.raw.messages mailkit.report.raw.bounces mailkit.report.raw.responses
  • Profile (2)
    mailkit.profile.emails.list mailkit.profile.queries.list
  • Other (4)
    Event API mailkit.filemanager.upload mailkit.filemanager.list mailkit.filemanager.delete
  • Examples (3)
    PHP example 1 (Example of mailkit.mailinglist.list call) PHP example 2 (example of mailkit.campaigns.single.schedule call) PERL example of mailkit.mailinglist.adduser call
  • API Introduction
  • Campaign management
  • Mailing list management
  • Campaign delivery
  • Reporting
  • Profile
  • Other
  • Examples
API Introduction
mailkit.campaigns.list mailkit.campaigns.create mailkit.campaigns.update mailkit.campaigns.single.schedule mailkit.campaigns.schedule.list mailkit.campaigns.schedule.timezone mailkit.campaigns.schedule.cancel mailkit.campaigns.messages mailkit.campaigns.messages.last mailkit.campaigns.messages.test mailkit.campaigns.history
mailkit.mailinglist.list mailkit.mailinglist.create mailkit.mailinglist.delete mailkit.mailinglist.adduser mailkit.mailinglist.edituser mailkit.mailinglist.import mailkit.mailinglist.getstatus mailkit.mailinglist.unsubscribed mailkit.mailinglist.engagement mailkit.email.getstatus mailkit.email.getstatus.history mailkit.email.move mailkit.email.delete mailkit.email.unsubscribe mailkit.email.unsubscribe.getstatus mailkit.email.revalidate mailkit.email.topics mailkit.email.wipe
mailkit.sendmail mailkit.sendmail_mass mailkit.sendmail_mass.results mailkit.sendsms
mailkit.report mailkit.report.campaign mailkit.report.message mailkit.report.message.recipients mailkit.report.message.feedback mailkit.report.message.links mailkit.report.message.links.visitors mailkit.report.message.bounces mailkit.report.raw.messages mailkit.report.raw.bounces mailkit.report.raw.responses
mailkit.profile.emails.list mailkit.profile.queries.list
Event API mailkit.filemanager.upload mailkit.filemanager.list mailkit.filemanager.delete
PHP example 1 (Example of mailkit.mailinglist.list call) PHP example 2 (example of mailkit.campaigns.single.schedule call) PERL example of mailkit.mailinglist.adduser call
Search

mailkit.sendsms

SMS campaign delivery

XML-RPC request must be sent in the format displayed below. 

NOTICE: Data must be Base64 encoded.

API call example:

JSON

{
    "function": "mailkit.sendsms",
    "id": "client_id",
    "md5": "client_md5",
    "parameters": {
        "campaign": {
            "ID_message": 12346,
            "ID_user_list": 123456,
            "use_utf": false,
            "allow_split": false,
            "source": "SenderName"
        },
        "recipient": {
            "email":"",
            "mobile":"+420777744440",
            "first_name":"John",
            "last_name": "Doe",
            "gender": "m",
            "custom1": "custom field",
            "custom2": "custom field"
        },
        "content": {
            "sms_data": "base64 encoded content",
            "content": {
                "var1": "base64 encoded data",
                "var2": "base64 encoded data"
            }
        }
    }
}

XML

<?xml version="1.0" encoding="UTF-8"?>
<methodCall>
    <methodName>mailkit.sendsms</methodName>
    <params>
        <param>
            <value>
                <int>client_id</int>
            </value>
        </param>
        <param>
            <value>
                <string>client_md5</string>
            </value>
        </param>
        <param>
            <value>
                <struct>
                    <member>
                        <name>ID_message</name>
                        <value>
                            <i4>123456</i4>
                        </value>
                    </member>
                    <member>
                        <name>ID_user_list</name>
                        <value>
                            <i4>12345</i4>
                        </value>
                    </member>
                    <member>
                        <name>use_utf</name>
                        <value>
                            <string>FALSE</string>
                        </value>
                    </member>
                    <member>
                        <name>allow_split</name>
                        <value>
                            <string>FALSE</string>
                        </value>
                    </member>
                    <member>
                        <name>source</name>
                        <value>
                            <string>Sender name</string>
                        </value>
                    </member>
                </struct>
            </value>
        </param>
        
      ------ recipient ------    
        
        <param>
            <value>
                <struct>
                    <member>
                        <name>mobile</name>
                        <value>
                            <i4>+420778535877</i4>
                        </value>
                    </member>
                    <member>
                        <name>email</name>
                        <value>
                            <string>mail@example.com</string>
                        </value>
                    </member>
                    <member>
                        <name>vocative</name>
                        <value>
                            <string>Vocative</string>
                        </value>
                    </member>
                    <member>
                        <name>prefix</name>
                        <value>
                            <string>Prefix</string>
                        </value>
                    </member>
                    <member>
                        <name>last_name</name>
                        <value>
                            <string>Last name</string>
                        </value>
                    </member>
                    <member>
                        <name>first_name</name>
                        <value>
                            <string>First name</string>
                        </value>
                    </member>
                    <member>
                        <name>reply_to</name>
                        <value>
                            <string>example@example.com</string>
                        </value>
                    </member>
                    <member>
                        <name>company</name>
                        <value>
                            <string>Company</string>
                        </value>
                    </member>
                    <member>
                        <name>custom1</name>
                        <value>
                            <string>Custom field 1;</string>
                        </value>
                    </member>
                    <member>
                        <name>custom2</name>
                        <value>
                            <string>Custom field 2</string>
                        </value>
                    </member>
                </struct>
            </value>
        </param>
        
      ------ content ------    
        
        <param>
            <value>
                <struct>
                    <member>
                        <name>sms_data</name>
                        <value>
                            <string>base64 encoded sms content</string>
                        </value>
                    </member>
                    <member>
                        <name>content</name>
                        <value>
                            <struct>
                                <member>
                                    <name>VAR1</name>
                                    <value>
                                        <string>base64 encoded</string>
                                    </value>
                                </member>
                                <member>
                                    <name>VAR2</name>
                                    <value>
                                        <string>base64 encoded</string>
                                    </value>
                                </member>
                                <member>
                                    <name>STORE</name>
                                    <value>
                                        <struct>
                                            <member>
                                                <name>CITY</name>
                                                <value>
                                                    <string>base64 encoded</string>
                                                </value>
                                            </member>
                                            <member>
                                                <name>STREET</name>
                                                <value>
                                                    <string>base64 encoded</string>
                                                </value>
                                            </member>
                                        </struct>
                                    </value>
                                </member>
                            </struct>
                        </value>
                    </member>
                </struct>
            </value>
        </param>
        
    ----------------    
        
    </params>
</methodCall>

Structured

my $result = $server->call(
    'mailkit.sendsms',
    $cid,
    $md5,
    {
        'ID_user_list' => $ID_user_list,
        'ID_message'   => $ID_message,
        'use_utf'      => 'TRUE',
        'allow_split'	=> 'FALSE'
        'source'	=> 'Sendername',
    },
    {
        'email'        => $email,
        'mobile'       => $mobile,
        'custom1'      => 1,
        'custom2'      => 2,
        'custom3'      => 3,
    },
    {
        'sms_data'     => encode_base64("sms message content"),
        'content',
        {
            'company_rpc',encode_base64('Mailkit'),
            'name_rpc',encode_base64('sample name'),
            'test_url',encode_base64('http://www.example.com'),
        },
    },
);

Values

client_id * = client ID can be found in your Mailkit account's menu Profile/Integration.
client_md5 * = MD5 code can be found in your Mailkit account's menu Profile/Integration.​​​​​​​
id_message * = ID of SMS campaign
id_user_list * = ID of mailing list, where will be the recipient added​​​​​​​
use_utf  = allow UTF8 characters in SMS. Can be one of:

  • FALSE (default) = all UTF8 characters will be converted to ASCII (no non-ASCII characters will be in the resulting message)
  • TRUE = UTF8 characters are allowed in SMS (messages with such special characters are limited to 70 characters and any longer message will be split into multiple messages during delivery)

allow_split  = allows long SMS messages to be split to multiple parts (max. 6). Can be one of:

  • FALSE (default) = SMS will not be split
  • TRUE = SMS longer than 160 characters will be split into multiple parts

source = sender name also known as SenderID (optional). This name will be displayed on recipient's device as the sender instead of the number. SMS messages are sent with the default Sender ID "Info". You can use your own sender to send your SMS campaigns. If you want to register it, don't hesitate to contact us. The Sender ID can have a maximum of 11 characters (the following characters are allowed: a-z, A-Z, 1-9, dot, dash and space).Sender name/SenderID needs to be pre-approved by telco operators and availability varies by destination country and network.

mobile * = mobile phone in international format (+420XXXYYYXXX)​​​​​​​
​​​​​​​email = e-mail address of the recipient (optional) - if not provided, system will automatically create a recipient record in the form of +420XXXYYYXXX@mailkit.mobile.

Keep in mind that only e-mail address is the default identificator of each recipient. If an SMS recipient is added without an e-mail at first and with e-mail the second time it will produce two distinct records with no relation to each other.

first_name,
gender,
custom1, ...
 = custom recipient data

sms_data (base64 data) = SMS content encoded using base64

content (base64 data) = variables encoded using base64. Variable can be later used in templates under the names used in the API call, e.g. [% shared.VAR1 -%] or e.g. [% data.STORE.CITY -%] for complex structures..

* required value

Successful call response:

JSON

{
    "status": "0",
    "data": "123456789",
    "data2": "123456",
    "error_status": 0,
    "data3": "123456789"
}

XML

<?xml version="1.0" encoding="utf-8"?>
<methodResponse>
    <params>
        <param>
            <value>
                <struct>
                    <member>
                        <name>data2</name>
                        <value>
                            <i4>12345</i4>
                        </value>
                    </member>
                    <member>
                        <name>data</name>
                        <value>
                            <i4>12345678</i4>
                        </value>
                    </member>
                    <member>
                        <name>error_status</name>
                        <value>
                            <i4>0</i4>
                        </value>
                    </member>
                    <member>
                        <name>status</name>
                        <value>
                            <i4>0</i4>
                        </value>
                    </member>
                    <member>
                        <name>data3</name>
                        <value>
                            <i8>12345678</i8>
                        </value>
                    </member>
                </struct>
            </value>
        </param>
    </params>
</methodResponse>

Values

data = ID of newly created or matched recipient
data2 = ID of sent message
data3 = ID of campaign
status

  • 0 = update (recipient has been updated)
  • 1 = insert (recipient has been inserted)
  • 2 = insert (recipient has been previously unsubscribed and remains unsubscribed)
  • 3 = update (recipient has been previously unsubscribed and remains unsubscribed)
  • 4 = fault (mobile phone had an invalid format and recipient was not inserted)

error_status

  • 0 = succesfull request
  • 1+ = unsuccesfull request

Unsuccessful call response:

JSON

{
    "error_status": 1,
    "error": "Invalid source"
}

XML

<?xml version="1.0" encoding="utf-8"?>
<methodResponse>
    <params>
        <param>
            <value>
                <string>Invalid source</string>
            </value>
        </param>
    </params>
</methodResponse>

Values

Invalid ID_mailing_list = invalid mailing list ID
Missing ID_mailing_list = missing mailing list ID
Invalid ID_message = invalid campaign ID
Missing ID_message = missing campaign ID
Invalid source = invalid Sender ID (either not registered for the account or a Sender ID other than the one registered for the account)
Missing mobile =  missing mobile phone number

Contact us

Let us know what your campaign objectives are and we'll create a plan that works for you.

+420 277 001 800
sales@mailkit.com


Processing of information provided using this form is governed by our Privacy Policy.

Required
Required
Required
Mailkit logo

A Czech emailing platform with its own infrastructure, that is a leader in international mailing distribution.

 

  • Features
  • Services
  • Resources
  • About us

services

  • Email Authentication
  • Agency Partnerships
  • Email Training
  • Inbox Brand Visibility
  • Deliverability

ReSOURCES

  • Knowledge Base
  • API documentation
  • Blog
  • Status
  • BIMI inspector
Logo Maawg
Logo Experience
Logo CSA
Logo Signal spam
Logo ISO-27001
Logo ISO-9001
This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.
© 2006-2022 Mailkit - All rights reserved