This document describes the base API interfaces which can be used with Panacea Mobile.
The API is currently only implemented with a JSON wrapper.
These API's can be accessed with an HTTP client independent of language. We have provided PHP examples to demonstrate the implementation as well as raw HTTP requests in order to assist.
Some general considerations:
= Negative number in status codes indicate an error
= HTTP Keep-Alive is supported and should be used for large numbers of queries.
= Unbilled queries are limited to 10 per minute (message_status, user_get_balance, etc)
Get's a list of contacts for a particular group
Add a contact to a group
Delete a contact
Update an existing contact
Retrieves a list of address book groups
Add's a new address book group
Delete's an address book group
This action affiliate users to create new users, please contact support@panaceamobile.com if you are interested in becoming an affiliate.
Please note that this method returns its own status codes, an english error message will be returned to you, it is at your own discretion to translate these strings.
Public method that sets promotion codes for new users
Retrieves a list of the user batches.
Checks the status of a batch
Create's a new batch, returns batch ID if successful
Starts the given batch
Stops/pauses the given batch
This action allows you to execute multiple actions within the API with a single request.
The payload (with all actions) must be sent in a POST request with a variable named 'data' containing a JSON encoded array of actions to execute.
Public method that returns affiliate country information. Primarily used for detecting number prefixes.
This method provides all a list of all methods currently available in the API and their parameters
This function returns all inbound (MO) messages for the user which have an ID larger than 'last_id'.
Best practice is to use this function starting with last_id = 0, then as messages are received, to store last_id as the highest message ID you receive back from the API request.
Send an SMS message
In the return result, if successful the details key will contain the message ID.
Checks the status of a message
This function can only be used 10 times per minute (to prevent bad implementation :)) if you require status for each message you send please use the report_url and report_mask variables when sending your messages with message_send().
Function to ensure communication
This action allows you to check the price you can expect to pay for a message to the destination in 'to'
This action allow's a third party application to get an authentication key in order to make use of a user's account.
The benefits of using this method is know that the application doesn't have to worry about registration of the user account, it simply redirects the user to a web based location (which is provided) for authentication, once done, if the user allowed it, the application can access the API functions using the new API token.
WARNING: Request key's generated here can only be guaranteed to be valid for 1 hour, so you *MUST* call user_get_api_key() after the process has been completed.
Once the user_authorize_application() action is completed and the user has returned to your application, you must call user_get_api_key() to create a permanent API key.
Get's the user balance
This function returns the verified phone number for the given user
Transfer credit from one account to another
Authentication failure
Could not save
Duplicate record found (when adding)
Internal error
Invalid record
API Request Key created
Message sent/queued
There was a required parameter missing from the request (see 'details' key in result for more information)
No action was specified in the request
There was no matching action found
Generic OK
Out of credit
Routing error
User is not part of any affiliate program
Batch is busy being processed
There was an error processing the batch
The batch is waiting to be filtered Set the batch to this status if you wish for it to be filtered.
Batch is busy being filtered
Batch is waiting to be processed
Batch is busy being parsed
Parsing of the batch has been paused
Batch has been parsed and is currently paused
Batch is waiting to be processed (no action required)
Batch has been submitted
User has reached maximum registrations during specified period.
Message acknowledged
Message has been delivered
Message does not exist
Failed
var @int
Filtered (blocked or previously failed)
Message failed (internal error)
Routing error
Message has been sent to the networks
Documentation generated on Tue, 03 May 2011 16:17:12 +0200 by Panacea Mobile