Aller directement à la fin des métadonnées
Aller au début des métadonnées

Vous regardez une version antérieure (v. /wiki/spaces/FondsRepPublic/pages/3629121571/Guide+d+veloppeur+-+API+GesCo+Fonds+R+parations+EEE) de cette page.

afficher les différences afficher l'historique de la page

« Afficher la version précédente Vous regardez la version actuelle de cette page. (v. 57) afficher la version suivante »

Documentation à l’adresse des développeurs pour l’utilisation de l’API de pilotage des données et des traitements pour le Fonds Réparations EEE.

Janvier 2024

Nous attirons votre attention qu'à partir de début Janvier 2024, comme annoncé ces derniers mois, le référentiel des produits s’enrichit et que les codes Pannes ainsi que les codes Symptomes seront modifiés
Il est donc important que vous utilisiez la méthode de récupération du référentiel produit avec /PrintProductTypeList

  • Versions déployées de l’API GesCo Fonds Réparations EEE

    • PreProd = 1.3

    • Prod = 1.3

Historique des versions

  • VERSION 1.4 fin Février 2024

    • Création d’un dossier Claims (Demande de remboursement) sans création préalable d’un dossier Request (Demande de soutien)

  • VERSION 1.3

    • Création ou mise à jour de Request sans usage du SMS => mode unique autorisé

  • VERSION 1.2

    • calculateecosupport :

      • support des marques inconnues

      • détection des équipements pris en charge dans le cas d’une marque inconnue par Ecologic ou Eco System

    • CreateSupportRequest

      • support des marques inconnues

    • CreateClaim / UpdateClaim

      • support des marques inconnues

  • VERSION 1.1

    • printproducttypewithlabellist : ajout d’une méthode permettant d’obtenir les codes symptomes et réparations avec leur intitulé afin de faciliter la présentation dans l’interface utilisateur

    • calculateecosupport : prise en compte du paramètre RepairCode pour définir la prise en charge de la panne si elle est identifiée à cette étape

    • submitclaim : ajout de cette méthode pour déclencher la soumission d’un dossier de remboursement en utilisant uniquement l’ID du dossier. L’usage de UpdateClaim avec le paramètre “submit=true” est toujours possible

    • Code HTTP 206 pour les réponses aux méthodes Create et Update pour les Request (dossier de demande soutien) et Claim (dossier de demande de remboursement)

  • VERSION 1.01

    • getsupportrequestStatus = affichage des erreurs encore présentes (comme pour CreateSupportRequest ou UpdateSupportRequest)

    • getclaimstatus= affichage des erreurs encore présentes dans la demande de remboursement (comme pour CreateClaim ou UpdateClaim)

    • PostMan = mise à jour de la collection

  • VERSION 1.0 version initiale

Objectifs

Cette API permet l’intégration des étapes de traitements et l'échange des données entre les applications métiers de réparateur et le système d’information gérant les données de soutien pour le Fond Réparations EEE.
Basée sur les standards JSON Rest, elle s’adresse aux intégrateurs et développeurs.

Diagramme de séquence

Le diagramme ci-contre, est une proposition de scénario de séquence des appels vers les méthodes de l’API.

La phase initiale consiste à récupérer les informations de référence devant être utilisée par l’application cliente.
Il est recommandé de consolider les référentiels au moins 1 fois par jour.

Si possible évitez de faire appel au référentiel avant chaque appel d’une méthode pour les Resquest ou Claim.

Une fois les informations sur le produit et l’estimation / devis pour la panne réalisée, la première étape est de s’assurer que la réparation va bien être prise en charge par Ecologic avec “CalculateEcoSupport”.

Si la réponse est positive vous avez le montant du soutien allouable à l’acte de réparation.

L'étape suivante consiste à créer la demande de soutien en fournissant les informations sur le produit, le devis et le consommateur avec “CreateSupportRequest”.

Une fois la demande créée vous pouvez la mettre à jour (avec “UpdateSupportRequest”)

Evolution à partir de la version 1.01 : A noter que la création d’une demande de soutien se fait par défaut en mode attestion, c’est à dire qu’il faudra apporter au dossier de remboursement une pièce attestant que le consommateur a bien validé l’intervention (fiche d’intervention, document d’attestation…).
NOTE L’ancienne méthode de validation par SMS avec le consommateur n’est plus disponible

Utilisez la méthode “GetSupportRequestStatus” pour vérifier le statut du dossier.

La demande de remboursement se crée avec “CreateClaim” et la réponse vous indique s’il vous manque des informations pour pouvoir la soumettre à la vérification (et si tout est OK, au paiement).

Généralement, il manque initialement les documents de type, facture, plaque de numéro de série…
Ces documents peuvent être intégrés à la demande de remboursement avec “AttachFile”.
Il est aussi possible de compléter la demande avec “UpdateClaim”.

Si la vérification est OK avec “GetClaimStatus”, vous pouvez faire un “SubmitClaim” en demandant la soumission du dossier.

Le dossier de remboursement passe ensuite dans les étapes de contrôle chez Ecologic.

Gestion des marques inconnues (ou dites Orphelines) VERSION 1.2

L’API comme l’interface Web permet de gérer les dossiers de demandes de soutien (Request) ou de demandes de remboursement (Claim) en définissant pour un équipement donnée une marque inconnue.

Le mécanisme est testable en ligne sur le site Label QualiRepar = https://www.label-qualirepar.fr/remboursement-bonus/

Ecologic ou EcoSystems

Une marque est dites inconnue à partir du moment où elle n’est pas listée dans la réponse à la méthode printbrandlist.
Exemple :

  • produit smartphone avec le code EEE.M2.044

  • marque “SUPERPhone”

Ce couple n’est pas listé et doit être traité comme une marque inconnue.

Lorsqu’un produit est associé à une marque inconnue, pour savoir si Ecologic est en charge de celui-ci, il faut interroger la méthode calculateecosupport. La réponse peut être négative, dans ce cas, il faut faire appel à l’API d’EcoSystems.

