Last updated: July 9th 2025

Node.JS / Javascript Library Introduction

Using a single Node.JS library, Node.JS developers can send SMS messages using their own software.

Register your account

If you don't have an account, head to https://bestsms.au/signup and fill in the form.


Create an API user

To access the API, you'll need a User with API access:

  1. Login to the BestSMS Dashboard
  2. Navigate to 'Users'
  3. Create a new user or select an existing one
  4. Enable API access (if it's not already enabled)
  5. Click on the 'API' tab
  6. Enable 'Auth Token' and create a new Auth Token
  7. Click the ' Copy' button to copy it to your clipboard
  8. Paste the Auth Token into the Authorization Header in your application or code

At any time, you can refresh your Auth Token by clicking the button and exporting your new Auth Token. This action will invalidate any apps using your old Auth Token.

Auth Tokens can be used for multiple use-cases, with SubAccount and Department values helping in tracking reporting and billing.

API v2.04 utilises JWT token Authentication. For OAuth2 authentication options, contact your BestSMS representative.


Understanding the Node.JS Library basics

Save hundreds of lines of code and hours of time by add the BestSMS Node.JS library into your project. Using one package and simple code tweaks, your software can send SMS messages.


Download the Library:

Download and install the 'bestsms' using npm: npm i bestsms

BestSMS npm Package



Reference the Library:

Reference the library in your code: const BestSMS = require('bestsms');



Send Messages using the Library:

Using the [request].SendMessage(callback_function); function, the package will connect to BestSMS's REST API (in JSON format) and send messages.



Capture Status & Replies using the Library:

Message Status and Received Messages can be captured using a Webhook (a POST to your nominated URL), or can be Polled for using the Library's [request].Poll(callback_function); function.

See Status Reporting and Receive Messages.

Send Messages - build your application with the Node.JS Library

Find instructions for each Message Type:

Sending SMS - Send SMS/TXT via Node.JS

 

Send SMS (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response: ",JSON.stringify(data, null, "  "));
};

client.Messaging.SMS.SendMessage({
    Reference: "Test",                  // Optional
    Message: "Test SMS",                // SMS Message
    Destinations: [                     // SMS Recipients
      { Recipient: "+61411111111" },
      { Recipient: "+61422222222" }
    ]
}).then(callback); // Send Message                                                 

Copy code

Send SMS (Advanced):


const BestSMS = require('bestsms');
const ContactModel = require('bestsms/lib/Api/Addressbook/Contacts/models/ContactModel');
const GroupModel = require('bestsms/lib/Api/Addressbook/Groups/models/GroupModel');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response: ",JSON.stringify(data, null, "  "));
};

client.Messaging.SMS.SendMessage({

    MessageID: "ID12345",                             // MessageID - Leave blank to auto-generate
    Reference: "Test SMS - Advanced version",         // Reference
    SMSEmailReply: "[email protected]",                // Email address to receive reply back
    CharacterConversion: true,                        //  Convert multi-byte characters into normalised GSM character
    Message: "Test SMS Message for [[Attention]] at [[Company]]. Click [[File1]] | [[File2]] to download files.",                              // SMS Message
    Destinations: [                                   // SMS Recipients
        {
            Recipient: "+61411231234",                // Recipient Mobile Number
            Company: "Test Company",                  // Company Name
            Attention: "Test Recipient",              // Attention
            Custom1: "Custom1",                       // Custom Field
            Custom2: "Custom2",
            Custom3: "Custom3",
            Custom4: "Custom4",
            Custom5: "Custom5"
        },
        {
            Recipient: "+61471231234",                // Recipient Mobile Number
            Company: "Test Company 2",                // Company Name
            Attention: "Test Recipient 2",            // Attention
            Custom1: "Custom1",                       // Custom Field
            Custom2: "Custom2",
            Custom3: "Custom3",
            Custom4: "Custom4",
            Custom5: "Custom5"
        },
        {
            Group: new GroupModel({
                GroupID: "GGGGGGGG-AAAA-AAAA-AAAA-AAAAAAAAAAAA"
            })
        },
        {
            GroupID: "GGGGGGGG-BBBB-BBBB-BBBB-BBBBBBBBBBBB"
        },
        {
            Contact: new ContactModel({
                ContactID: "CCCCCCCC-AAAA-AAAA-AAAA-AAAAAAAAAAAA",
            })
        },
        {
            ContactID: "CCCCCCCC-BBBB-BBBB-BBBB-BBBBBBBBBBBB"
        }
    ],
    Attachments: [
        "D:/File1.pdf",
        "D:/File2.pdf",
    ]
    
}).then(callback); // Send Message                                                 

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
Message Hello, this is a test message from Department01. Thank you. Plain or UTF-8 formatted SMS message
Destinations {"Recipient": "+61421000002"} Mobile number to receive the message (for detailed formatting, see the Destinations parameter below)

