iPromo

API Developpeur - 1.0 - 23/02/10 - contact@ipromo-app.com


A) Principe

  1. Présentation

L'API développeur vous permet d'importer vos produits directement depuis votre boutique en ligne, sans recourir à notre interface d'administration. Pour cela votre application doit génerer un fichier XML, et communiquer son adresse URL à notre serveur pour traitement.

  1. Description du processus

Votre site va génerer, via un script (PHP, ASP, Perl, …) un fichier reprenant l'ensemble des informations nécessaires au fonctionnement de votre boutique iPromo

Une fois ce fichier géneré, votre script doit appeler une adresse URL (file_get_contents() en PHP apr exmeple) avec comme variable l'adresse de votre fichier XML précedemment créé. Notre serveur va traiter toutes les informations, de l'authentification au téléchargement et redimensionnement de vos photos. Un code de réponse est alors transmis en retour.

Attention : si vous utilisez l'API, tous les produits et modifications effectuées via l'interface d'administration classique seront écrasées et irrecuperable. Tous les articles et photos sont regenerés à chaque appel à l'API. Il est conseillé d'utiliser soit l'API soit l'interface d'administration, et de limiter au maximum l'utilisation des deux en simultané.

B) Le fichier XML

  1. Exemple

<?xml  version="1.0" encoding="iso-8859-1" ?>
<ipromo  version="1.0">
<test>test</test> <login>identifiant@ipromo.com</login> <password>NUMERODECERTIFICAT</password> <logo>http://www.adresse.url/devotre/logo.jpg</logo> <description>Description rapide de votre activité</description> <url>http://www.adresse-url.com/</url> <email>contact@votreboutique.com</email> <tel>0123456789</tel> <signature>472d14764a789b4d9f5a175df4c92284</signature> <date>1266930291</date> <items> <product ordre="1"> <cat>01</cat> <ref>REFERENCE</ref> <titre><![CDATA[Article n°1]]></titre> <prix>11952</prix> <prix_promo>10865</prix_promo> <port>695</port> <img>http://www.adresse.com/images/votreimage.jpg</img> <img_2>http://www.adresse.com/images/votreimage2.jpg</img_2> <img_3>http://www.adresse.com/images/votreimage3.jpg</img_3> <link>http://www.adresse.com/fiche-produit.php</link> <description><![CDATA[description de votre <b>Produit</b>]]></description> </product> </items> </ipromo>
  1. Détails des balises

Balise

Descriptif

Exemple


Contenu

<ipromo>

Indique le début de votre flux. Il doit contenir l'attribut version (actuelle : 1.0)

<ipromo version="1.0">

obligatoire

N/A
<test>
Indique qu'il s'agit d'un test, les résultats ne sont pas sauvegardés. utilisez cette balise pour faire vos essais d'integration, puis retirez la pour le passage en production.
<test>test</test>   "test"

<login>

Contient votre identifiant iPromo utilisé lors de votre inscription

<login>identifiant@boutique.com</login>

obligatoire

Texte

<password>

Contient votre clef privé, disponible dans votre zone d'administration (Certificat API)

<password>A3BHF5LKD2454</password>

obligatoire

Texte

<logo>

Adresse URL du logo de votre boutique, format JPG, PNG (recommandé) ou Gif, taille : 57x57px

<logo>http://www.adresse.com/logo.png</logo>

obligatoire

Adresse URL

<description>