Marques inconnues pour les Requests et les Claims

Cette définition de la marque inconnue peut être aussi appelée pour les Request et les Claims.
Voir plus en détails les ajouts spécifiques pour ces méthodes.

Environnement de développement (Pre Production)

Lexique

  • Request = demande de soutien

  • Claim =demande de remboursement

Accéder à l’environnement de développement

Pré requis

Le développement n’a de sens que s’il s’adresse à un réparateur qui dispose d’un compte sur le service e-reparateur.eco (https://www.e-reparateur.eco )

Le développeur doit contacter le support afin de se faire identifier : support@e-reparateur.eco

Procédure

  1. contacter le support support@e-reparateur.eco en demandant à avoir accès à un environnement de pré-production

  2. si votre demande est acceptée vous recevrez par email en réponse

    1. une clé API de Pré-Production pour réaliser votre développement

    2. un compte d’accès au service web e-reparateur de Pre-Production sur lequel vous pourrez gérer, vérifier, mettre à jour les différents objets du service

  3. vous pouvez contacter le support par email sur support@e-reparateur.eco

Récupération de votre clé de Pre Production

Vous pouvez aussi générer votre clé de pré-production en vous connectant sur votre compte e-reparateur de Pré-Production (sur https://preprod-ecologic.agoraplus.com/) et dans les informations de celui-ci, utiliser l’entrée “Ma Clé API” dans le menu à droite.

Veillez à bien vous assurer que la clé générée est avec le statut “Etat = Activé”

image-20240208-113252.png


Outils de tests

Une fois que vous avez vos accès vous pouvez tester les premiers éléments (notamment votre clé API) avec les outils suivants

SwaggerUI

SwaggerUI de l’API de Pre Production = https://preprod-apiecologic.e-reparateur.eco/apidoc/ui/index#/

Requis = disposer de votre clé d’autorisation d’usage de l’API (voir ci-dessu)

une fois votre clé entrée vous pourrez tester les méthodes de l’API

PostMan

Les informations contenus dans les structures JSON et les paramètres POSTMAN peuvent contenir des paramètres liés aux produits, aux code symptomes, aux code pannes qui ne sont plus valides au moment où vous réaliserez vos tests.
Donc veiller à vérifier ces paramètres notamment à partir des informations récupérées avec les méthodes d’interrogations du référentiel.

Postman est un outil standard dans le développement et la validation des API Rest.
Nous vous mettons à disposition une collection préparée pour pouvoir tester toutes les méthodes, mais il est recommandé de bien lire les informations fournies pour chacune d’entre elles.

Pour utiliser la collection disponible ci-contre, vous avez juste à réaliser l’importation du fichier json depuis l’interface de Postman.

Ensuite il vous reste à définir votre clé API de Pre Production pour réaliser les appels avec le niveau d’autorisation du site associé.
Pour cela ouvrez l’arborescence de la collection et sélectionnez “Pre Prod” et l’onglet “Authorization” pour y intégrer votre clé API

surtout pensez à sauvegarder à chaque fois l’onglet, sinon l’information ne sera pas utilisable dans les autres onglets que vous allez ouvrir

Pour utiliser une méthode sélectionnez là dans l’arborescence et adaptez les valeurs pour les paramètres et le contenu pour le body selon votre contexte

Collection PostMan à importer

version du

La collection regroupe les méthodes dans des dossiers permettant de plus facilement identifier un ordre type d’usage de celles-ci.
Ce n’est qu’un exemple, il vous est possible d’organiser les appels aux méthodes différemment et de n’utiliser que celles que vous identifiez utiles.

Environnement de Production

Récupération de votre clé de Production

Vous pouvez générer votre clé de production en vous connectant sur votre compte e-reparateur de Production (sur https://www.e-reparateur.eco/) et dans les informations de celui-ci, utiliser l’entrée “Ma Clé API” dans le menu à droite.

Veillez à bien vous assurer que la clé générée est avec le statut “Etat = Activé”

image-20240208-113252.png


Spécifications de l’API

Authentification

Appeler l’API depuis une service nécessite de disposer d’une clé d’authentification à passer dans l'entête HTTP de chacune des requêtes.

Nom de la clé d’entête = api_key

Valeur de la clé = <votre_clé_api> (GUID ex : C8E88146-AF8D-4E95-9B76-8C8FFF5A2C9B)

<votre_clé_api> existe

  • soit en version de PreProduction à utiliser lors des développements et des tests

  • soit en version de Production et les appels à l’API déclencheront des actions concrètes et réelles auprès du Fond Réparation EEE.

Cette clé est unique pour chaque compte e-reparateur.eco.
Attention à ne pas la divulguer. Si jamais vous aviez un doute n’hésitez pas à prévenir le support = support@e-reparateur.eco


Vérification des sites

Récupération des informations du site associé à la clé API - /GetRepairSitesByATS GET

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/getrepairsitesbyats

Fonctions

Permet de récupérer les ID des sites associés à la clé API utilisée.
Ce sera l’information qu’il faudra ensuite utiliser dans certaines méthodes dans le paramètre “RepairSiteId

Ex réponse

{
    "ResponseData": [
        {
            "SiteId": "02c867c0-0000-0000-000-3cf8de2dc1c8",
            "Name": "Test Reparateur",
            "CommercialName": "ECO REPARE",
            "Zip": "78280",
            "City": "GUYANCOURT"
        }
    ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Réponse avec plusieurs sites

{
    "ResponseData": [
        {
            "SiteId": "9cc23555-0000-0000-0000-3279c2f57261",
            "Name": "Test Reparateur 1",
            "CommercialName": "ECO REPARE",
            "Zip": "12100",
            "City": "MILLAU"
        },
        {
            "SiteId": "0590e586-0000-0000-0000-f94f4e1cb199",
            "Name": "Test Reparateur 1",
            "CommercialName": "ECO REPARE",
            "Zip": "12850",
            "City": "ONET-LE-CHATEAU"
        },
        {
            "SiteId": "b14ca037-0000-0000-0000-54a3391ee624",
            "Name": "Test Reparateur 1",
            "CommercialName": "ECO REPARE",
            "Zip": "12200",
            "City": "VILLEFRANCHE-DE-ROUERGUE"
        }
    ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Référentiels des données

Les créations de dossier de demande de soutien et de remboursement nécessitent de s’appuyer sur des données de références utilisées par l’API.
Celle-ci permet par contre de récupérer ces référentiels mis à jour régulièrement (au moins 1 fois toutes les 24h).

Prod vs PreProd

attention les ID des entrées ne sont pas identiques entre les référentiels récupérés par l’API de Pre-Production et l’API de Production, donc veillez à bien récupérer ces référentiels pour chacun des contextes et à utiliser les bonnes valeurs associées.

Récupération de la liste des marques - /PrintBrandList GET

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/printbrandlist

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/printbrandlist

Fonctions

Permet de récupérer la liste des marques supportées par Ecologic.
Appeler cette API vous permettra de disposer d'un code marque unique et de l'associer à votre référentiel.

Usage

entrée = pas de paramètre spécifique

Exemple de réponse

{
    "ResponseData": [
        {
            "BrandName": "Acer",
            "BrandId": "1689"
        },
        {
            "BrandName": "ADVANCE",
            "BrandId": "1922"
        },
        {
            "BrandName": "AEG",
            "BrandId": "1690"
        },
        ...
  ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

🆕 Récupérer la liste des types de produit - /PrintProductTypeListWithLabelList GET VERSION 1.1

Cette méthode est à préférer par rapport à la méthode /PrintProductTypeList, car elle permet de récupérer les intitulés des codes de symptomes et de pannes.

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/printproducttypewithlabellist

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/printproducttypewithlabellist

Fonctions

Permet de récupérer la liste des équipements avec

  • code unique de l'équipement

  • nom de l'équipement

  • date d'éligibilité au soutien

  • date de fin du soutien

  • Tableau des codes pannes

  • Tableau des codes symtomes

Exemple usage

entrée = pas de paramètre spécifique

sortie =

ProductId = Identifiant produit

ProductName  =Désignation du type de produit (ex: Four (hors micro-ondes et mini-four))

EligibilityStartDate = Date de début d'éligibilité

EligibilityEndDate = Date de fin d'éligibilité

RepairCodes = Tableau d’une liste des codes pannes IRIS pouvant être utilisés dans la demande de remboursement (Claim) avec leur libellé

IRISSymptoms = Tableau d’une liste des codes symptôme IRIS éligibles pour le type de produits et pour Ecologic à utiliser dans la demande de soutien (Request) avec leur libellé

vérifiez la date d'éligibilité afin de vous assurer de ne pas soumettre un dossier avec ce produit avant que celle-ci ne soit valide.

Exemple de réponse

{
    "ResponseData": [
        {
            "ProductId": "EEE.M1.010",
            "ProductName": "Cave à vin",
            "EligibilityStartDate": "2022-01-01T00:00:00",
            "EligibilityEndDate": "9999-12-31T00:00:00",
            "RepairCodes": [
                {
                    "Code": "XXX",
                    "Label": "Autre"
                },
                {
                    "Code": "PSP",
                    "Label": "Défaut d'alimentation"
                },
                {
                    "Code": "G12",
                    "Label": "Défaut de carte de commande"
                },
                {
                    "Code": "G13",
                    "Label": "Défaut de carte de puissance"
                },
                {
                    "Code": "C05",
                    "Label": "Fuite de fluide frigorigène"
                },
                {
                    "Code": "C01",
                    "Label": "Problème compresseur"
                },
                {
                    "Code": "C10",
                    "Label": "Problème de thermostat"
                }
            ],
            "IRISSymtoms": [
                {
                    "Code": "XX4",
                    "Label": "Devient très buyant"
                },
                {
                    "Code": "XX6",
                    "Label": "N'affiche plus"
                },
                {
                    "Code": "XX12",
                    "Label": "Ne refroidit plus"
                },
                {
                    "Code": "XX13",
                    "Label": "Ne s'allume plus"
                },
                {
                    "Code": "XX1",
                    "Label": "Autre"
                },
                {
                    "Code": "XX23",
                    "Label": "Problème de bouton / connecteur"
                }
            ]
        },
        ...
  ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Fonctions

Permet de récupérer la liste des équipements avec

  • code unique de l'équipement

  • nom de l'équipement

  • date d'éligibilité au soutien

  • date de fin du soutien

  • Tableau des codes pannes

  • Tableau des codes symtomes

.

Exemple usage

entrée = pas de paramètre spécifique

sortie =

ProductId = Identifiant produit

ProductName  =Désignation du type de produit (ex: Four (hors micro-ondes et mini-four))

EligibilityStartDate = Date de début d'éligibilité

EligibilityEndDate = Date de fin d'éligibilité

RepairCodes = Tableau des codes pannes IRIS pouvant être utilisés dans la demande de remboursement (Claim)

IRISSymptoms[] = Liste des codes symptôme IRIS éligibles pour le type de produits et pour Ecologic à utiliser dans la demande de soutien (Request)

vérifiez la date d'éligibilité afin de vous assurer de ne pas soumettre un dossier avec ce produit avant que celle-ci ne soit valide.

Exemple de réponse

{
    "ResponseData": [
        {
            "ProductId": "EEE.M1.010",
            "ProductName": "Cave à vin",
            "EligibilityStartDate": "2022-01-01T00:00:00",
            "EligibilityEndDate": "9999-12-31T00:00:00",
            "RepairCodes": [
                "XXX",
                "PSP",
                "G12",
                "G13",
                "C05",
                "C01",
                "C10",
                "SFT"
            ],
            "IRISSymtoms": [
                "004",
                "006",
                "012",
                "013",
                "001",
                "023"
            ]
        },
        ...
  ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Demandes de soutien

Plusieurs méthodes sont disponibles pour gérer la construction et la soumission d’une demande de soutien, tout en s’assurant que les équipements concernés y seront éligibles.

Calculer le montant du soutien - /CalculateEcoSupport GET

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/calculateccosupport

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/calculateccosupport

Fonctions

Permet de connaître l'éligibilité, l'éco-organisme et le montant du soutien pour un type de produit donné, en fonction du symptôme ou du code section fourni. Cette API n'a pour seul but que de simuler la demande de soutien.

Elle n'effectue aucune demande réelle auprès d'Ecologic.

Données à transmettre

Exemple

{
    "TotalAmountExclVAT": 120.00,
    "TotalAmountExclVAT_Currency": "EUR",
    "BrandId": 8055,
    "ProductId": 3032,
    "IRISSymtom": "001" 
 }

Données en entrée

  • TotalAmountExclVAT : Montant total HT de la réparation

  • TotalAmountExclVAT_Currency : Devise

  • BrandId: Code de la marque (retourné préalablement par l'API /PrintBrandList)

  • ProductId : Code du type de produit (retourné préalablement par l'API /PrintProductTypeList) 

  • IRISSymptom : Liste des codes symptôme IRIS éligibles pour le type de produits et pour Ecologic

Données en sortie

  • EcoOrganizationId: Identifiant e-Reparateur de l'éco-organisme (44=Ecologic, 45=Ecosystem)

  • SupportAmount: Montant TTC du soutien

Exemple de paramètre en entrée

Exemple de réponse

{
    "ResponseData": [
        {
            "EcoOrganizationId": 44,
            "SupportAmount": 10.00
        }
    ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Gestion des erreurs

Si le produit ou la marque n’est pas connu vous aurez une réponse similaire à

{
    "ResponseData": null,
    "ResponseStatus": "W",
    "IsValid": false,
    "ResponseMessage": "Produit pas valide",
    "ResponseErrorMessage": null
}

Si le symptôme ne correspond pas au code IRIS du produit l’erreur sera

{
    "ResponseData": null,
    "ResponseStatus": "W",
    "IsValid": false,
    "ResponseMessage": "Symptôme pas valide",
    "ResponseErrorMessage": null
}

Si la fiche de compétence (ou fiche métier) associée au produit soumis, issue de la labellisation, n’est pas associée au site faisant la demande un refus sera retourné.

  {
    "ResponseData": null,
    "ResponseStatus": "W",
    "IsValid": false,
    "ResponseMessage": "Votre compte n'est pas autorisé à effectuer une demande de soutien pour ce type de produit.",
    "ResponseErrorMessage": null
}

CalculateEcoSupport - Usage des marques inconnues VERSION 1.2

le mode marque inconnue est utilisable en utilisant les paramètres

  • BrandId = 0 (ce qui force le mode marque inconnue)

  • BrandName = nom_de_la_marque (champ qui devient obligatoire si BrandId = 0)

Ce qui donne par exemple les paramètres suivants

Si jamais le produit n’est pas pris en charge pour une marque inconnue par Ecologic, la réponse indique une erreur "ResponseMessage": "Invalid organization"

exemple

Fonctions

Permet de soumettre la demande de soutien en vue d'obtenir la vérification du consommateur.

Jusqu'à la version 1.4 cette étape est obligatoire, car l'Id de la demande sera demandé lors de la création de la demande de remboursement.

Données à transmettre

Exemple

{
  "Consumer": {
    "Title": 1,
    "LastName": "Test Nom",
    "FirstName": "Test prénom",
    "StreetNumber": "15",
    "Address1": "Avenue du Centre",
    "Address2": "",
    "Address3": "",
    "Zip": "78280",
    "City": "GUYANCOURT",
    "Country": "250",
    "Phone": "0600000000",
    "Email": "test@egmail.com",
    "AutoValidation": true
},
  "Product": {
    "ProductId": "EEE.M5.024",
    "BrandId": "2194",
    "CommercialRef": "Repasse Plus",
    "SerialNumber": "ABCDE",
    "PurchaseDate": "2020-10-06",
    "IRISCondition": "",
    "IRISConditionEX": "",
    "IRISSymptom": "XX13",
    "IRISSection": "",
    "IRISDefault": "",
    "IRISRepair": "",
    "FailureDescription": "Symptome code IRIS XX13",
    "DefectCode": ""  
},
  "Quote": {
    "LaborCost": {
      "Amount": 20.00,
      "Currency": "EUR"
    },
    "SparePartsCost": {
      "Amount": 10.00,
      "Currency": "EUR"
    },
    "TravelCost": {
      "Amount": 0.00,
      "Currency": "EUR"
    },
    "TotalAmountExclVAT": {
      "Amount": 100.00,
      "Currency": "EUR"
    },
    "TotalAmountInclVAT": {
      "Amount": 106.00,
      "Currency": "EUR"
    },
    "SupportAmount": {
      "Amount": 10.00,
      "Currency": "EUR"
    }
  },
  "SpareParts": [
    {
      "Partref": "",
      "Quantity": 0,
      "Status": ""
    }
  ]
}

Données en entrée

Dans les paramètres

  • CallDate= date de référence de l’appel à l’API

  • RepairSiteId= ID de votre compte e-reparateur.eco

  • QuoteNumber= numéro du devis

Dans le body

il y a 3 sections importantes:

  • Consumer : fourni

    • identité

      • Title -> 1 : Mrs. ; 2 : Ms. ; 3 : Mr. ; 4 : Société

    • adresse

    • téléphone = très important en cas de mode de vérification par SMS

    • email

    • VERSION 1.3 AutoValidation (optionnel)

      • si absent = Autovalidation = True => le mode sans SMS est activé

      • Autovalidation = False => génère une erreur (le mode SMS n’est plus autorisé)

  • Product : définit tous les paramètres du produit en réparation

    • ProductID = code du produit du référentiel

    • BrandID = code de la marque

    • SerialNumber = numéro de série

    • IRISSymptom = code IRIS de symptôme retenu associé au produit (doit correspondre à une entrée du référentiel retourné par PrintProductTypeList

    • FailureDescription = description des symptômes de la panne (ou de la panne)

  • Quote : définit les montants du devis associé à la demande

Données en sortie

  • RequestId: Identifiant de la demande de soutien,
    Cet ID unique sera à fournir pour toute référence à la demande de soutien qui vient d'être créée.

VERSION 1.1

Http Status

A la demande de plusieurs développeurs, l’API différencie dans le statut de réponse HTTP le fait que celle-ci le soit en réponse à une requête

  • avec toute les informations attendues = 200

  • avec des informations manquantes = 206

Exemple de réponse

{
    "ResponseData": {
        "EcoOrganizationId": 44,
        "RequestId": 5310857,
        "IsValid": true
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

En cas d’erreur un message vous oriente vers la cause

{
    "ResponseData": {
        "EcoOrganizationId": 44,
        "RequestId": 5312273,
        "IsValid": false,
        "ValidationErrors": [
            {
                "Field": "Montant de remboursement / Soutien",
                "ErrorMessage": "Code symptôme non valide, demande de remboursement / soutien non valide",
                "MessageType": "E"
            }
        ]
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": null,
    "ResponseErrorMessage": null
}

VERSION 1.3
Si le mode SMS est activé la création sera refusée

{
    "ResponseData": null,
    "ResponseStatus": "E",
    "IsValid": false,
    "ResponseMessage": "Invalid request",
    "ResponseErrorMessage": "AutoValidation should be false or empty"
}

Gestion des modes SMS ou Offline

VERSION 1.3 Le mode SMS n’est plus autorisé depuis la version 1.3 de l’API conformément à ce que les pouvoirs publics ont demandé

Il est possible de déclencher une demande de soutien en utilisant 2 modes différents:

  • mode SMS = le consommateur se verra envoyer un SMS avec un lien vers une page web lui permettant de valider la demande créée par le réparateur afin de s’assurer de la légitimité de la procédure en cours,

  • mode Offline = le consommateur n’est pas sollicité par SMS. Cela permet de traiter les cas où ce dernier n’est pas en situation de traiter un SMS (téléphone en panne, manque de pratique…)
    Le consommateur doit alors signer un document qui devra être transmis avec la demande de remboursement.

Le mode Offline est déclenché en ajoutant le paramètre "AutoValidation": true dans la structure des informations pour "Consumer"

{
  "Consumer": {
    "Title": 1,
    "LastName": "Test Nom",
    "FirstName": "Test prénom",
    "StreetNumber": "15",
    "Address1": "Avenue du Centre",
    "Address2": "",
    "Address3": "",
    "Zip": "78280",
    "City": "GUYANCOURT",
    "Country": "250",
    "Phone": "0600000000",
    "Email": "test@egmail.com",
    "AutoValidation": true
},

💡 Ne rien mettre ou mettre "AutoValidation": false sont équivalents

CreateSupportRequest - Usage des marques inconnues VERSION 1.2

le mode marque inconnue est utilisable en utilisant les paramètres

  • BrandId = 0 (ce qui force le mode marque inconnue)

  • BrandName = nom_de_la_marque (champ qui devient obligatoire si BrandId = 0)

Ce qui donne (fragment du JSON)

  ...
  "Product": {
    "ProductId": "EEE.M2.044",
    "BrandId": "0",
    "BrandName": "Marque Test 1",
    "CommercialRef": "Mobile Plus",
    "SerialNumber": "ABCDE",
    "PurchaseDate": "2020-10-06",
    "IRISCondition": "",
    "IRISConditionEX": "",
    "IRISSymptom": "XX9",
    "IRISSection": "",
    "IRISDefault": "",
    "IRISRepair": "",
    "FailureDescription": "Symptome code IRIS XX9",
    "DefectCode": ""  
},
...

Attention, s’il est possible de passer directement à la méthode CreateSupportRequest il faut s’assurer que le produit est bien pris en charge par Ecologic.
La méthode CreateSupportRequest peut engendrer une réponse négative si le produit sélectionné n’est pas pris en charge par Ecologic.
Donc n’utilisez ce mode directement que si vous avez la certitude que le produit sera bien accepté avec les paramètres transmis.

Fonctions

Permet de savoir si le consommateur a donné sa validation pour une demande de soutien donnée.

Données en entrée

Dans les paramètres

  • RequestId = Id de votre dossier issu de la réponse à CreateSupportRequest
    Ex : /GetSupportRequestStatus?RequestId=1564

Données en sortie

  • ValidationErrors : liste des erreurs encore présentes dans le dossier empêchant sa conversion en demande de remboursement (Claim)

  • LastStatus: Dernier statut de la demande de soutien

    • mode SMS non validé par le consommateur = "En attente de validation consommateur"

    • mode SMS validé par le consommateur ou mode offline : "Validé par le consommateur"

    • refusé

Exemple de réponse

{
    "ResponseData": [
        {
            "RequestId": 5310857,
            "LastStatus": "Validé par le consommateur",
            "Comment": "Symptome code IRIS 013",
            "CreateDate": "2023-03-01T15:49:50.4"
        }
    ],
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Fonctions

Permet de mettre à jour, compléter une demande de soutien (Request) avec un jeu de données.

Une demande de soutien (Request) validée par le consommateur ne peut plus être modifiée

Donc si en mode SMS le consommateur a validé ou si le processus est en mode Offline, la demande de modification retournera une erreur

Données en entrée

Dans les paramètres

  • RequestId = Id de votre dossier issu de la réponse à CreateSupportRequest
    Ex : /GetSupportRequestStatus?RequestId=1564

Données en sortie

  • RequestId : numéro du dossier de soutien (request)

  • IsValid : true si le dossier est prêt à être soumis

VERSION 1.1

Http Status

A la demande de plusieurs développeurs, l’API différencie dans le statut de réponse HTTP le fait que celle-ci le soit en réponse à une requête

  • avec toute les informations attendues = 200

  • avec des informations manquantes = 206

Exemple de réponse

{
    "ResponseData": {
        "EcoOrganizationId": 44,
        "RequestId": 5310864,
        "IsValid": true
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

VERSION 1.3
Si le mode SMS est activé la création sera refusée

{
    "ResponseData": null,
    "ResponseStatus": "E",
    "IsValid": false,
    "ResponseMessage": "Invalid request",
    "ResponseErrorMessage": "AutoValidation should be false or empty"
}


Gestion des demandes de remboursement

Une fois le dossier de soutien accepté et validé par le consommateur, la demande de remboursement peut être créée et gérée.

Créer une demande de remboursement - /CreateClaim POST

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/createclaim

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/createclaim

Fonctions

Permet d'effectuer la demande de remboursement (Claim) en convertissant une demande de soutien (Request)

En retour de cet appel, vous obtiendrez l'ID de votre demande de remboursement (ClaimId), qu'il vous faudra utiliser pour corriger les erreurs de validation, pour ajouter les pièces jointes requises et finalement soumettre votre demande. 

Informations du consommateur obligatoires

Données

Champs

Remarque

Civilité

Title

1 : Mrs. ; 2 : Ms. ; 3 : Mr. ; 4 : Société

Nom

LastName

Prénom

FirstName

Code postal

Zip

Ville

City

E-mail

Email

N° de téléphone

Phone

Pays

Country

code 250 pour la France
ISO 3166

Informations du Produit obligatoires

Données

Champs

Remarque

Marque

BrandId

issu du référentiel

Type de produit

ProductId

issu du référentiel

Code Panne

IRISSection

issu du référentiel

Informations du Produit facultatives

Données

Champs

Remarque

Référence commerciale

CommercialRef

N° de série / ID

SerialNumber

attention champ obligatoire si produit lié à la Fiche métier 7 EI&T

exemple

{
  "Consumer": {
    "Title": 1,
    "LastName": "Test Nom",
    "FirstName": "Test prénom",
    "StreetNumber": "15",
    "Address1": "Avenue du Centre",
    "Address2": "",
    "Address3": "",
    "Zip": "78280",
    "City": "GUYANCOURT",
    "Country": "250",
    "Phone": "0600000000",
    "Email": "test@egmail.com",
    "AutoValidation": false  
},
  "Product": {
    "ProductId": "EEE.M5.024",
    "BrandId": "2194",
    "CommercialRef": "Repasse Plus",
    "SerialNumber": "ABCDE",
    "PurchaseDate": "2020-10-06",
    "IRISCondition": "",
    "IRISConditionEX": "",
    "IRISSymptom": "",
    "IRISSection": "G18",
    "IRISDefault": "",
    "IRISRepair": "",
    "FailureDescription": "Code IRIS Symptome 013",
    "DefectCode": ""  
},
  "Quote": {
    "LaborCost": {
      "Amount": 20.00,
      "Currency": "EUR"
    },
    "SparePartsCost": {
      "Amount": 10.00,
      "Currency": "EUR"
    },
    "TravelCost": {
      "Amount": 0.00,
      "Currency": "EUR"
    },
    "TotalAmountExclVAT": {
      "Amount": 100.00,
      "Currency": "EUR"
    },
    "TotalAmountInclVAT": {
      "Amount": 106.00,
      "Currency": "EUR"
    },
    "SupportAmount": {
      "Amount": 10.00,
      "Currency": "EUR"
    }
  },
  "SpareParts": [
    {
      "Partref": "",
      "Quantity": 0,
      "Status": ""
    }
  ]
}

Données en entrée

Dans les paramètres
ex : /CreateClaim?RequestId=1564&RepairEndDate=2022-06-27T11:50:37.913Z&RepairSiteId=54654&ConsumerInvoiceNumber=132564

  • RequestId = date de référence du dossier de demande de soutien, issue de la réponse à CreateSupportRequest

  • RepairEndDate = Date de référence de la fin de réparation (ISO8601)

  • RepairSiteId = ID de votre compte e-reparateur.eco

  • ConsumerInvoiceNumber = numéro de référence de votre facture cliente

  • quoteNumber OPTIONNEL = numéro de référence interne chez le réparateur

Dans le body

Vérifiez bien la liste des champs obligatoires dans le Swagger évoqué au début du document.
C’est la source la plus sûr pour la structure des données à transmettre dans les méthodes.

  • IRISSection = il faut intégrer le code panne IRIS parmi ceux associés au produit dans le référentiel

Données en sortie

  • ClaimId : Identifiant du dossier de remboursement

  • IsValid : indique si le dossier de remboursement est valide (true ou false)

  • ValidationErrors : tableau des erreurs détectées si IsValid = false

VERSION 1.1

Http Status

A la demande de plusieurs développeurs, l’API différencie dans le statut de réponse HTTP le fait que celle-ci le soit en réponse à une requête

  • avec toute les informations attendues = 200

  • avec des informations manquantes = 206

Exemple de réponse

{
    "ResponseData": {
        "ClaimId": 5312276,
        "IsValid": false,
        "ValidationErrors": [
            {
                "Field": "Plaque signalétique",
                "ErrorMessage": "Des pièces jointes sont requises : Plaque signalétique",
                "MessageType": "E"
            },
            {
                "Field": "Facture",
                "ErrorMessage": "Des pièces jointes sont requises : Facture",
                "MessageType": "E"
            },
            {
                "Field": "Panne ou code IRIS",
                "ErrorMessage": "Cette valeur est obligatoire",
                "MessageType": "E"
            },
            {
                "Field": "Validation manuelle du consommateur",
                "ErrorMessage": "Des pièces jointes sont requises : Validation manuscrite",
                "MessageType": "E"
            },
            {
                "Field": "Montant de remboursement / Soutien",
                "ErrorMessage": "Code panne non valide, demande de remboursement / soutien non valide",
                "MessageType": "E"
            },
            {
                "Field": "Numéro de série",
                "ErrorMessage": "Une réparation a déjà été effectuée il y a moins de 6 mois sur cet appareil. Cette réparation est donc couverte par votre garantie.",
                "MessageType": "E"
            }
        ]
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": null,
    "ResponseErrorMessage": null
}

Ajouter une pièce jointe à la demande de remboursement - /AttachFile POST

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/AttachFile

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/AttachFile

Fonctions

Permet d'ajouter un document à une demande de remboursement. 

Formats supportés en entrée

  • jpg

  • jpeg

  • png

  • pdf

Un dossier de remboursement peut contenir plusieurs types de fichiers

Les types de fichiers qui peuvent être joints à une demande : 

  • facture = INVOICE

  • plaque signalétique ou numéro d’identification = NAMEPLATE

  • photo de l’appareil = PRODUCTPICTURE

  • l'élément de preuve = CONSUMERVALIDATION

Les pièces jointes obligatoires sont :

  • la facture

  • l'élément de preuve

  • (avertissement) pour les produits liés à la Fiche Métier 7 EI&T = la photo du numéro d’identification

Toute demande de remboursement qui ne disposerait pas de ces documents sera "non valide" et ne pourra être soumise.

Données à transmettre

exemple

{
  "FileContent": "KJQFKJSQKJDKJQSJDKLFDSGDGDG5F4D65HG46G4D5FSG456FD4G4SG64FSDG5FD5G46DS5G456FD4G56FDSG654FDS56G4F6DG54FDS6G5FD6SG45FS4D6G4F56D4SG654S6G4F5D4G6S45FD4G45SFD4G65FD4SG65DF46S4"
 }

Données en entrée

Dans les paramètres
ex : /AttachFile?ClaimId=16466&FileName=Facture797&FileExtension=pdf&DocumentType=Invoice

  • ClaimId = date de référence du dossier de demande de remboursement, issu de la réponse à CreateClaim

  • FileName = nom du fichier transmis (sans l’extension)

  • FileExtension = extension du fichier (voir ci contre)

    • permet de définir le type

    • extension sans le point “.”

  • DocumentType = type de document transmis à intégrer dans la demande (voir les codes identifiants ci contre)

Dans le body

  • FileContent = contenu du fichier en Base64

pour test exemple d’encodeur Base64 en ligne

https://base64.guru/converter/encode/file

Données en sortie

  • "Code 200 -> OK"

Le statut de sortie est géré par le statut de la réponse HTTP

  • Code 200 -> OK

  • Code 400 -> Bad request

  • Code 500 -> Internal Error


Mettre à jour, corriger la demande de remboursement - /UpdateClaim POST

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/updateclaim

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/updateclaim

Fonctions

Permet de mettre à jour, de corriger et de soumettre la demande de remboursement. La mise à jour n'est plus possible après la soumission de la demande.

Données à transmettre

Exemple (les données ci-dessous de l’exemple sont à mettre à jour; en effet des champs sont obsolètes)

{
  "Consumer": {
    "Title": 1,
    "LastName": "Test Nom",
    "FirstName": "Test prénom",
    "StreetNumber": "15",
    "Address1": "Avenue du Centre",
    "Address2": "",
    "Address3": "",
    "Zip": "78280",
    "City": "GUYANCOURT",
    "Country": "250",
    "Phone": "0600000000",
    "Email": "test@egmail.com",
    "AutoValidation": false  
},
  "Product": {
    "ProductId": "EEE.M5.024",
    "BrandId": "2194",
    "CommercialRef": "Repasse Plus",
    "SerialNumber": "ABCDE",
    "PurchaseDate": "2020-10-06",
    "IRISCondition": "",
    "IRISConditionEX": "",
    "IRISSymptom": "",
    "IRISSection": "G18",
    "IRISDefault": "",
    "IRISRepair": "",
    "FailureDescription": "Code IRIS Symptome 013",
    "DefectCode": ""  
},
  "Quote": {
    "LaborCost": {
      "Amount": 20.00,
      "Currency": "EUR"
    },
    "SparePartsCost": {
      "Amount": 10.00,
      "Currency": "EUR"
    },
    "TravelCost": {
      "Amount": 0.00,
      "Currency": "EUR"
    },
    "TotalAmountExclVAT": {
      "Amount": 100.00,
      "Currency": "EUR"
    },
    "TotalAmountInclVAT": {
      "Amount": 106.00,
      "Currency": "EUR"
    },
    "SupportAmount": {
      "Amount": 10.00,
      "Currency": "EUR"
    }
  },
  "SpareParts": [
    {
      "Partref": "",
      "Quantity": 0,
      "Status": ""
    }
  ]
}

Données en entrée

Dans les paramètres
ex : /UpdateClaim?ClaimId=5310865&repairEndDate=2023-02-24T11:00:00Z&RepairSiteId=02c867c0-3cef-454d-9a04-3cf8de2dc1c8&consumerInvoiceNumber=FACT_20230301-1&quoteNumber=REF_INT_20230301-1&Submit=false

  • ClaimId = date de référence du dossier de demande de soutien, issu de la réponse à CreateSupportRequest

  • RepairEndDate = Date de référence de la fin de réparation (ISO8601)

  • RepairSiteId = ID de votre compte e-reparateur.eco

  • ConsumerInvoiceNumber = numéro de référence de votre facture cliente

  • quoteNumber OPTIONNEL = numéro de référence interne chez le réparateur

VERSION 1.1 Le paramètre suivant reste fonctionnel et peut être utilisé, mais il peut être plus pratique d’utiliser la méthode /submitclaim pour déclencher la soumission

  • Submit = 💡 indique si la mise à jour déclenche ou non la soumission

    • false = la mise à jour n’est pas suivi d’une tentative de soumission

    • true = la mise à jour entraine une tentative de soumission

Dans le body

VVérifiez bien la liste des champs obligatoires dans le Swagger évoqué au début du document.
C’est la source la plus sûr pour la structure des données à transmettre dans les méthodes.

Données en sortie

  • ClaimId : Identifiant du dossier de remboursement en cours

  • IsValid : indique si le dossier de remboursement est valide (true ou false)

  • ValidationErrors : tableau des erreurs détectées si IsValid = false

VERSION 1.1

Http Status

A la demande de plusieurs développeurs, l’API différencie dans le statut de réponse HTTP le fait que celle-ci le soit en réponse à une requête

  • avec toute les informations attendues = 200

  • avec des informations manquantes = 206

Exemple de réponse

{
    "ResponseData": {
        "ClaimId": 5275562,
        "IsValid": false,
        "ValidationErrors": [
            {
                "Field": "Plaque signalétique",
                "ErrorMessage": "Des pièces jointes sont requises : Plaque signalétique",
                "MessageType": "E"
            },
            {
                "Field": "Facture",
                "ErrorMessage": "Des pièces jointes sont requises : Facture",
                "MessageType": "E"
            },
            {
                "Field": "Panne ou code IRIS",
                "ErrorMessage": "Cette valeur est obligatoire",
                "MessageType": "E"
            }
        ],
        "ErrorMessage": "Validation Errors"
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Si la soumission est OK

{
    "ResponseData": {
        "ClaimId": 5310865,
        "IsValid": true
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Facture non conforme à la soumission

Exemple de facture non liée à l’utilisateur

{
    "ResponseData": {
        "ClaimId": 5310865,
        "IsValid": false,
        "ValidationErrors": [
            {
                "Field": "OCR facture",
                "ErrorMessage": "La facture n'est pas conforme (Nom du consommateur)",
                "MessageType": "E"
            }
        ],
        "ErrorMessage": "Validation Errors"
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Fonctions

Permet de connaitre le statut d'une demande de remboursement qui a été soumise.

Données à transmettre

Exemple

/GetClaimStatus?ClaimId=5312276

Données en entrée

Dans les paramètres
ex : /GetClaimStatus?ClaimId=5312276

  • ClaimId = date de référence du dossier de demande de soutien, issu de la réponse à CreateSupportRequest

Données en sortie

  • ValidationErrors : liste des erreurs encore présentes dans le dossier empêchant sa soumission

  • LastStatus : Dernier statut de la demande de soutien

    • “Dossier incomplet” : des pièces ou des informations doivent être ajoutées au dossier de demande de remboursement (Claim) avant de tenter de le soumettre

Le statut "NotConform" indique qu'une action de correction est requise par Ecologic.
Ce statut permet de visualiser la demande dans le champ "Comment" et de mettre à jour la demande de remboursement puis finalement de la soumettre à nouveau.

Exemple de réponse

{
    "ResponseData": {
        "ValidationErrors": [
            {
                "Field": "Plaque signalétique",
                "ErrorMessage": "Des pièces jointes sont requises : Plaque signalétique",
                "MessageType": "E"
            },
            {
                "Field": "Facture",
                "ErrorMessage": "Des pièces jointes sont requises : Facture",
                "MessageType": "E"
            },
            {
                "Field": "Validation manuelle du consommateur",
                "ErrorMessage": "Des pièces jointes sont requises : Validation manuscrite",
                "MessageType": "E"
            },
            {
                "Field": "Montant de remboursement / Soutien",
                "ErrorMessage": "Le seuil n'est pas dépassé, demande de remboursement / soutien non valide",
                "MessageType": "E"
            },
            {
                "Field": "Numéro de série",
                "ErrorMessage": "Une réparation a déjà été effectuée il y a moins de 6 mois sur cet appareil. Cette réparation est donc couverte par votre garantie.",
                "MessageType": "E"
            }
        ],
        "ClaimId": 5312276,
        "LastStatus": "Dossier incomplet",
        "Comment": "Code IRIS Symptome 013",
        "CreateDate": "2023-05-05T15:15:50.953"
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

🆕 Soumettre la demande de remboursement - /submitclaim POST VERSION 1.1

URL Preprod = https://preprod-apiecologic.e-reparateur.eco/api/v1/ecosupport/submitclaim

URL Prod = https://apiecologic.e-reparateur.eco/api/v1/ecosupport/submitclaim

Fonctions

Permet de soumettre simplement un dossier

Données à transmettre

Exemple

/submitclaim?claimId=5275562

Données en entrée

Dans les paramètres
ex : /submitclaim?claimId=5275562

  • claimId = date de référence du dossier de demande de soutien, issu de la réponse à CreateSupportRequest

Données en sortie

  • ResponseData : détails sur le traitement

    • IsValid : indique si la soumission a été validée

    • ValidationErrors : liste des erreurs encore présentes dans le dossier empêchant sa soumission

Exemple de réponse

si la soumission contient des erreurs :

{
    "ResponseData": {
        "ClaimId": 5312276,
        "LastStatus": "Dossier incomplet",
        "Comment": "Code IRIS Symptome 013",
        "CreateDate": "2023-05-05T15:15:50.953"
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

Si la soumission est OK

{
    "ResponseData": {
        "ClaimId": 5310865,
        "IsValid": true
    },
    "ResponseStatus": "S",
    "IsValid": true,
    "ResponseMessage": "",
    "ResponseErrorMessage": ""
}

  • Aucune étiquette