Bonne nouvelle pour les développeurs de solution e-commerce ! La Poste propose depuis peu un web service d’étiquetage (WSColiPosteLetterService) permettant de générer et imprimer les étiquettes de colis destinés à être envoyés par Colissimo.
S’agissant d’un web service de type SOAP, Lexik a mis en open-source la librairie WSColiPosteLetterService, fournissant un client et les différentes classes nécessaires à l’appel au service (et leurs règles de validation).
Et si vous développez sous Symfony2 c’est encore plus simple, avec l’intégration du LexikColissimoBundle proposant une configuration et une utilisation simplifiée.
Attention, l’accès au service WSColiPosteLetterService nécessite l’adhésion à un contrat de type “SO FLEXIBILITE” auprès de La Poste (la version test ne fonctionnant pas correctement – dixit le service technique – au moment d’écrire ces lignes). À noter également que le service ne sert qu’à générer des étiquettes prêtes à être collées sur un carton d’emballage, et ne gère pas les tarifs de livraison. Pour cela vous avez une grille tarifaire fournie par votre conseiller Colissimo qu’il vous faudra traiter vous-même.
Utilisation du bundle Symfony2
Installation avec composer
php composer.phar require lexik/colissimo-bundle
Activation du bundle (app/AppKernel.php)
public function registerBundles() { $bundles = array( // ... new Lexik\Bundle\ColissimoBundle\LexikColissimoBundle(), ); }
Configuration (app/config.yml)
lexik_colissimo: ws_coliposte_letter_service: contract_number: 123456 password: 'abcdef'
Exemple d’utilisation
// use Lexik\Bundle\ColissimoBundle\Exception\InvalidRequestException; // use Lexik\Bundle\ColissimoBundle\Exception\FailedRequestException; $colissimo = $this->container->get('lexik_colissimo.ws_coliposte_letter_service.service'); try { $response = $colissimo->getLabel( array('weight' => 1.780), array( 'name' => 'Client Name', 'surname' => 'Client Surname', 'email' => 'client@email.com', 'line2' => 'Client Address', 'city' => 'Client City', 'postalCode' => 'Client Postal Code' ) ); // en cas de succès, un dump de $response ressemblera à ça object(WSColissimo\WSColiPosteLetterService\Response\ValueObject\ReturnLetter)[1102] protected 'file' => null protected 'parcelNumber' => string '13xc1v654d123' (length=13) protected 'PdfUrl' => string 'https://ws.colissimo.fr/path/to/pdf-file' (length=40) protected 'errorID' => int 0 protected 'error' => string '' (length=0) protected 'signature' => null protected 'dateCreation' => null } catch (InvalidRequestException $e) { // probleme de validation } catch (FailedRequestException $e) { // erreur du webservice }
Utilisation de la librairie PHP
Vous avez développé une boutique en ligne custom ou vous souhaitez réaliser un module PrestaShop, Magento ou pour toute autre solution e-commerce PHP existante, vous pouvez vous appuyer sur la logique fournie par la librairie WSColissimo.
Installation avec composer
php composer.phar require lexik/ws-colissimo