www.reach-interactive.com
Open in
urlscan Pro
62.7.174.71
Public Scan
URL:
https://www.reach-interactive.com/sms-api/api/
Submission: On September 07 via manual from GB
Submission: On September 07 via manual from GB
Form analysis
0 forms found in the DOMText Content
* * * +44 (0) 3333 111 020 * sales@reach-data.com * Contact Reach * * FEATURES * WEB BASED SMS * SHORT CODES * EMAIL SMS * ATTACH DOCUMENTS * LANDING PAGES * LINK SHORTENING * INBOUND TEXT NUMBERS * PRICING * WHY REACH? * ABOUT REACH * WHY USE SMS? * BUSINESS BENEFITS * SUCCESS STORIES * RESOURCES & BLOG * OUR CHARITY PROGRAMME * THE REACH PODCAST * CONTACT REACH * SMS API * LOGIN * FREE TRIAL * Menu * FEATURES * WEB BASED SMS * SHORT CODES * EMAIL SMS * ATTACH DOCUMENTS * SMS API * LINK SHORTENING * INBOUND TEXT NUMBERS * PRICING * WHY REACH? * ABOUT REACH * WHY USE SMS * BULK SMS PROVIDER * BUSINESS BENEFITS * SUCCESS STORIES * RESOURCES & BLOG * OUR CHARITY PROGRAMME * THE REACH PODCAST * CONTACT REACH * SMS API * LOGIN * FREE TRIAL * FEATURES API GET YOUR API KEY LOGIN FREE TRIAL FEATURES API ORDER 10K TEXTS GET 10K FREE * Introduction * SMPP * Authentication * HTTP Status Codes * DLR Codes * Messaging * Balance * Message Send * Message Details * Message Delete * Delivery Report * Inbound SMS API DOCUMENTATION Our API gateway lets you connect to our interfaces over HTTP/S and allows your applications to integrate SMS over the internet. Our API uses a RESTful endpoint and our request and response payloads are formatted as JSON but we also provide GET as an alternative. All you need to use our service is a free account and your authentication details are accessible after you sign up. SMPP We support SMPP Version 3.4. If you require an SMPP bind, please contact sales@reach-data.com and we will happy to set things up for you. Authentication All requests require your username and password being passed across in the header. These can be found once you have logged in under Support > Developer > API Details Header Description username Your Reach Interactive API Username password Your Reach Interactive API Password HTTP Status Code Code Description 200 Successful Request 400 Details not correct or missing mandatory parameters 401 Invalid Account details 402 Out of Credits 403 Account forbidden for this action. 500 Service error. 503 The Service is unavailable. DLR Codes DLR codes are the same for our API's and our SMPP binds. Code Description 000 Delivered 600 No credits to send 601 No route 602 Blacklisted number detected 603 Bad destination number 604 Bad source number 605 Target SMSC message queue 606 Target SMSC submit fail 607 General error 608 Spam message detected 609 Validity period expired 610 Unauthorised Source address 611 Unknown DLR code 612 Submit timeout Messaging The URI for this section is https://api.reach-interactive.com/sms/[Action] Balance Action The URI for this section is GET/sms/balance Required Parameters There are no extra parameters for the Balance * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/balance"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "GET"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Balance: {1}, Description: {2}", data["Success"], data["Balance"], data["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl http://api.reach-interactive.com/sms/balance -H username: YourReachUserName' -H password: YourReachPassword'; <?php $url = "http://api.reach-interactive.com/sms/balance"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_HTTPGET, true); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Message Send Creates a new message object. We return an array of each Id generated. Per request, a max of 50 recipients can be entered. POST/sms/message Required Parameters Parameter Description to The Number that you want to send to, can be multiple numbers seperated by a ',' or ';' from Who the message will appear to be from message The message to send to the phone, the first 160 characters will be a single message, anything over will be split down into messages the size of 153 characters. For Unicode, this is the text encoded in hexadecimal For Binary messaging, this the User Data (140 octets max) Optional Parameters Parameter Description Default valid How many hours that you require us to try to send the SMS for before it is expired, the minimum for this is 15 minutes (0.25) 72 reference A reference that you want saved against the message in our system callbackUrl The URL that you want us to send the delivery report to. See below in the Delivery Report for more information scheduled The Date and Time you want the message to be sent (yyyy/MM/dd hh:mm) coding The type of message you would like to send, 1 = Text, 2 = Unicode, 3 = Binary 1 udh User Data Header Example JSON Payload { "to" : "447xxxxxxxxx", "from" : "Reach", "message" : "Test Json Send" } * C# * cURL * PHP using System; using System.Collections.Generic; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/message"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "POST"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var streamWriter = new StreamWriter(request.GetRequestStream())) { string json = "{ \"to\" : \"447xxxxxxxxx\", \"from\" : \"Reach\", \"message\" : \"Test API Message\"}"; streamWriter.Write(json); streamWriter.Flush(); streamWriter.Close(); } using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); foreach (Dictionary<string, dynamic> item in data) { Console.WriteLine("Success: {0}, Id: {1}, Description: {2}", item["Success"], item["Id"], item["Description"]); } } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int) ((HttpWebResponse) err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl -X "POST" http://api.reach-interactive.com/sms/message -H username: YourReachUsername -H password: YourReachPassword -H "Content-Type: application/json -d "{\"to\":\"RecipientPhoneNumber\",\"from\":\"FromName\",\"message\":\"YourMessage\"}" <?php $url = "http://api.reach-interactive.com/sms/message"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'Content-Type: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; $data = array("to" => "447xxxxxxxxx", "from" => "Reach", "message" => "Test API PHP send"); $data_string = json_encode($data); //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_POSTFIELDS, $data_string); curl_setopt($crl, CURLOPT_CUSTOMREQUEST, "POST"); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Message Details This can be used to retreive the details of a message sent over our API or SMPP binds. GET/sms/message/{Id} * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "GET"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, To: {1}, From: {2}, Text: {3}, Sent: {4}, Status: {5}, Delivered: {6}, Code: {7}, Description: {8}", data[0]["Success"], data[0]["To"], data[0]["Originator"], data[0]["Text"], data[0]["Sent Date"], data[0]["Message Status"], data[0]["Delivered Date"], data[0]["DlrCode"], data[0]["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl http://http-1-uat.reach-interactive.com/sms/message/{id} -H username: YourReachUsername -H password: YourReachPassword <?php $url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_HTTPGET, true); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Returned Response [{ "Method":"H", "To":"447xxxxxxxxx", "Originator":"Reach", "Text":"Your Message", "Sent Date":"2016-06-23T15:27:08.497", "Message Status":"Delivered", "Delivered Date":"2016-06-23T15:27:17.973", "DlrCode":"000", "Description":"Unknown Error Code", "Reference":"", "Success":true }] Message Delete This can be used to delete a scheduled message that has not been sent. DELETE /sms/message/{Id} * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "DELETE"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}", data["Success"], data["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl -X "DELETE" http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa -H username: YourReachUsername -H password: YourReachPassword <?php $url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_CUSTOMREQUEST, "DELETE"); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Returned Response { "Success":true, "Id":"aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa", "Description":"Id Removed" } Delivery Report We can provide an HTTP GET response of the message These are the parameters that will be passed back Parameter Description msgid The Id that was originally supplied in the API call msisdn The number that the delivery report is from timestamp The date and time of the delivery report status The status of the delivery report code The DLR code of the message Extra Information If you require any more information passed back in the call back, you can add them to the URL that you supply. For example if you supply https://www.yourdomain.com/?CustomerId=123 the call back that then gets send back will be https://www.yourdomain.com/?CustomerId=123 &MsgId=aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa &MSISDN=447xxxxxxxxx&Timestamp=dd/MM/yyyy hh:mm:ss&Status=Delivered&Code=000 Status Status Description delivered Delivered successfully rejected Message rejected expired Message could not be delivered within valid time frame undelivered Message has not been delivered Inbound Messages After purchasing an Inbound long number or Short code keyword. Please Go to Inbox > Inbox in the menu to view / edit the settings for each Inbound SMS API DOCUMENTATION Our API gateway lets you connect to our interfaces over HTTP/S and allows your applications to integrate SMS over the internet. Our API uses a RESTful endpoint and our request and response payloads are formatted as JSON but we also provide GET as an alternative. All you need to use our service is a free account and your authentication details are accessible after you sign up. SMPP We support SMPP Version 3.4. If you require an SMPP bind, please contact sales@reach-data.com and we will happy to set things up for you. Authentication All requests require your username and password being passed across in the header. These can be found once you have logged in under Support > Developer > API Details Header Description username Your Reach Interactive API Username password Your Reach Interactive API Password HTTP Status Code Code Description 200 Successful Request 400 Details not correct or missing mandatory parameters 401 Invalid Account details 402 Out of Credits 403 Account forbidden for this action. 500 Service error. 503 The Service is unavailable. DLR Codes DLR codes are the same for our API's and our SMPP binds. Code Description 000 Delivered 600 No credits to send 601 No route 602 Blacklisted number detected 603 Bad destination number 604 Bad source number 605 Target SMSC message queue 606 Target SMSC submit fail 607 General error 608 Spam message detected 609 Validity period expired 610 Unauthorised Source address 611 Unknown DLR code 612 Submit timeout Messaging The URI for this section is https://api.reach-interactive.com/sms/[Action] Balance Action The URI for this section is GET/sms/balance Required Parameters There are no extra parameters for the Balance * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/balance"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "GET"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Balance: {1}, Description: {2}", data["Success"], data["Balance"], data["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl http://api.reach-interactive.com/sms/balance -H username: YourReachUserName' -H password: YourReachPassword'; <?php $url = "http://api.reach-interactive.com/sms/balance"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_HTTPGET, true); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Message Send Creates a new message object. We return an array of each Id generated. Per request, a max of 50 recipients can be entered. POST/sms/message Required Parameters Parameter Description to The Number that you want to send to, can be multiple numbers seperated by a ',' or ';' from Who the message will appear to be from message The message to send to the phone, the first 160 characters will be a single message, anything over will be split down into messages the size of 153 characters. For Unicode, this is the text encoded in hexadecimal For Binary messaging, this the User Data (140 octets max) Optional Parameters Parameter Description Default valid How many hours that you require us to try to send the SMS for before it is expired, the minimum for this is 15 minutes (0.25) 72 reference A reference that you want saved against the message in our system callbackurl The URL that you want us to send the delivery report to. See below in the Delivery Report for more information scheduled The Date and Time you want the message to be sent (yyyy/MM/dd hh:mm) coding The type of message you would like to send, 1 = Text, 2 = Unicode, 3 = Binary 1 udh User Data Header Example JSON Payload { "to" : "447xxxxxxxxx", "from" : "Reach", "message" : "Test Json Send" } * C# * cURL * PHP using System; using System.Collections.Generic; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/message"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "POST"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var streamWriter = new StreamWriter(request.GetRequestStream())) { string json = "{ \"to\" : \"447xxxxxxxxx\", \"from\" : \"Reach\", \"message\" : \"Test API Message\"}"; streamWriter.Write(json); streamWriter.Flush(); streamWriter.Close(); } using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); foreach (Dictionary<string, dynamic> item in data) { Console.WriteLine("Success: {0}, Id: {1}, Description: {2}", item["Success"], item["Id"], item["Description"]); } } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int) ((HttpWebResponse) err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl -X "POST" http://api.reach-interactive.com/sms/message -H username: YourReachUsername -H password: YourReachPassword -H "Content-Type: application/json -d "{\"to\":\"RecipientPhoneNumber\",\"from\":\"FromName\",\"message\":\"YourMessage\"}" <?php $url = "http://api.reach-interactive.com/sms/message"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'Content-Type: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; $data = array("to" => "447xxxxxxxxx", "from" => "Reach", "message" => "Test API PHP send"); $data_string = json_encode($data); //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_POSTFIELDS, $data_string); curl_setopt($crl, CURLOPT_CUSTOMREQUEST, "POST"); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Message Details This can be used to retreive the details of a message sent over our API or SMPP binds. GET/sms/message/{Id} * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "GET"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, To: {1}, From: {2}, Text: {3}, Sent: {4}, Status: {5}, Delivered: {6}, Code: {7}, Description: {8}", data[0]["Success"], data[0]["To"], data[0]["Originator"], data[0]["Text"], data[0]["Sent Date"], data[0]["Message Status"], data[0]["Delivered Date"], data[0]["DlrCode"], data[0]["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl http://http-1-uat.reach-interactive.com/sms/message/{id} -H username: YourReachUsername -H password: YourReachPassword <?php $url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_HTTPGET, true); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Returned Response [{ "Method":"H", "To":"447xxxxxxxxx", "Originator":"Reach", "Text":"Your Message", "Sent Date":"2016-06-23T15:27:08.497", "Message Status":"Delivered", "Delivered Date":"2016-06-23T15:27:17.973", "DlrCode":"000", "Description":"Unknown Error Code", "Reference":"", "Success":true }] Message Delete This can be used to delete a scheduled message that has not been sent. DELETE /sms/message/{Id} * C# * cURL * PHP using System; using System.IO; using System.Net; using System.Web.Script.Serialization; namespace Sms { class Program { static void Main(string[] args) { var serializer = new JavaScriptSerializer(); try { var url = "http://api.reach-interactive.com/sms/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/json"; request.Method = "DELETE"; request.Headers.Add("Username", "Your Reach Username"); request.Headers.Add("Password", "Your Reach Password"); using (var response = (HttpWebResponse)request.GetResponse()) { using (var reader = new StreamReader(response.GetResponseStream())) { var jsonResponse = reader.ReadToEnd(); dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}", data["Success"], data["Description"]); } } } catch (WebException err) { using (var response = err.Response.GetResponseStream()) using (var reader = new StreamReader(response)) { var jsonResponse = reader.ReadToEnd(); try { dynamic data = serializer.Deserialize<dynamic>(jsonResponse); Console.WriteLine("Success: {0}, Description: {1}, HTTP Status Code: {2}", data["Success"], data["Description"], (int)((HttpWebResponse)err.Response).StatusCode); } catch (Exception) { Console.WriteLine(jsonResponse); } } } catch (Exception err) { Console.WriteLine(err.Message); } Console.ReadKey(); } } } curl -X "DELETE" http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa -H username: YourReachUsername -H password: YourReachPassword <?php $url = "http://api.reach-interactive.com/sms/message/aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa"; // The data to send to the API $header = array(); $header[] = 'Accept: application/json'; $header[] = 'username: Your Reach Username'; $header[] = 'password: Your Reach Password'; //cURL starts $crl = curl_init(); curl_setopt($crl, CURLOPT_URL, $url); curl_setopt($crl, CURLOPT_HTTPHEADER, $header); curl_setopt($crl, CURLOPT_RETURNTRANSFER, true); curl_setopt($crl, CURLOPT_CUSTOMREQUEST, "DELETE"); $json_response = curl_exec($crl); $status = curl_getinfo($crl, CURLINFO_HTTP_CODE); if ( $status != 200 ) { die("Error: call to URL $url failed with status $status, response $json_response curl_error " . curl_error($crl) . " curl_errno " . curl_errno($crl)); } else{ $response = json_decode($json_response, true); print_r($response); } curl_close($crl); ?> Returned Response { "Success":true, "Id":"aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa", "Description":"Id Removed" } Delivery Report We can provide an HTTP GET response of the message These are the parameters that will be passed back Parameter Description msgid The Id that was originally supplied in the API call msisdn The number that the delivery report is from timestamp The date and time of the delivery report status The status of the delivery report code The DLR code of the message Extra Information If you require any more information passed back in the call back, you can add them to the URL that you supply. For example if you supply https://www.yourdomain.com/?CustomerId=123 the call back that then gets send back will be https://www.yourdomain.com/?CustomerId=123 &MsgId=aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa &MSISDN=447xxxxxxxxx&Timestamp=dd/MM/yyyy hh:mm:ss&Status=Delivered&Code=000 Status Status Description delivered Delivered successfully rejected Message rejected expired Message could not be delivered within valid time frame undelivered Message has not been delivered Inbound Messages After purchasing an Inbound long number or Short code keyword. Please Go to Inbox > Inbox in the menu to view / edit the settings for each Inbound PARTNER SUCCESS TEXT MESSAGE MARKETING HAS A 3X ROI FOR US ON THE COST OF THE TEXT! PARTNER : SKINNY TAN READ HOW SKINNY TAN USE REACH HAVE A QUESTION? TALK TO TEAM REACH * SEND MESSAGE FAQ AND SUPPORT ARTICLES How to get started with bulk SMS. OPEN How to increase your opt-in rates. OPEN 10 ways to connect with stakeholders via bulk text messaging. OPEN How to write the perfect SMS offer. OPEN The best time to send your SMS marketing messages. OPEN A five-step guide to successfully uploading your contact list. OPEN How does GDPR impact SMS marketing? OPEN How to get started with bulk SMS. How to increase your opt-in rates. 10 ways to connect with stakeholders via bulk text messaging. How to write the perfect SMS offer. The best time to send your SMS marketing messages. A five-step guide to successfully uploading your contact list. How does GDPR impact SMS marketing? GET IN TOUCH tech.support@reach-data.com sales@reach-data.com +44 (0) 0333 009 5117 Contact Reach LONDON OFFICE Reach-Data Ltd. 5 Beaumont Gate Shenley Hill, Radlett Hertfordshire WD7 7AR YORKSHIRE OFFICE Reach-Data Ltd. Atlas 4 Atlas Office Park First Point, Doncaster DN4 5JT MADRID OFFICE Reach-Data Ltd. Paseo Castellana 136 28046 Madrid Spain OUR CHARITY PARTNER FIND OUT ABOUT OUR CHARITY PROGRAMME GET IN TOUCH tech.support@reach-data.com sales@reach-data.com +44 (0) 0333 009 5117 Contact Reach LONDON OFFICE REACH-DATA LTD. 5 BEAUMONT GATE SHENLEY HILL, RADLETT. HERTFORDSHIRE WD7 7AR YORKSHIRE OFFICE REACH-DATA LTD. ATLAS 4 ATLAS OFFICE PARK FIRST POINT, DONCASTER DN4 5JT ©2002-2021 All rights Reserved. Reach Interactive© is a registered trademark of Reach-Data Ltd is registered in the UK and Wales. Registration Number: 04602161. Privacy Policy Terms and Conditions ×