Contient une breve description de votre boutique. Utilisé par le moteur de recherche et sur les fiches articles. Texte uniquement (pas d'HTML)

<description>Ma boutique en ligne !</description>

obligatoire

Texte

<url>

Contient l'URL de l'index de votre boutique

<url>http://www.maboutique.com</url>

obligatoire

Adresse URL

<email>

Contient l'adresse e-mail utilisée pour vous contacter depuis l'iphone

<email>adresse@votreboutique.com</email>

facultatif

Adresse Email

<tel>

Contient le numéro de téléphone pour vous joindre directement depuis l'application. Indiquer un numéro sans prefix international (pas de +33)

<tel>0175430382</tel

facultatif

Numéro de téléphone

<signature>

Signature de votre flux. Elle est calculée de la manière suivante :

md5(contenu de la balise login + contenu de la balise password + contenu de la balise date);

Voir plus bas dans la section exemple pour plus détails

<signature>AAAAABBBBBCCC4444666</signature>

obligatoire

Hashage MD5
<date>
Contient la date de génération du flux au format timestamp Linux (fonction time() en PHP)
<date>1234567890</date> obligatoire Timestamp
<items>
Indique le début de la liste des articles à integrer
<items> obligatoire N/A
<product>
Indique le début d'une fiche produit. Doit contenir l'attribut ordre qui indique le classement de l'article. Cette valeur peut aller de 1 (tete de liste) à x (nombre maximum d'article permis, ou nombre d'article dans le flux)
<product ordre="2"> obligatoire N/A
<cat>
Identifiant de la catégorie pour classement : Index des catégories
<cat>4</cat> obligatoire Entier Numérique
<ref>
La référence de votre produit. Celle si sera utilisée lors des commandes. Doit être unique
<ref>LAREFERENCEDEMONPRODUIT</ref> obligatoire Texte
<titre>
Titre de votre produit
<titre><![CDATA[Titre de mon article]]></titre> obligatoire Texte et entitées HTML
<prix>
Prix de base de votre produit exprimé en Euros hors taxe x 100 (pas de séparateur de centimes)
<prix>10000</prix> (100 € HT) Obligatoire Entier numérique
<prix_promo>
Prix promotionnel exprimé en Euros hors taxe x 100 (pas de séparateur de centimes) . Ce prix sera utilisé pour la commande de ce produit si > 0
<prix_promo>8000</prix_promo> (80 € HT) Facultatif Entier numérique
<port>
Tarif du port pour cet article exprimé en Euros hors taxe x 100
<port>500</port> (5 € HT) Facultatif Entier numérique
<img>
Adresse URL de la photo principale d'illustration de ce produit au format JPG, GIF ou PNG. La photo ne doit pas dépasser les 500 Ko et sera automatiquement redimensionnée pour l'affichage sur iPhone.
<img>http://www.maboutique.com/produitt/mareference.jpg</img> Recommandé Adresse URL
<img_x>
Vous permet d'ajouter des photos supplémentaires. x peut valoir de 2 à 5 compris.
<img_2>http://www.maboutique.com/produit/mareference2.jpg</img> facultatif Adresse URL
<link>
Lien vers la fiche produit complète. Sera ouverte dans le navigateur iPhone si l'internaute en fait la demande
<link>http://wwww.maboutique.com/fiche-produit.html</link> facultatif Adresse URL
<description>
Description complète de votre produit. Peut contenir du code HTML (formattage, images, tableaux , pas de flash ni vidéo). Ayez à l'esprit que cette description est affichée sur un écran de 420x380 pixel, avec une faible bande passante, pensez à redimensionner vos images !
<description><![CDATA[<b>Description de mon produit</b>]></description> obligatoire Texte et HTML


Vous devez alors enregistrer votre fichier en local (le nom n'a pas d'importance) à un emplacement accessible depuis le Web (ce fichier va être téléchargé par notre serveur)

C) Transmission du fichier

Votre script doit ensuite appeler l'URL suivante : http://api.ipromo-app.com/api/api.php?flux=http:/www.maboutique.com/flux/iphone.xml

Remplacer la variable "flux" par l'adresse URL complète du flux que vous venez de créer

D) Réponse du serveur

Notre serveur va ensuite traiter votre flux et renverra un message de retour contenant un code d'erreur, et la signature pour controler de l'intégrité des données

<result>
		<code>0</code>  
		<description>Pas d'erreur</description>  
		<signature>472d14764a789b4d9f5a175df4c92284</signature> 
</result>  
  1. Code de retour

Code

Signification

0

Pas d'erreur : les articles ont été mis à jour

1

Signature incorrecte

2

Echec de l'identification

3

Erreur de syntaxe XML

4

Compte désactivé

5

Compte suspendu

6

Trop de produits

7 Erreur Interne
8 Erreur provisoire
9 Flux introuvable
10 Flux inconnu
11 Format email inconnu
12 Format télephone inconnu
13 Format d'adresse inconnu
14 Format d'adresse logo inconnu
15 Description incorrecte
16 Catégorie inexistante
17 Titre article introuvable
18 Format de prix article incorrect
19 Aucun produit saisis
20 Logo : protocole inconnu
21 Logo : format inconnu
22 Logo : Fichier introuvable (erreur 404)
23 Logo : Fichier trop lourd (> 50 Ko)
24 Logo : Fichier trop grand (max 60px de coté)

E] Exemple complet (PHP)

<?php

// Paramètres de base

$time = time();
$cert = 'B6B3C136F4C7B67FE912B2BD3C99758D'; // certificat à recuperer dans l'administration
$login = 'contact@maboutique.com';

