Différences entre versions de « Génération de la signature »

De Ikoula Wiki
Jump to navigation Jump to search
 
Ligne 15 : Ligne 15 :
 
<!-- Début de l'article. Placez votre texte ci-après et n'hésitez pas à personnaliser les chapitres selon votre besoin -->
 
<!-- Début de l'article. Placez votre texte ci-après et n'hésitez pas à personnaliser les chapitres selon votre besoin -->
  
 
+
#REDIRECT [[Comment_utiliser_l'API_d’Ikoula]]
 
 
==Introduction==
 
Lors d'un appel à l'API, comme indiqué dans le Wiki de l'authentification, une signature est obligatoire. Elle est générée '''en fonction de l'ensemble des paramètres fournis lors de l'appel'''.<br />
 
Pour des raisons techniques, les paramètres d'authentification doivent ''pour l'instant'' toujours être transmises via la méthode HTTP GET.
 
 
 
==Exemple==
 
 
 
<syntaxhighlight lang="php">
 
// Définition des paramètres
 
$data["login"] = "mail@example.com";
 
$data["password"] = "dh4=674j_G"; // Mot de passe non chiffré
 
// D"autres paramètres peuvent êtres ajoutés en fonction de l"appel à l"API
 
// $data["autre_parametre"] = "valeur";
 
// $data["autre_parametre_2"] = "valeur_2";
 
// $data["..."] = "...";
 
 
// Triage des paramètres dans l'ordre croissant
 
ksort($data);
 
 
// Encodage des paramètres
 
$query = http_build_query($data);
 
 
// Encodage des signes plus
 
$query = str_replace("+", "%20", $query);
 
 
// Transformation de la chaîne de caractères en minuscule
 
$query = strtolower($query);
 
 
// Clé publique d'Ikoula (cf. lien ci-dessus)
 
$public_key="MIIBIjAN...";
 
 
// Hashage des paramètres
 
$hash = hash_hmac("SHA1", $query, $public_key, true);
 
 
// Encodage en base64, puis encodage en URL selon RFC 3986
 
$signature = rawurlencode(base64_encode($hash));
 
 
// ==> $signature contient alors la signature finale
 
</syntaxhighlight>
 
 
 
==Conclusion==
 
Une fois la signature générée, il faut la passer en paramètre (en plus de tous les autres paramètres) à l'appel API.<br />
 
En suivant l'exemple précédent, les paramètres à passer auraient donc été :<br />
 
* login = "mail@example.com" ;
 
* password = "dh4=674j_G" ;
 
* signature = $signature.
 
 
 
<!-- Fin de l'article -->
 
<br /><br />
 
Cet article vous a semblé utile ? <vote />
 
<!-- Placez ici la catégorie à laquelle se rapporte votre article. Ex: [[Catégorie:Contribuer]] -->
 
[[Category:cloud public]]
 
[[Category:cloud privé]]
 
[[Catégorie:API]]
 
[[Category:Cloud]]
 
[[Catégorie:Serveur VPS]]
 
<!-- Gestion SEO. Indiquez les informations manquantes -->
 
<br />
 
<comments />
 

Version actuelle datée du 22 février 2021 à 17:52