Optional parameters

Parameter Example Value Description
MessageID ID12345 A Message Identifier helps you keep track of each message (maximum 40 characters, alphanumeric). Use a unique MessageID for each request. If you leave this field blank, the API will generate a 36-character UUID (v4) for you and include it in the response body.
Reference Test1 Human readable message description (free format field, maximum 80 characters).
SendTime new DateTime() Delay sending until the specified date/time (YYYY-MM-DD HH:mm in your local timezone, specified by your Sender setting or overridden using the TimeZone command)
TimeZone AUS Eastern User's local timezone
SubAccount SubAccount01 Used for reporting, billing and Web Dashboard segmentation.
Department Department01 Used for reporting, billing and Web Dashboard segmentation.
ChargeCode BillingGroup01 Bespoke app cost allocation code (for invoice segmentation)
FromNumber +61421000001 Setting SMS origination number.
SMSEmailReply [email protected] For email (SMTP) reply receipt notifications
CharacterConversion True Convert multi-byte characters into normalised GSM character format. ie. © to (C)
Message Hi Jess, your Happy Fitness membership renewal is due next week. Reply YES to renew or call (03) 9876 5432 for any questions. Reply STOP to opt out. An example Message
Destinations > Recipient +61421000001 Recipient of the SMS in E.164 internationalised format
> Attention John Doe Recipient's friendly name
> Company Example Corp Recipient's company
> Custom1 Customisable field
> Custom2 Customisable field

Sending messages in test mode

Under request object you can specify an additional Mode=Test parameter.

Mode=Test means any messages will be handled by the API, instantly called a SUCCESS and the success report will be delivered to you. This is a useful way to end-to-end test without sending a live message.


# Test mode
request.Mode = "Test"
                                              

Edit Messages - Edit a submitted message

Once a message has been sent, you can retry a failed message, reschedule a delayed message, abort a delayed message and edit the NumberOfOperators value on Voice/TTS messages.


Retry Sending - Resubmit a failed message

If your message is 'Failed' (sending completed and was unsuccessful), you can use this API module to retry sending.

The Retry is applied to a specific MessageID. If you use common MessageID values across multiple messages, it will apply to the most recent message and only if the Status was Failed.


Set Resubmit:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Resubmit.SendRequest({
    MessageID: "ID123456",                   // MessageID generated from system OR your message ID if specified
}).then(callback);                                          

Copy code

Set Resubmit:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Resubmit.SendRequest({
    MessageID: "ID123456",                   // MessageID generated from system OR your message ID if specified
    SendTime: "2023-09-01T12:30"
}).then(callback);                                          

Copy code

ResubmitRequest Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
MessageID ID123456 MessageID the Action should apply to

ResubmitRequestResult object parameters

Parameter Example Value Description
Result Success Result of your API call (not the result of the message)
Status Transmit Current Status of your message
JobNum ABCD1234 Your Job Number
Action Resubmit What action (Resubmit) was requested
ErrorMessage ["Missing Sender"] Reason for the API call failure



