Statut par message
Cette requête permet de récupérer les statuts de plusieurs SMS à partir d’un ID.
URL
GET
https://api.smspartner.fr/v1/bulk-status
Les comptes-rendus sont habituellement reçus en quelques secondes après l'envoi du SMS. Cependant, selon les opérateurs et la charge de notre plateforme, ce délai peut parfois aller jusqu'à 48 heures.
Paramètres obligatoires
apiKey
messageId
Requêtes
<?php
// Prepare data for GET request
$data = 'apiKey=YOUR_API_KEY&messageId=300';
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL,'https://api.smspartner.fr/v1/bulk-status?'.$data);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_TIMEOUT, 10);
$result = curl_exec($curl);
curl_close($curl);
// Process your response here
echo $result;
?>
Imports System.IO
Imports System.Net
Module Module1
Sub Main()
Dim base_url As String = "http://api.smspartner.fr/v1/"
Dim apiKey As String = "VOTRE_APIKEY"
Dim messageId As Integer = XXX
#check credits
Dim url As String
url = base_url & "bulk-status" & "?apiKey=" & apiKey & "&messageId=" & messageId
Dim credits As String
credits = apiRequest("GET", url, Nothing)
End Sub
Function apiRequest(method As String, url As String, parameters As String) As String
Dim request As HttpWebRequest
request = WebRequest.Create(url)
request.Method = method
request.Timeout = 10000 # timeout in ms
request.ContentType = "application/json; charset=utf-8"
request.ContentLength = 0
#set POST data
If Not String.IsNullOrEmpty(parameters) Then
request.ContentLength = parameters.Length
Using reqStream As StreamWriter = New StreamWriter(request.GetRequestStream())
reqStream.Write(parameters)
End Using
End If
#get response
Dim returnValue As String = Nothing
Using response As HttpWebResponse = request.GetResponse()
If response.StatusCode = HttpStatusCode.OK Then
Using resStream = response.GetResponseStream()
If resStream IsNot Nothing Then
Using reader As New StreamReader(resStream)
returnValue = reader.ReadToEnd()
End Using
End If
End Using
End If
End Using
apiRequest = returnValue
End Function
End Module
# std
import logging
import json
from collections import OrderedDict
# 3p
import requests
API_KEY = "MY API KEY"
URL = "https://api.smspartner.fr/v1"
class SMSPartner():
def get_delivery(self,message_id):
url = URL + "/bulk-status?apiKey=" + API_KEY + "&messageId=" + message_id
r = requests.get(url)
r_json = r.json()
if r_json.get("success") == True:
print(r_json)
status = True
else:
print(r_json)
status = False
return status
curl -H "Content-Type: application/json" -X GET https://api.smspartner.fr/v1/bulk-status?apiKey=xxx&messageId=300
const https = require('https');
//Cette requête permet de récupérer les statuts de plusieurs SMS à partir d’un ID.
// Préparer les données pour la requête GET
let data = 'apiKey=YOUR_API_KEY&messageId=300';
let url = 'https://api.smspartner.fr/v1/bulk-status?' + data;
https.get(url, (res) => {
let data = '';
res.on('data', (chunk) => {
data += chunk;
});
res.on('end', () => {
console.log(JSON.parse(data));
});
}).on("error", (err) => {
console.log("Erreur: " + err.message);
});
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
public class StatutSmsParID {
public static void main(String[] args) {
try {
// Prepare data for GET request
String apiKey = "YOUR_API_KEY";
String messageId = "300";
// Create GET request URL
String urlString = "https://api.smspartner.fr/v1/bulk-status?" +
"apiKey=" + apiKey + "&messageId=" + messageId;
// Create URL object
URL url = new URL(urlString);
// Create HTTP connection
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
connection.setConnectTimeout(10000);
connection.setReadTimeout(10000);
// Send GET request
int responseCode = connection.getResponseCode();
// Get response
BufferedReader reader;
if (responseCode >= 200 && responseCode <= 299) {
reader = new BufferedReader(new InputStreamReader(connection.getInputStream()));
} else {
reader = new BufferedReader(new InputStreamReader(connection.getErrorStream()));
}
StringBuilder response = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
response.append(line);
}
reader.close();
// Process your response here
System.out.println(response.toString());
} catch (Exception e) {
e.printStackTrace();
}
}
}
import SwiftUI
struct StatutSmsParID: View {
@State private var result: String = "Loading..."
var body: some View {
VStack {
Text("Statut SMS Par ID")
.font(.title)
.padding()
Text(result)
.font(.system(size: 20))
.padding()
}
.onAppear(perform: getStatusById)
}
func getStatusById() {
let apiKey = "YOUR_API_KEY"
let messageId = "300"
let urlString = "https://api.smspartner.fr/v1/bulk-status?apiKey=\(apiKey)&messageId=\(messageId)"
guard let url = URL(string: urlString) else {
print("URL inválida")
return
}
let task = URLSession.shared.dataTask(with: url) { (data, response, error) in
if let error = error {
print("Error: \(error)")
} else if let data = data {
let result = String(data: data, encoding: .utf8)
DispatchQueue.main.async {
self.result = result ?? "Error"
}
}
}
task.resume()
}
}
struct StatutSmsParID_Previews: PreviewProvider {
static var previews: some View {
StatutSmsParID()
}
}
package main
import (
"io/ioutil"
"log"
"net/http"
"time"
)
func main() {
// Prepare data for GET request
apiKey := "YOUR_API_KEY"
messageId := "300"
// Create GET request URL
url := "https://api.smspartner.fr/v1/bulk-status?" +
"apiKey=" + apiKey + "&messageId=" + messageId
// Create HTTP client
client := &http.Client{Timeout: 10 * time.Second}
// Send GET request
resp, err := client.Get(url)
if err != nil {
log.Fatalf("Error sending request: %v", err)
}
defer resp.Body.Close()
// Get response
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Fatalf("Error reading response body: %v", err)
}
// Process your response here
log.Printf("Response: %s", body)
}
using System;
using System.Net.Http;
using System.Threading.Tasks;
class Program
{
private static readonly HttpClient client = new HttpClient();
static async Task Main(string[] args)
{
var apiKey = "YOUR_API_KEY";
var messageId = "300";
var uri = new Uri($"https://api.smspartner.fr/v1/bulk-status?apiKey={apiKey}&messageId={messageId}");
HttpResponseMessage response = await client.GetAsync(uri);
if (response.IsSuccessStatusCode)
{
var result = await response.Content.ReadAsStringAsync();
Console.WriteLine(result);
}
else
{
Console.WriteLine("GET request failed with status code: " + response.StatusCode);
}
}
}
Réponse
{
"success": true,
"code": 200,
"message_id": "111",
"StatutResponse_List": [
{
"phoneNumber": "+336XXXXXXX1",
"status": "Delivered",
"stopSMS": false,
"date": "1517989111"
},
{
"phoneNumber": "+336XXXXXXX2",
"status": "Delivered",
"stopSMS": false,
"date": "1517989101"
}
...
}
<?xml version='1.0' encoding='UTF-8'?>
<result>
<entry>true</entry>
<entry>200</entry>
<entry>
<![CDATA[11]]>
</entry>
<entry>
<entry>
<entry>
<![CDATA[+336XXXXXXX1]]>
</entry>
<entry>
<![CDATA[Delivered]]>
</entry>
<entry>false</entry>
<entry>
<![CDATA[1517989111]]>
</entry>
</entry>
<entry>
<entry>
<![CDATA[+336XXXXXXX2]]>
</entry>
<entry>
<![CDATA[Delivered]]>
</entry>
<entry>false</entry>
<entry>
<![CDATA[1517989086]]>
</entry>
</entry>
...
</entry>
</result>
Delivered (Livré) : Ce statut indique que le message a été livré avec succès au destinataire. Cela signifie que le message a été envoyé correctement et qu’il a été reçu sur l’appareil ou la plateforme du destinataire. La date et l’heure de la réception est normalement disponible.
Not delivered (Non livré) : Ce statut fait référence aux messages qui n’ont pas pu être livrés au destinataire. Il peut y avoir plusieurs raisons pour lesquelles un message n’est pas livré : comme un numéro de téléphone non valide ou un problème opérateurs chez un opérateur.
Waiting (En attente) : Ce statut indique que le message est en cours de livraison et qu’il n’a pas encore été confirmé s’il sera livré ou non. Cela peut se produire en cas de retards sur le réseau ou lorsque des confirmations supplémentaires sont nécessaires avant de pouvoir marquer le message comme livré ou non livré.
Erreurs
{
"success": false,
"code": 10,
"message": "Clé API incorrecte"
}
<?xml version='1.0' encoding='UTF-8'?>
<result>
<entry>false</entry>
<entry>10</entry>
<entry>Clé API incorrecte</entry>
</result>
Code erreurs
1
La Clé API est requise
3
l'ID du message est requis
4
Message introuvable
10
Clé API incorrecte
200
Tout s'est bien passé !
Dernière mise à jour