Fonctions communes:API : Différence entre versions

De Logilys
Aller à : navigation, rechercher
(Liste des opérations)
 
(51 révisions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
{{Entete_NOTOC}}<br>  
+
{{Entete_TOC}}<br>  
  
 
== Communications (exemple en php)  ==
 
== Communications (exemple en php)  ==
Ligne 29 : Ligne 29 :
 
</pre>'''Fichier JSON'''
 
</pre>'''Fichier JSON'''
  
UID : Numéro unique servant uniquement à identifier la requête lorsqu'il est nécessaire de déboguer une requête.<br>Session : Texte de 100 caractères permettant de s'identifier dans votre logiciel. Cette chaîne de caractères doit être unique par utilisateur.<br>DemSoftware : Fait référence à la colonne « Application » dans la grille de la fenêtre de configuration de LDE. Sert à identifier à quel logiciel se connecter. (advenant le cas où vous auriez plusieurs logiciels de Logilys)<br>DemCat : Sert à identifier l'opération à effectuer. Voir la liste ci-dessous.<br>DemAction : Sert à identifier l'opération à effectuer. Voir la liste ci-dessous.<br>DemOptions : Paramètres nécessaires pour effectuer l'opération voulue. La liste va changer selon l'opération identifiée par DemAction et DemCat.
+
UID : Numéro unique servant uniquement à identifier la requête lorsqu'il est nécessaire de déboguer une requête.<br>Session : Texte de 100 caractères permettant de s'identifier dans votre logiciel. Cette chaîne de caractères doit être unique par utilisateur.<br>DemSoftware : Fait référence à la colonne « Application » dans la grille de la fenêtre de configuration de LDE. Sert à identifier à quel logiciel se connecter. (advenant le cas où vous auriez plusieurs logiciels de Logilys)<br>DemCat : Sert à identifier l'opération à effectuer. Voir la [[#Liste des opérations|liste des opérations]].<br>DemAction : Sert à identifier l'opération à effectuer. Voir la [[#Liste des opérations|liste des opérations]].<br>DemOptions : Paramètres nécessaires pour effectuer l'opération voulue. La liste va changer selon l'opération identifiée par DemAction et DemCat.
  
 
'''Envoi du JSON avec curl'''
 
'''Envoi du JSON avec curl'''
Ligne 160 : Ligne 160 :
 
</pre>
 
</pre>
  
== Ouverture de session  ==
+
== Liste des opérations ==
L'ouverture de session est obligatoire. Aucune requête ne sera fonctionnelle tant qu'une session n'aura pas été ouverte dans votre logiciel.
+
{| class="wikitable"
<br><br>DemAction : SELECT<br>DemCat : LOGIN<br>DemOptions :
+
!DemAction
* UsrEmail : Courriel servant à s'identifier. Doit correspondre au courriel inscrit dans la fiche de l'utilisateur dans votre logiciel.
+
!DemCat
* NomSession : Même nom de session utiliser lors de l'envoi d'une requête sous forme de JSON.
+
!Explications
* LngUID : Langue d'affichage (0 = Français, 1 = Anglais)
+
|-
<br>Informations retournées : <pre>
+
|[[Fonctions_communes:API_-_SELECT_-_LOGIN|SELECT]]
+
|[[Fonctions_communes:API_-_SELECT_-_LOGIN|LOGIN]]
  "Usr":[
+
|Ouverture de session.
    { 
+
|-
      "UsrHidenNo":"5",
+
|[[Fonctions_communes:API_-_SELECT_-_GRID_CONFIG|SELECT]]
      "LngUID":"0",
+
|[[Fonctions_communes:API_-_SELECT_-_GRID_CONFIG|GRID_CONFIG]]
      "Message":""
+
|Récupérer la configuration d'une grille.
    }
+
|-
  ],
+
|[[Fonctions_communes:API_-_BROWSE_-_DATA|BROWSE]]
  "SecUsr":[
+
|[[Fonctions_communes:API_-_BROWSE_-_DATA|DATA]]
    { 
+
|Récupérer les données d'une grille.
      "Security":"ASSNOUVALCLI",
+
|-
      "Access":"O"
+
|[[Fonctions_communes:API_-_CONSULT_-_CLI|CONSULT]]
    },
+
|[[Fonctions_communes:API_-_CONSULT_-_CLI|CLI]]
    { 
+
|Afficher les données d'un client.
      "Security":"CLIGES",
+
|-
      "Access":"A M D C"
+
|[[Fonctions_communes:API_-_CONSULT_-_CLI_LIST|CONSULT]]
    },
+
|[[Fonctions_communes:API_-_CONSULT_-_CLI_LIST|CLI_LIST]]
    { 
+
|Afficher les listes personnalisées de type client pour un client.
      "Security":"ADRESSEGES",
+
|-
      "Access":"A M _ C"
+
|[[Fonctions_communes:API_-_LIST_-_WIDGET|LIST]]
    }
+
|[[Fonctions_communes:API_-_LIST_-_WIDGET|WIDGET]]
  ],
+
|Afficher la liste des widgets disponibles.
  "DisplayFormat":[
+
|-
    { 
+
|[[Fonctions_communes:API_-_CONFIG_-_WIDGET|CONFIG]]
      "LngUID":"0",
+
|[[Fonctions_communes:API_-_CONFIG_-_WIDGET|WIDGET]]
      "LngCode":"FR",
+
|Récupérer la liste des paramètres d'un widget.
      "CurrencyFormat":"0",
+
|-
      "NegCurrencyFormat":"14",
+
|[[Fonctions_communes:API_-_RESULT_-_WIDGET|RESULT]]
      "DecimalSeparator":",",
+
|[[Fonctions_communes:API_-_RESULT_-_WIDGET|WIDGET]]
      "ThousandSeparator":"\u00A0",
+
|Récupérer les données nécessaires à l'affichage du widget.
      "DateSeparator":".",
+
|-
      "ShortDateFormat":"jj.mm.aaaa",
+
|[[Fonctions_communes:API_-_CHECK_-_MAINTENANCE|CHECK]]
      "LongDateFormat":"jjjj j mmmm aaaa",
+
|[[Fonctions_communes:API_-_CHECK_-_MAINTENANCE|MAINTENANCE]]
      "DateTimeFormat":"jj.mm.aaaa hh:nn",
+
|Permet de vérifier si une mise à jour du logiciel est en cours.
      "ShortTimeFormat":"hh:nn",
+
|-
      "CurrencyString":"$"
+
|[[Fonctions_communes:API_-_ELEVATE_-_USR|ELEVATE]]
    },
+
|[[Fonctions_communes:API_-_ELEVATE_-_USR|USR]]
    { 
+
|Permet à un utilisateur de s'élever SUPERVISEUR ou de quitter le mode SUPERVISEUR.
      "LngUID":"1",
+
|-
      "LngCode":"EN",
+
|[[Fonctions_communes:API_-_CONSULT_-_TAC|CONSULT]]
      "CurrencyFormat":"0",
+
|[[Fonctions_communes:API_-_CONSULT_-_TAC|TAC]]
      "NegCurrencyFormat":"0",
+
|Afficher les données d'une tâche.
      "DecimalSeparator":",",
+
|-
      "ThousandSeparator":" ",
+
|[[Fonctions_communes:API_-_UPDATE_-_TOKEN_ADMIN|UPDATE]]
      "DateSeparator":"/",
+
|[[Fonctions_communes:API_-_UPDATE_-_TOKEN_ADMIN|TOKEN_ADMIN]]
      "ShortDateFormat":"yyyy/mm/dd",
+
|Change le code de sécurité et l'expiration pour le compte DEVELOPPEUR.
      "LongDateFormat":"dddd, mmmm d yyyy",
+
|-
      "DateTimeFormat":"yyyy/mm/dd hh:nn",
+
|[[Fonctions_communes:API_-_FIND_-_FILES|FIND]]
      "ShortTimeFormat":"hh:nn",
+
|[[Fonctions_communes:API_-_FIND_-_FILES|FILES]]
      "CurrencyString":"$"
+
|Retourne la liste des fichiers de ce dossier.
    }
+
|-
  ],
+
|[[Fonctions_communes:API_-_DOWNLOAD_-_FILE|DOWNLOAD]]
  "Support":[
+
|[[Fonctions_communes:API_-_DOWNLOAD_-_FILE|FILE]]
    { 
+
|Télécharge un fichier.
      "NoSerie":"0007008012",
+
|-
      "OrgCodeP":"G6T 1S7",
+
|[[Fonctions_communes:API_-_UPLOAD_-_FILE|UPLOAD]]
      "OrgBur":"(819) 758-0560"
+
|[[Fonctions_communes:API_-_UPLOAD_-_FILE|FILE]]
    }
+
|Téléverse un fichier.
  ],
+
|}
  "About":[ 
 
    { 
 
      "NoSerie":"0007008012",
 
      "Version":"5.0.5",
 
      "TypeVersion":"Multi-utilisateur",
 
      "VersionSQL":"Developer Edition (64-bit) 11.0.2100.60 RTM",
 
      "NbLic":"10"
 
    }
 
  ],
 
  "Org":[
 
    { 
 
      "OrgUID":"1",
 
      "OrgCode":"ORG1",
 
      "OrgNom":"Fondation Démo"
 
    }
 
}
 
</pre>
 
'''Usr''' : Informations sur l'utilisateur et le login<br>
 
* UsrHidenNo : Numéro de l'utilisateur correspondant au courriel utilisé pour le login. Si ce champ est vide, c'est que le login a échoué.
 
* LngUID : Langue d'affichage (0 = Français, 1 = Anglais)
 
* Message : Message d'erreur indiquant pourquoi le login a échoué.
 
'''SecUsr''' : Sécurités
 
* Security : Code de la sécurité
 
* Access : Accès pour cette sécurité (AMDC ou Oui/Non)
 
'''DisplayFormat''' : Configurations pour les formats d'affichage
 
* LngUID : Langue d'affichage (0 = Français, 1 = Anglais)
 
* LngCode : Code de la langue d'affichage
 
* CurrencyFormat : Format d'affichage pour les valeurs monétaires positives
 
  0 = $1
 
  1 = 1$
 
  2 = $ 1
 
  3 = 1 $
 
* NegCurrencyFormat : Format d'affichage pour les valeurs monétaires négatives
 
  0  = ($1)
 
  1  = -$1
 
  2  = $-1
 
  3  = $1-
 
  4  = (1$)
 
  5  = -1$
 
  6  = 1-$
 
  7  = 1$-
 
  8  = -1 $
 
  9  = -$ 1
 
  10 = 1 $-
 
  11 = $ 1-
 
  12 = $ -1
 
  13 = 1- $
 
  14 = ($ 1)
 
  15 = (1 $)
 
* DecimalSeparator : Séparateur de décimales pour les valeurs monétaires
 
* ThousandSeparator : Séparateur de milliers pour les entiers supérieurs à 999
 
* DateSeparator : Séparateur de date
 
* ShortDateFormat : Format d'affichage pour les dates courtes sans heure, sans nom de jour ni de mois.
 
* LongDateFormat : Format d'affichage pour les dates longues sans heure mais ayant un nom de jour ou de mois.
 
* DateTimeFormat : Format d'affichage pour les dates ayant une heure
 
* ShortTimeFormat : Format d'affichage pour les heures
 
* CurrencyString : Devise monétaire
 
'''Support''' : Informations nécessaire pour l'affichage de la page de demande de soutien
 
* NoSerie : Numéro de série de la clé logicielle
 
* OrgCodeP : Code postal de l'organisme #1
 
* OrgBur : Téléphone au bureau de l'organisme #1
 
'''About''' : Informations nécessaire pour l'affichage de la page « À propos de... »
 
* NoSerie : Numéro de série de la clé logicielle
 
* Version : Version de l'application
 
* TypeVersion : Type de license
 
* VersionSQL : Numéro de la version de MS SQL Server
 
* NbLic : Nombre d'utilisateur simultanés
 
'''Org''' : Liste de organismes
 
* OrgUID : ID de l'organisme
 
* OrgCode : Code de l'organisme
 
* OrgNom : Nom de l'organisme
 
  
== Récupération de la configuration d'une grille  ==
+
== Erreurs ==
Cette opération permet de récupérer la liste des vues, des filtres et des boutons de filtre rapide pour une grille précise.<br>
+
Lorsqu'une opération génère une erreur, le résultat retourne 3 informations : Le code d'erreur (ErrCode), le message (ErrMessage) et possiblement des informations supplémentaires sur l'erreur (ErrMemo).
 +
<br><br>
 
{{BasPage_Fonctions_communes}}
 
{{BasPage_Fonctions_communes}}

Version actuelle datée du 15 mai 2019 à 13:38

API


Communications (exemple en php)

Pour utiliser l'API, les requêtes doivent passer par LDE. Les communications se font par l'intermédiaire de fichiers JSON. Voici un exemple en php servant à faire une demande à LDE afin de récupérer de l'information :

$jsonfile='{';
$jsonfile.='"UID":"1318396",';
$jsonfile.='"Session":"ifcu20j7de8q5m96r1ovpheog4",';
$jsonfile.='"DemSoftware":"PRODON",';
$jsonfile.='"DemCat":"LOGIN",';
$jsonfile.='"DemAction":"SELECT",';
$jsonfile.='"DemOptions":{"LngUID":0,"UsrEmail":"exemple@exemple.com","NomSession":""}';
$jsonfile.='}';

$ch=curl_init();
curl_setopt($ch,CURLOPT_URL,"https://192.168.0.50");
curl_setopt($ch,CURLOPT_PORT,"123");
curl_setopt($ch,CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch,CURLOPT_POST,1);
curl_setopt($ch,CURLOPT_USERPWD,"username:password");
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE);
curl_setopt($ch,CURLOPT_CAINFO,"/path/to/cacert.pem");
curl_setopt($ch,CURLOPT_POSTFIELDS,array("filecontenttype"=>"application/json","file"=>$jsonfile));
curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);
curl_setopt($ch,CURLOPT_CONNECTTIMEOUT,30);
curl_setopt($ch,CURLOPT_TIMEOUT,30);
$result=curl_exec($ch);

Fichier JSON

UID : Numéro unique servant uniquement à identifier la requête lorsqu'il est nécessaire de déboguer une requête.
Session : Texte de 100 caractères permettant de s'identifier dans votre logiciel. Cette chaîne de caractères doit être unique par utilisateur.
DemSoftware : Fait référence à la colonne « Application » dans la grille de la fenêtre de configuration de LDE. Sert à identifier à quel logiciel se connecter. (advenant le cas où vous auriez plusieurs logiciels de Logilys)
DemCat : Sert à identifier l'opération à effectuer. Voir la liste des opérations.
DemAction : Sert à identifier l'opération à effectuer. Voir la liste des opérations.
DemOptions : Paramètres nécessaires pour effectuer l'opération voulue. La liste va changer selon l'opération identifiée par DemAction et DemCat.

Envoi du JSON avec curl

CURLOPT_URL : URL pour accéder à votre LDE.
CURLOPT_PORT : Port SSL inscrit dans la section « Web Server » de la fenêtre de configuration de LDE.
CURLOPT_USERPWD : Username et Password inscrit dans la section « Web Server » de la fenêtre de configuration de LDE.
CURLOPT_CAINFO : Doit pointer vers votre certificat SSL.
CURLOPT_POSTFIELDS : Identifier le fichier JSON à envoyer. Il faut absolument documenter le filecontenttype à application/json.

Réception de la réponse

La réponse sera retournée sous forme de JSON. Voilà à quoi peut ressembler la réponse :

stdClass Object
(
    [Usr] => Array
        (
            [0] => stdClass Object
                (
                    [UsrHidenNo] => 24
                    [LngUID] => 0
                    [Message] => 
                )

        )

    [SecUsr] => Array
        (
            [0] => stdClass Object
                (
                    [Security] => CLIGES
                    [Access] => A M D C
                )

            [1] => stdClass Object
                (
                    [Security] => ADRESSEGES
                    [Access] => A M _ C
                )

            [2] => stdClass Object
                (
                    [Security] => STD_RAPPORT_17
                    [Access] => O
                )

        )

    [Module] => Array
        (
            [0] => stdClass Object
                (
                    [Module] => AEL
                    [Active] => 1
                )

            [1] => stdClass Object
                (
                    [Module] => BENEF
                    [Active] => 1
                )

            [2] => stdClass Object
                (
                    [Module] => DEL
                    [Active] => 1
                )

        )

    [DisplayFormat] => Array
        (
            [0] => stdClass Object
                (
                    [LngUID] => 0
                    [LngCode] => FR
                    [CurrencyFormat] => 0
                    [NegCurrencyFormat] => 14
                    [DecimalSeparator] => ,
                    [ThousandSeparator] =>  
                    [DateSeparator] => .
                    [ShortDateFormat] => jj.mm.aaaa
                    [LongDateFormat] => jjjj j mmmm aaaa
                    [DateTimeFormat] => jj.mm.aaaa hh:nn
                    [ShortTimeFormat] => hh:nn
                    [CurrencyString] => $
                )

            [1] => stdClass Object
                (
                    [LngUID] => 1
                    [LngCode] => EN
                    [CurrencyFormat] => 0
                    [NegCurrencyFormat] => 0
                    [DecimalSeparator] => ,
                    [ThousandSeparator] =>  
                    [DateSeparator] => /
                    [ShortDateFormat] => yyyy/mm/dd
                    [LongDateFormat] => dddd, mmmm d yyyy
                    [DateTimeFormat] => yyyy/mm/dd hh:nn
                    [ShortTimeFormat] => hh:nn
                    [CurrencyString] => $
                )

        )

    [Support] => Array
        (
            [0] => stdClass Object
                (
                    [NoSerie] => 0007008012
                    [OrgCodeP] => G6T 1S7
                    [OrgBur] => (819) 758-0560
                )

        )

    [About] => Array
        (
            [0] => stdClass Object
                (
                    [NoSerie] => 0007008012
                    [Version] => 5.0.5
                    [TypeVersion] => Multi-utilisateur
                    [VersionSQL] => Developer Edition (64-bit) 11.0.2100.60 RTM
                    [NbLic] => 10
                )

        )

)

Liste des opérations

DemAction DemCat Explications
SELECT LOGIN Ouverture de session.
SELECT GRID_CONFIG Récupérer la configuration d'une grille.
BROWSE DATA Récupérer les données d'une grille.
CONSULT CLI Afficher les données d'un client.
CONSULT CLI_LIST Afficher les listes personnalisées de type client pour un client.
LIST WIDGET Afficher la liste des widgets disponibles.
CONFIG WIDGET Récupérer la liste des paramètres d'un widget.
RESULT WIDGET Récupérer les données nécessaires à l'affichage du widget.
CHECK MAINTENANCE Permet de vérifier si une mise à jour du logiciel est en cours.
ELEVATE USR Permet à un utilisateur de s'élever SUPERVISEUR ou de quitter le mode SUPERVISEUR.
CONSULT TAC Afficher les données d'une tâche.
UPDATE TOKEN_ADMIN Change le code de sécurité et l'expiration pour le compte DEVELOPPEUR.
FIND FILES Retourne la liste des fichiers de ce dossier.
DOWNLOAD FILE Télécharge un fichier.
UPLOAD FILE Téléverse un fichier.

Erreurs

Lorsqu'une opération génère une erreur, le résultat retourne 3 informations : Le code d'erreur (ErrCode), le message (ErrMessage) et possiblement des informations supplémentaires sur l'erreur (ErrMemo).


Nom du document : Fonctions communes:API