Reschedule Sending - Adjust the Delayed Sending Date/Time

If you have an existing Delayed message (scheduled for sending at a future date/time), you can use this API module to adjust the sending date/time.

The adjustment is applied to a specific MessageID. If you use common MessageID values across multiple messages, it will apply to the most recent message.


Set Reschedule:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Reschedule.SendRequest({
    MessageID: "ID123456",                  // MessageID generated from system OR your message ID if specified
    SendTime: "2023-09-01T00:00"            // New Date/Time
}).then(callback);                                          

Copy code

Set Reschedule:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Reschedule.SendRequest({
    MessageID: "ID123456",                  // MessageID generated from system OR your message ID if specified
    SendTime: "2023-09-01T00:00"            // New Date/Time
}).then(callback);
                                          

Copy code

RescheduleRequest Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
MessageID ID123456 MessageID the Action should apply to
SendTime 2020-05-12 14:05:00 Reschedule sending for the specified date/time (YYYY-MM-DD HH:mm in your Account/Sender's default timezone setting)

RescheduleRequestResult object parameters

Parameter Example Value Description
Result Success Result of your API call (not the result of the message)
Status Delayed Current Status of your message
JobNum ABCD1234 Your Job Number
Action Reschedule What action (Reschedule) was requested
ErrorMessage ["Missing Sender"] Reason for the API call failure



Abort Sending - Cancel/Delete a Message from the Queue

If you have an existing Delayed message (scheduled for sending at a future date/time) you can use this API module to Cancel sending of the message.

The cancellation is applied to a specific MessageID. If you use common MessageID values across multiple messages, it will apply to the most recent message.


Set Abort:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Abort.SendRequest({
    MessageID: "ID123456"                     // MessageID generated from system OR your message ID if specified
}).then(callback);
                                          

Copy code

Set Abort:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Actions.Abort.SendRequest({
    MessageID: "ID123456"                     // MessageID generated from system OR your message ID if specified
}).then(callback);
                                          

Copy code

AbortRequest Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
MessageID ID123456 MessageID the Action should apply to

AbortRequestResult object parameters

Parameter Example Value Description
Result Success Result of your API call (not the result of the message)
Status Pending Current Status of your message
JobNum ABCD1234 Your Job Number
Action Abort What action (Abort) was requested
ErrorMessage ["Missing Sender"] Reason for the API call failure

Status Reporting - Reporting and event tracking

Delivery Reports advise whether delivery was successful. If not, it will describe why.

Each delivery report type is optional and multiple delivery report types can be used.



Web Dashboard - Tracking message statuses via the online dashboard

You will be supplied with a Web Dashboard login at registration. The Dashboard can be used to set up new sender/token pairs, as well as track sent and replied messages. You can drill into specific messages to view individual events, such as delivery attempts, retries, replies, results, clicks, etc.



SMTP Email - Receive message statuses via email

Delivery reports are emailed as an HTML email for viewing by an end-user. Your sales representative can enable this for you.

Whitelabelling of SMTP Email reports is available.

The email address to receive SMS Reply reports can be specified on the original message submission using the SMSEmailReply parameter.



Webhook - Message statuses delivered via a webhook

If you are set up to receive Status webhooks, you will also be receiving SMS Received webhooks.

To receive Delivery Reports via Webhook, please advise the URL to submit to.

Webhooks are delivered as an HTTP POST in either XML or JSON format (your preference).
Webhook failures are retried every five minutes for a maximum of 24 hours.

Supplied parameters are:



Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
Type SMS Type of Message ('Email', 'SMS', 'Fax', 'Voice' or 'TextToSpeech')
Destination +61421000001 Destination that the webhook is for (alphanumeric field, where telephone/mobile numbers are supplied in E.164 internationalised format)
MessageID js82hn8n MessageID parameter supplied when sending your original API call
SubAccount SubAccount01 Used for reporting, billing and Web Dashboard segmentation
Department Department01 Used for reporting, billing and Web Dashboard segmentation
JobNumber 10C7B9A0 Eight digit alphanumeric tracking number (our internal Job Number)
SentTime 16/10/2018 13:43 p.m. Time message was completed (Sender's local time time in 'YYYY-MM-DD HH:mm tt' format)
Status SUCCESS For submission results, values are SUCCESS, FAILED, PENDING
For reply reports, this will be RECEIVED
For additional analytics, this will be UPDATED
Result Sent OK Final delivery result and/or the cause for a message delivery failure
Message Field will be blank; it is used by the Receive Messages webhook only
Price 0.20 Your cost for this transaction, charged by us to you
Detail SMSParts:2 Additional billing detail: "SMSParts", "FaxPages", "VoiceMinutes", "Size", "Prompts"
URL https://www.example.com/webhook The URL this webhook is sent to
RESPONSEMODE JSON This webhook's format


GET Status Poll - Track message statuses using a GET poll

You are able to poll for the status of a message via the GET Status API.

The Poll should be configured to timeout after 48 hours with no result.

Reference : BestSMS.Messaging.Get

Get Status:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.Status.Poll({
    MessageID: "ID123456",                    // MessageID generated from system OR your message ID if specified
}).then(callback);
                                          

Copy code

Get Status:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.Status.Poll({
    MessageID: "ID123456",                    // MessageID generated from system OR your message ID if specified
    RecordsPerPage: 10,                       // x number of records
    Page: 1                                   // Current location
}).then(callback);
                                          

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
MessageID ID123456 Your provided Message ID or BestSMS generated Message ID

Receive Messages - Track messages received

Currently, tracking SMS Received is supported.

Tracking of faxes and voicemail received is scheduled for a future release. Let your account manager know if this interests you.



Web Dashboard - Tracking messages received via the online dashboard

You will be supplied with a Web Dashboard login at registration. The Dashboard can be used to set up new sender/token pairs, as well as track sent and replied messages. You can drill into specific messages to view individual events, such as delivery attempts, retries, replies, results, clicks, etc.



SMTP Email - Track messages received via email

Delivery reports are emailed as an HTML email for viewing by an end-user. Your sales representative can enable this for you.
Whitelabelling of SMTP Email reports is available.

When submitting SMS messages, specify the SMSEmailReply parameter.



Webhook - Messages received data delivered via a webhook

If you are set up to receive Status webhooks, you will also be receiving SMS Received webhooks.

To receive SMS replies via Webhook, please advise the URL to submit to.

Webhooks are delivered as an HTTP POST in either XML or JSON format (your preference).
Webhook failures are retried every five minutes for a maximum of 24 hours.

The mobile has 7 days to reply to a message. Any replies received after the 7 day window will be treated as a new message.


Supplied parameters are:


Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
Type SMSReply Type of Message ('Email', 'SMS', 'Fax', 'Voice', 'TextToSpeech', 'SMSInbound' or 'SMSReply')
Destination +61421000001 Mobile number sending the SMS message (alphanumeric field, where telephone/mobile numbers are supplied in E.164 internationalised format)
MessageID js82hn8n MessageID parameter supplied when sending your original API call
SubAccount SubAccount01 Used for reporting, billing and Web Dashboard segmentation
Department Department01 Used for reporting, billing and Web Dashboard segmentation
JobNumber 10C7B9A0 Eight digit alphanumeric tracking number (our internal Job Number)
SentTime 16/10/2018 13:43 p.m. Time reply message was received
Status RECEIVED For submission results, values are SUCCESS, FAILED, PENDING
For reply reports, this will be RECEIVED
For additional analytics, this will be UPDATED
Result RECEIVED Final delivery result and/or the cause for a message delivery failure
For reply reports, this will be RECEIVED
For additional analytics, this will be the event description
Message This is a reply. The received SMS message (if 'Type=SMSInbound' or 'Type=SMSReply')
Price 0.20 Your cost for the outbound message sent, charged by us to you (no cost for the reply received)
Detail SMSParts:2 Additional billing detail: "SMSParts", "FaxPages", "VoiceMinutes", "Size", "Prompts" on the outbound message sent (not the SMS Received)
URL https://www.example.com/webhook The URL this webhook is sent to
RESPONSEMODE JSON This webhook's format


GET SMS Received Poll - Track SMS Received using a GET poll

You are able to poll for all received SMS messages in a given time-frame.

The Poll should be configured to timeout after 48 hours with no result.

Reference : BestSMS.Messaging.Get

 

Get SMS Received:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.SMSReceived.Poll({
    TimePeriod: 1440                          // Return results from the last x minutes
    RecordsPerPage: 10,
    Page: 1
}).then(callback);                                          

Copy code

Get SMS Received:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.SMSReceived.Poll({
    DateFrom: "2023-06-01T00:00:00",          // Return results from the date/time
    DateTo: "2023-06-30T23:59:59",            // Return results to the date/time
    RecordsPerPage: 10,                       // x numbers of records to return per request
    Page: 1                                   // current location
}).then(callback);                                          

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
TimePeriod 1440 Return results from the last x minutes
DateFrom 2022-08-01T00:00:00 Return results from the specified date (optional)
DateTo 2022-08-01T23:59:59 Return results to the specified date (optional)
RecordsPerPage 20 Return x number of records per request (optional)
Page 1 Current location of the result set (optional)

SMSReceivedResult object parameters

Parameter Example Value Description
Result Success Result of your API call (not the result of the message)
ReceivedMessages SMSReceivedMessage List of SMS messages received
ErrorMessage ["Missing Sender"] Reason for the API call failure

SMSReceivedMessage object parameters

Parameter Example Value Description
Date 2019-12-01 14:02:03 Date/Time SMS was received (yyyy-mm-dd HH:mm:ss)
From +61421000001 Sender of the SMS in E.164 internationalised format
MessageText This is a reply back from the mobile phone. The SMS message received


GET SMS Reply Poll - Track SMS replies using a GET poll

You are able to poll for replies to a specific SMS message, tracked using the MessageID on the outbound message.

The Poll should be configured to timeout after 48 hours with no result.

Reference : BestSMS.Messaging.Get

Get SMS Reply:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

request.Poll(callback);

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.SMSReply.Poll({
    MessageID: "ID123456",                    // MessageID generated from system OR your message ID if specified
    Page: 1                                   // Current location
}).then(callback);                                          

Copy code

Get SMS Reply:


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
  console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Reports.SMSReply.Poll({
    MessageID: "ID123456",                    // MessageID generated from system OR your message ID if specified
    RecordsPerPage: 10,                       // x number of records per page
    Page: 1                                   // Current location
}).then(callback);
                                          

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
MessageID ID123456 Your provided Message ID or BestSMS generated Message ID

SMSReceivedResult object parameters

Parameter Example Value Description
Result Success Result of your API call (not the result of the message)
Status Received Status of your job
MessageID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Your provided Message ID or BestSMS generated Message ID
JobNum 10AB20CE Eight digit alphanumeric tracking number (our internal Job Number)
Account 102030 Your BestSMS Account
SubAccount Your supplied BestSMS SubAccount
Department Your supplied BestSMS Department
SentMessage SMSSentMessage Object Details of your sent message
ReceivedMessages SMSReceivedMessage Objects Details of your received message(s)
ErrorMessage ["Missing Sender"] Reason for the API call failure

SMSSentMessage object parameters

Parameter Example Value Description
Date 2019-12-01 14:02:03 Date/Time SMS was received (yyyy-mm-dd HH:mm:ss)
Destination 6421000001 Recipient of the SMS in E.164 internationalised format
MessageText This is an outbound message sent via API. Plain or UTF-8 formatted SMS message sent

SMSReceivedMessage object parameters

Parameter Example Value Description
Date 2019-12-01 14:02:03 Date/Time SMS was received (yyyy-mm-dd HH:mm:ss)
From +61421000001 Sender of the SMS in E.164 internationalised format
MessageText This is a reply back from the mobile phone. The SMS message received

List Contact - List Contact via BestSMS NodeJS Library

 

List Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.List({
    Page: 1
}).then(callback);            

Copy code

List Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.List({
    RecordsPerPage: 10,
    Page: 1
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token

Optional parameters

Parameter Example Value Description
RecordsPerPage 50 Specifies the number of records per page to be returned. If not provided, the default number (100) of records per page will be used.
Page 1 Specifies the page number of the contact list to retrieve. If not provided, the default (1) behaviour will be followed.

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
TotalRecords int 3 Total number of contacts
RecordsPerPage int 100 Return x number of records per request (optional)
PageCount int 1 Maximum number of pages
Page int 1 Current location of the result set (optional)
Contacts Array() Contact object list List of contacts
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Get Contact Detail - Get Contact Detail via BestSMS NodeJS Library

 

Get Contact Detail (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Detail({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Get Contact Detail (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Detail({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to retrieve.

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Contact object properties

Property Type Example Value Description
ID string AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Unique identifier for the contact
Owner string COM\EXAMPLE\TEST Your UserKey
Created datetime 2023-12-01T12:00:00 Creation date for this contact in your local date/time
CreatedUTC datetime 2023-12-01T00:00:00 Creation date for this contact in UTC date/time
Updated datetime 2023-12-01T12:00:00 Last updated date for this contact in your local date/time
UpdatedUTC datetime 2023-12-01T00:00:00 Last updated date for this contact in UTC date/time
Timezone string AUS Eastern Timezone associated with Created/Updated date/time
Attention string Person Attention Indicates the attention or focus associated with the contact.
Title string Ms Represents the title or honorific of the contact (e.g., Mr, Mrs, Ms).
Company string BestSMS Specifies the company or organization associated with the contact.
CompanyDepartment string Sales Dept. Indicates the department or division within the company associated with the contact.
FirstName string Person first name Represents the first name of the contact.
LastName string Person last name Represents the last name of the contact.
Position string Sales Represent Specifies the job position or role of the contact.
StreetAddress string Sales Represent Represents the street address or location of the contact.
Suburb string My Suburb Specifies the suburb or district associated with the contact's address.
City string Auckland Indicates the city or locality associated with the contact's address.
State string AKL Represents the state or province associated with the contact's address.
Country string AUS Eastern Specifies the country associated with the contact's address.
Postcode string 1234 Represents the postal code or ZIP code associated with the contact's address.
MainPhone string 092223333 Specifies the main phone number of the contact. This property typically used for Voice & Text-To-Speech messages.
AltPhone1 string 093334444 Represents an alternate phone number for the contact. This property typically used for Voice & Text-To-Speech messages.
AltPhone2 string 094445555 Represents a second alternate phone number for the contact. This property typically used for Voice & Text-To-Speech messages.
DirectPhone string 094445555 Indicates the direct phone number of the contact.
MobilePhone string 0211144489 Represents the mobile phone number of the contact. This property typically used for SMS messages.
FaxNumber string 093334444 Specifies the fax number associated with the contact.
EmailAddress string [email protected] Represents the email address of the contact.
WebAddress string https://bestsms.au Specifies the website address or URL associated with the contact.
Custom1...4 string Custom Value Represents custom fields or additional information associated with the contact.
ViewBy string Account Specifies the visibility of the contact. Values can be "Account", "SubAccount", "Department" or "No" visibility option.
EditBy string Account Specifies the permission level required to edit the contact. Values can be "Account", "SubAccount", "Department" or "No" permission option.

Create Contact - Create Contact via BestSMS NodeJS Library

 

Create Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Create({
    Attention: "Test Person",
    FirstName: "First",
    LastName: "Last",
    MobilePhone: "+61421000001",
}).then(callback);            

Copy code

Create Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Create({
    Title: "Mr",
    Company: "BestSMS",
    FirstName: "First",
    LastName: "Last",
    MobilePhone: "+61421000001",
    ViewBy: "Account",
    EditBy: "Account"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Update Contact - Update Contact via BestSMS NodeJS Library

 

Update Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Update({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    Attention: "Test Attention"
}).then(callback);            

Copy code

Update Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Update({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    Attention: "Test Attention"
    Title: "Mr",
    Company: "BestSMS",
    FirstName: "First",
    LastName: "Last",
    MobilePhone: "+61422223333",
    ViewPublic: "Account",
    EditPublid: "Account"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to update.

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Delete Contact - Delete Contact via BestSMS NodeJS Library

 

Delete Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Delete({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Delete Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Contact.Delete({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to delete.

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

List Contact Group - List Contact Group via BestSMS NodeJS Library

 

List Contact Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.List({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    Page: 1
}).then(callback);            

Copy code

List Contact Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.List({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    RecordsPerPage: 10,
    Page: 1
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to retrieve. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
TotalRecords int 3 Total number of groups associated with this contact
RecordsPerPage int 100 Return x number of records per request (optional)
PageCount int 1 Maximum number of pages
Page int 1 Current location of the result set (optional)
Contact object Contact object Contact detail
Groups Array() Group object list List of groups associated with this contact
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Get Contact Group Detail - Get Contact Group Detail via BestSMS NodeJS Library

 

Get Contact Group Detail (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Detail({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Get Contact Group Detail (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Detail({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to retrieve. (required)
GroupCode TEST_GROUP Specifies the unique identifier of the group to retrieve. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
Contact object Contact object Contact detail
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Create Contact Group - Create Contact Group via BestSMS NodeJS Library

 

Create Contact Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Create({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Create Contact Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Create({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to create. (required)
GroupCode TEST_GROUP Specifies the unique identifier of the group to create. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Contact object Contact object Contact detail
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Delete Contact Group - Delete Contact Group via BestSMS NodeJS Library

 

Delete Contact Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Delete({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Delete Contact Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Delete({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to delete. (required)
GroupCode TEST_GROUP Specifies the unique identifier of the group to delete. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Contact object Contact object Contact detail
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

List Group - List Group via BestSMS NodeJS Library

 

List Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.List({
    Page: 1
}).then(callback);            

Copy code

List Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.List({
    RecordsPerPage: 10,
    Page: 1
}).then(callback);
            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token

Optional parameters

Parameter Example Value Description
RecordsPerPage 50 Specifies the number of records per page to be returned. If not provided, the default number (100) of records per page will be used.
Page 1 Specifies the page number of the contact list to retrieve. If not provided, the default (1) behaviour will be followed.

Response properties

Property Type Example Value Description
Result string Success Result of your API call (not the result of the message)
TotalRecords int 3 Total number of records
RecordsPerPage int 100 Return x number of records per request (optional)
PageCount int 1 Maximum number of pages
Page int 1 Current location of the result set (optional)
Groups object Group object list List of group
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Group Detail - Group Detail via BestSMS NodeJS Library

 

Group Detail (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Detail({
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Group Detail (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Detail({
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to retrieve. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Group object properties

Property Type Example Value Description
GroupCode string Test-Group Unique identifier for the group
GroupName string Test Group Represents the name of the group.
SubAccount string SubAccount01 Used for reporting, billing and Web Dashboard segmentation.
Department string Department01 Used for reporting, billing and Web Dashboard segmentation.
ViewEditBy string Account Specifies the permission level required to view/edit the group. Values can be "Account", "SubAccount", "Department" or "No" permission option.
Owner string COM\EXAMPLE\TEST Your UserKey

Create Group - Create Group via BestSMS NodeJS Library

 

Create Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Create({
    GroupName: "Test Group"
}).then(callback);            

Copy code

Create Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Create({
    GroupName: "Test Group",
    ViewEditBy: "Account"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to create. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Update Group - Update Group via BestSMS NodeJS Library

 

Update Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Update({
    GroupCode: "Test_Group",
    GroupName: "Test Group 123"
}).then(callback);            

Copy code

Update Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Update({
    GroupCode: "Test_Group",
    GroupName: "Test Group 123",
    SubAccount: "Test",
    ViewEditBy: "Account"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to update. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Delete Group - Delete Group via BestSMS NodeJS Library

 

Delete Group (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Delete({
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Delete Group (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.Group.Delete({
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to delete. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

List Group Contact - List Group Contact via BestSMS NodeJS Library

 

List Group Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.List({
    GroupCode: "Test_Group",
    Page: 1
}).then(callback);            

Copy code

List Group Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.List({
    GroupCode: "Test_Group",
    RecordsPerPage: 10,
    Page: 1
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to retrieve. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
TotalRecords int 3 Total number of groups associated with this contact
RecordsPerPage int 100 Return x number of records per request (optional)
PageCount int 1 Maximum number of pages
Page int 1 Current location of the result set (optional)
Group object Group object Group detail
Contacts Array() Contact object list List of contacts associated with this group
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Get Group Contact Detail - Get Group Contact Detail via BestSMS NodeJS Library

 

Get Group Contact Detail (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Create({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Get Group Contact Detail (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.ContactGroup.Create({
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD",
    GroupCode: "Test_Group"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to retrieve. (required)
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to retrieve. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Create Group Contact - Create Group Contact via BestSMS NodeJS Library

 

Create Group Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.Create({
    GroupCode: "Test_Group",
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Create Group Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.Create({
    GroupCode: "Test_Group",
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to create. (required)
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to create. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Delete Group Contact - Delete Group Contact via BestSMS NodeJS Library

 

Delete Group Contact (Basic):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.Delete({
    GroupCode: "Test_Group",
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Delete Group Contact (Advanced):


const BestSMS = require('bestsms');

const client = new BestSMS({
    AuthToken: "[Your Auth Token]"          // Auth Token
});

var callback = function(data) {
    console.log("Response:",JSON.stringify(data, null, "  "));
}

client.Addressbook.GroupContact.Delete({
    GroupCode: "Test_Group",
    ContactID: "AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD"
}).then(callback);            

Copy code

Required parameters

Parameter Example Value Description
AuthToken eyJhbGciOiJI...adQssw5c Auth Token value set up in Create a new API Auth token
GroupCode TEST_GROUP Specifies the unique identifier of the group to delete. (required)
ContactID AAAAAAAA-BBBB-BBBB-CCCC-DDDDDDDDDDDD Specifies the unique identifier of the contact to delete. (required)

Response properties

Property Type Example Value Description
Result string Success Result of your API call
Group object Group object Group detail
Contact object Contact object Contact detail
ErrorMessage Array() ["Missing Sender"] Reason for the API call failure

Versioning

As new versions of the APIs are released, this API reference guide will be updated to reflect the latest version and features supported:
API Version ChangeLog


Frequently Asked Questions

The maximum request size supported is 20MB. This is our server side limitation. Your client side limitation may be smaller.
There is no limit to the number of Destinations (in either format), provided you do not breach the maximum request size.
SMS messages are sent and charged in blocks of characters. One text message is 160 characters. By default, we will limit your message to three-message-parts in length (459 characters using the GSM character set, or 210 characters using Unicode/UCS-2). This can be increased on request. See the SMS Message Parts and Concatenated SMS guide for further information.
Yes, encrypted submissions are accepted via HTTPS. SSL/TLS is also supported for outbound email messages provided the receiving email server supports this.
Some networks support customised SMS Caller IDs. This can be configured upon the request.