// votre identifiant // Entete XML du flux, en ISO-8859-1 $flux = '<?xml version="1.0" encoding="iso-8859-1" ?>';
$flux .= '<ipromo version="1.0">';
$flux .= '<test>test</test>'; // informations d'identification
$flux .= '<login>'.$login.'</login>';
$flux .= '<password>'.$cert.'</password>'; // paramètres de la boutique
$flux .= '<logo>http://www.maboutique.com/images/iphone.jpg</logo>';
$flux .= '<description>Description complète de ma boutique</description>';
$flux .= '<url>http://www.maboutique.com/</url>';
$flux .= '<email>contact_iphone@maboutique.com</email>';
$flux .= '<tel>0123456789</tel>'; // verification de l'integrité du flux
$flux .= '<signature>'.md5($login.$cert.$time).'</signature>';
$flux .= '<date>'.$time.'</date>'; // début de la liste des produits $flux .= '<items>';
$res = mysql_query("SELECT * FROM produits ORDER BY ordre LIMIT 10"); // limiter suivant le nombre de produit de votre offre, les suivants seront ignorés $h = 1;
$mx = mysql_num_rows($res); while($h != $mx+1){ // boucle executée pour chaquert article sélectionnée depuis la base de données $rec = mysql_fetch_array($res); $flux .= '<product ordre="'.$h.'">'; // ordre d'affichage des produits $flux .= '<cat>01</cat>'; // numéro de la catégorie (voir annexe I) $flux .= '<ref>'.$rec['reference_produit'].'</ref>'; // reference interne de votre produit $flux .= '<titre><![CDATA['.htmlentities($rec['titre_produit']).']]></titre>'; // titre avec accents sous forme d'entitées // tarif x 100 (pas de séparateur de virgule) $flux .= '<prix>'.($rec['prix_normal']*100).'</prix>'; $flux .= '<prix_promo>'.($rec['prix_promotion']*100).'</prix_promo>'; $flux .= '<port>'.($rec['port']*100).'</port>'; // url des images du produits $flux .= '<img>http://www.maboutique.com/photo/mareference/photo1.jpg</img>'; $flux .= '<img_2>http://www.maboutique.com/photo/mareference/photo2.jpg</img_2>'; $flux .= '<img_3>http://www.maboutique.com/photo/mareference/photo2.jpg</img_3>';
$flux .= '<link><![CDATA[http://www.maboutique.com/monproduit.html]]></link>'; // description au format HTML
$flux .= '<description><![CDATA['.$rec['description_produit'].']]></description>';
$flux .= '</product>';

$h++;
}
$flux .= '</items>'; $flux .= '</ipromo>'; // ecriture du flux dans un fichier local $fp = fopen('iphone.xml', 'w+'); fputs($fp, $flux, strlen($flux)); fclose($fp);
// envoi de l'adresse du flux vers iPromo $dump = file_get_contents('http://www.ipromo-app.com/api/api.php?flux='.urlencode("http://www.maboutique.com/iphone.xml"));
// traitement eventuel du résultat echo $dump;
?>

Annexe I

