dev-master
9999999-devPlace and manage orders of stickers using the SmartLabel webservices
The Development Requires
by Laurent
Place and manage orders of stickers using the SmartLabel webservices
Le SDK SmartLabel vous permet d'intégrer rapidement et simplement les webservices d'Adesa dans vos applications PHP. Il vous permet de calculer des prix, créer des devis, les transformer en commande et uploader les fichiers, (*1)
PHP >= 5.3
avec les extensions php-soap
, (*2)
Vous pouvez installer le SDK de trois façons :, (*3)
$ composer install "adesa/smartlabel-client"
adesa/smartlabel-client
à vos dépendances dans le fichier composer.json
{ "require": { "adesa/smartlabel-client": "*" } }
.ini
ou un tableau associatif PHP# ./config/smartlabel.ini locale = {fr|en|es|…} localeBasePath = ../locale identifiantRevendeur = {votre identifiant revendeur} [FTP] host = adesaweb.adesa.fr user = {votre login FTP} password = {votre mot de passe FTP}
$config = \Adesa\SmartLabelClient\Config::fromIniFile(__DIR__ . "/../config/smartlabel.ini");
ou, (*4)
$config = \Adesa\SmartLabelClient\Config::fromArray([ "locale" => "fr-FR", "localeBasPath" => "../locale", "identifiantRevendeur" => "{votre identifiant revendeur}", "ftp" => [ "host" => "adesaweb.adesa.fr", "user" => "{votre identifiant revendeur}" "password" => "{votre mot de passe FTP}" ] ]);
SmartLabel
en lui passant la configuration$smartLabel = new \Adesa\SmartLabelClient($config);
Les Webservices Adesa SmartLabel proposent deux diamètres de mandrin :, (*5)
Ce diamètre est particulièrement important dans le cas d'une pose automatique, car s'il est de la mauvaise taille, il ne pourra pas s'adapter sur la machine de pose., (*6)
Pour récupérer la liste des mandrins disponibles, il faut appeler la méthode suivante :, (*7)
$smartLabel->listeMandrins(); // retourne un tableau d'objet Mandrin
Une matière est le support sur lequel est imprimé le visuel. Le webservice propose les supports suivants (peut évoluer) :, (*8)
$matieres = $smartLabel->listeMatieres(); // tableau d'objet Matière $select = "<select name=matieres>"; foreach($matieres as $matiere){ $select.= '<option value="' . $matiere->numero . '">'; $select.= $smartLabel->label($matiere); $select.= '</option>'; } $select.= "</select>";
Une finition est un procédé technique qui est appliqué sur la matière après impression. Les finitions disponibles sont fonction de la matière sélectionnée (peut évoluer) Le webservice propose les finitions suivantes :, (*9)
$matiere = $smartLabel->trouverMatiere($_GET['numero_matiere']); // Les finitions disponibles sont fonctions de la matière sélectionnée $finitions = $smartLabel->listeFinitions($matiere); $select = "<select name=finitions>"; foreach($finitions as $finition){ $select.= '<option value="' . $finition->numero . '">'; $select.= $smartLabel->label($finition); $select.= '</option>'; } $select.= "</select>";
Pour calculer le prix d'une impression d'étiquette, il faudra tout d'abord connaitre le scénario de fabrication. Pour cela, il convient d'appeler la méthode suivante :, (*10)
Le multi-modèle consite en l'impression de visuels différents sur des stickers partageant les mêmes caractéristiques : dimensions, matériau, finition, etc.
$scenario = $smartLabel->trouverScenario($matiere, $finition);
Il faut ensuite appeler la méthode demandePrix
, qui prend les arguments suivants :, (*11)
scenario
: le scénario qui vient d'être trouvé par la combinaison matière / finitionquantite
: le nombre total d'étiquettes à produire, tous modèles confondushauteur
: la hauteur en millimètres d'une étiquette (pas du visuel)largeur
: la largeur en millimètres d'une étiquette (pas du visuel)poseAutomatique
: si true
, les rouleaux sont destinés à être utilisés avec une
machine de pose automatique. Dans ce cas, il faut bien veiller à passer le bon diamètre de mandrin
et bien vérifier le diamètre total de la bobinemandrin
: le mandrin utilisénombreEtiquettesParRouleau
nombreRouleaux
rotation
: l'orientation du visuel aposé sur l'étiquette par rapport au sens de
défilement de la bobinequantitesParSerie
nombreSeries
Le webservice de demande de prix créer un dossier (devis) SmartLabel, qui contient les informations suivantes :, (*12)
numero
: Numéro de dossierprix
: Le prix d'achat de la commande, en Euro (€)poids
: Le poids du colis en Kgdiametre
: Le diamètre des bobines (à bien vérifier en cas de pose automatique)
Une fois le dossier créé, il est temps de passer commande ! Pour cela, il vous suffit
de passer l'objet Dossier à la méthode commander
. Vous pouvez passer en argument de cette
méthode un identifiant de commande externe, qui pourra vous servir d'identiant pivot pour
rattacher la commande SmartLabel à votre ERP / système d'informations., (*13)
Cette méthode va créer un bon de commande SmartLabel, qui vous servira à décrire la liste des modèles et leurs fichiers :, (*14)
$bonDeCommande = $smartLabel->commander($dossier, $myOrder->orderID); foreach($myOrder->getAttachments() as $attachment){ $bonDeCommande->ajouterModele($attachment['name'], $attachment['filename']); }
Une fois tous les modèles ajoutés, il ne vous reste plus qu'à finaliser ce bon de commande., (*15)
$smartLabel->finaliserBonDeCommande($bonDeCommande);
La finalisation du bon de commande dépose les fichiers sur le FTP d'Adesa et écrit les fiche de fabrication au format XML.
Une commande SmartLabel peut se trouver dans quatre états différents :, (*16)
Lorsqu'une commande est en livraison, SmartLabel retourne une URL de tracking vous permettant de suivre le colis sur le site du transporteur ainsi que des informations de livraison, au format texte., (*17)
Il est conseillé de mettre en place une tâche récurrent (dans la crontab
par exemple), qui
récupère les statuts de toutes les commandes SmartLabel qui n'ont pas encore été livrées., (*18)
// toutes vos commandes d'étiquettes smartlabel dans un tableau associatif // avec pour clé le numéro de dossier $orders = DB::fetchSmartLabelOrders(); $etats = $smartLabel->etatDossiers(array_keys($orders)); // Le tableau $etats est composé d'objets EtatDossier foreach($etats as $numeroDossier => $etat) { $order = $orders[$numeroDossier]; switch($etat->code){ case EtatDossier::LIVRAISON: $order->setState("shipping"); break; case EtatDossier::ERREUR_FICHIER: if(!$order->isInState("error")){ $order->setState("error"); $order->customer->sendErrorMail(); } break; } }
Place and manage orders of stickers using the SmartLabel webservices