Alimentation et vins
37Boisson
11Epicerie
61Matériel de professionnels
25Produits du terroir
49Vin et Champagne
Art, antiquités, collection
36Affiches
114Autocollants
123Autographes
173Autres art antiquités collection
60Cartes postales
153Eléments d'architecture
48Gravures
94Meubles et décoration
133Militaria
72Numismatique
104Objets à collectionner
143Objets déco
10Peinture
83Philatélie
24Photographies
163Reproductions, Copies
Auto, moto, scooter
81Accessoires 2 roues
46Accessoires auto
92Equipement du pilote
22Moto
70Réparation et mécanique
34Scooter et Mini moto
58Tuning
8Voiture
Bricolage, équipement, jardin
256Accessoires jardin
228Aménagement et loisirs
180Autres bricolage équipement
263Autres jardin
131Cheminées
196Contenant
242Décoration et mobilier extérieur
21Electricité
141Entretien et nettoyage
220Entretien, Traitement, Engrais
80Equipement et outillage bâtiment
112Gros oeuvre et maçonnerie
91Isolation, Cloison, Plafond
102Matériaux
212Matériaux et construction
249Matériel de professionnels
57Menuiserie, Huisserie
69Outillage
204Outillage de jardin
235Piscine, Sauna, Spa
7Plomberie
161Produits entretien et nettoyage
45Revêtement de sol
33Revêtement mural
171Sécurité et domotique
121Toiture et charpente
188Végétaux
151Vêtements et protection
Immobilier
13Location
26Vente
Informatique
201Accessoires
128Carte graphique
185Carte mémoire
148Carte mère
77Clavier
193Clé USB
168Composants
209Consommables
109Disque dur
42Ecran
225GPS
54Imprimante
118Lecteur/Graveur CD-DVD Rom
217Logiciels
4Mac
158Mémoire vive
31Ordinateur de bureau
18Ordinateur portable
177Périphériques
138Processeur
99Réseau
66Scanners
88Souris
Les insolites
Livres, CD, Musique, DVD & Blu-Ray
223Autres livres
15BD et humour
277Billetterie
304Blu-Ray
252Cassettes et autres supports
231CD
259Collection, Goodies
28Cuisine
39Dictionnaire
238Disque vinyle
51Droit
299DVD à droits locatifs
296DVD autres zones
293DVD Zone 1
290DVD Zone 2
63Economie & entreprise
74Enseignement
199Fournitures scolaires & bureau
306HD-DVD
85Histoire, actualité, politique
96Informatique
266Instruments de Musique
106Jeunesse
116Langues
125Littérature
191Livres anciens
135Nature
1Ouvrages art & culture
215Partitions et paroles
245Partitions, paroles
282Réparation CD rayés
207Revues
145Santé
155Sciences appliquées
165Sciences humaines
272Sono, DJ, Home Studio
175Sport et loisirs
183Tourisme
308UMD Vidéo
286Vêtements promotionnels
302VHS
Maison, électroménager, mobilier, déco
248Accessoires, Objets
241Animalerie
219Art de la table et Cuisine
255Articles de fête
279Autres décoration
79Autres électroménager
179Autres meubles
56Beauté, Santé, Forme
90Bureau
101Cave
111Chambre
120Chambre d'enfant
20Chaud, Cuisson
68Climatisation, Chauffage, Traitement de l'air
130Cuisine
187Décoration
269Enfants
32Froid
44Lavage et entretien
211Linge de maison, textile
262Loisirs créatifs
195Luminaires, éclairage
274Nettoyage et entretien
6Petit électroménager de cuisine
227Piscine
234Plantes
140Rangement
150Salle de bain, WC
160Salon, Salle à manger
170Tables et chaises
203Tapis
Matériel professionnel
12Mobilier professionnel
Mode, beauté, santé, enfance
152Accessoires chaussures
122Accessoires de mode
71Alimentation bébé
288Autres beauté santé bien-être
103Autres enfance
229Bien-être
197Bijoux
132Chaussures
142Chaussures de sport
221Cosmétique - Produit de beauté
257Epilation
93Hygiène de l'enfant et du bébé
270Hygiène, Santé
113Lingerie
172Mariage
284Matériel de soins professionnel
275Matériel paramédical
181Merchandising
264Minceur, Mise en forme
35Mode enfant
9Mode femme
23Mode homme
205Montres
213Parfums
82Pour la promenade
47Puériculture
189Sacs - Bagages
250Soins des cheveux
236Soins Hommes
243Soins solaire
280Tatouage, Body Art
59Vêtement de maternité
162Vêtement de sport
Sport, loisirs, jeux, jouets
216Accessoires Jeux Vidéo
146Activités santé, découverte
166Autres activités
267Billets de transport
260Billetterie
126Camping
246Cartes de jeux
117Chaussures de sport
156Coffrets, Bons cadeaux
208Consoles
224Figurines
40Forme, fitness
200Guide officiel & Soluce
136Jeux de plein air
239Jeux de rôle
192Jeux Vidéo
184Jeux, jouet
253Loisirs créatifs - Scrapbooking
232Modélisme
2Montagne, ski
16Nature
176Nutrition sportive
29Running
52Sport d'eau
75Sport de raquette, Golf
64Sports collectifs
97Sports d'air
86Vélo, VTT, Roller
107Vêtements de sport
Téléphone, PDA, GPS
41Accessoires mobiles
76Accessoires PDA
167Autres appareils
127Calculatrices
147Fax, Téléphonie professionnelle
137GPS, Navigation
3iPhone
65PDA, Organiseur de poche
87Récepteurs de Radiomessagerie
108Répondeurs
30Smartphone
157Téléphone VoIP
53Téléphones et recharges prépayées
98Téléphones fixes
17Téléphones mobiles
Vidéo, son, hifi, photo
233Accessoires photo, vidéo
294Accessoires son
119Accessoires TV, Vidéo
254Ampli
186Appareils photo argentiques
178Appareils photo numériques
297Audio auto
159Autres TV DVD home cinéma 
19Cadre photo numérique
169Caméscope, Caméra, Accessoires
287Casques & Micros
247Chaîne Hi-Fi
67Combiné TV
100Ecran de projection
283Enceintes
129Home Cinéma (788)
210Imprimante photo
5iPod
218Jumelles, Téléscope
261Lecteur & Graveur CD
278Lecteur cassette
55Lecteur et enregistreur DVD
139Magnétoscope
300Matériel hifi professionnel
226Matériel numérique professionnel
202Mémoire, Lecteur
240MP3 - Audio portable
194Objectif, Zoom et flash
268Platine vinyle
89Rétro-projecteur
291Sono, DJ, Home Studio
43Télévision
110TNT, Réception TV
273Tuner & Radio
149Vidéo embarquée voiture
78Vidéoprojecteur
Voyages