Poursuivons ce sujet déjà abordé dans un précédent article.
Services Web en RPG ILE, Écrire un programme HLL
Services Web en RPG ILE, Écrire un programme HLL
Pour accéder à la première partie du dossier : « Consommer des services Web en RPG ILE »
Nous allons évoquer aujourd’hui une amélioration très intéressante sur le sujet. Si vous vous rappelez, l’utilitaire wsdl2ws.sh d’Apache Axis nous permettait de générer tous les programmes clients nécessaires pour consommer un Service Web comme montré ci-dessous.
Il ne nous manquait plus qu’à écrire un programme HLL (en RPG ou COBOL) afin d’appeler ces programmes C/C++. La principale difficulté de cet exercice était de savoir lire un programme C/C++ afin de déterminer les bons paramètres attendus par ces « stubs ».
Dorénavant, nous pouvons utiliser le nouvel utilitaire wsdl2rpg.sh qui permet de générer les stubs directement en RPGLE facilitant ainsi grandement l’interface entre programmes. De plus, le résultat de la compilation n’est ni plus ni moins qu’un programme de service directement utilisable comme nous allons le voir.
L’utilitaire wsdl2rpg.sh est disponible par PTF en V5R4, V6R1 et V7R1 depuis le Janvier 2011.
V5R41 |
V6R1 |
V7R1 |
|
PTFs prélables |
SI42234 |
SI42236 |
SI42235
|
Source : APAR SE46281
Comme le précédent, cet utilitaire ce trouve dans le répertoire de l’IFS à l’emplacement :
/qibm/proddata/os/webservices/v1/client/bin
Reprenons l’exemple du Service Web gratuit StockQuote utilisé dans l’article précédent, permettant d’interroger directement la bourse de NewYork (NYSE). Vous pouvez le tester directement en ligne sur le lien suivant si le serveur n’est pas surchargé comme à son habitude.
Nous commencerons par créer un répertoire dans l’IFS.
MKDIR ‘/home/webservices’
Puis nous récupérons le fichier WSDL du service web et le plaçons dans l’IFS sous le nom StockQuote.WSDL : http://www.webservicex.net/stockquote.asmx?WSDL.
Sous QSH il nous suffit de lancer :
1./QIBM/ProdData/OS/WebServices/V1/client/BIN/wsdl2rpg.sh -t60 -o/home/webservices -s/QSYS.LIB/MYLIB.LIB/STOCKQUOTE.SRVPGM /home/webservices/StockQuote.wsdl
-t : Ce paramètre facultatif permet d’indiquer un timeout en secondes
-o : Répertoire où seront générés les sources des programmes
-s : Répertoire ou sera généré le programme de service compilé, ici il s’agit de la bibliothèque MYLIB
Le dernier paramètre représente le fichier WSDL ou son URI ce qui veut dire que l’on aurait très bien pu demander la génération du programme de service et des programmes sources sans copier le fichier WSDL dans l’IFS en utilisant la syntaxe ci-dessous :
1./QIBM/ProdData/OS/WebServices/V1/client/BIN/wsdl2rpg.sh -t60 -o/home/webservices -s/QSYS.LIB/MYLIB.LIB/STOCKQUOTE.SRVPGM http://www.webservicex.net/stockquote.asmx?WSDL
Code generation completed. Generated files in directory
'/home/webservices’.
Attempting to create service program...
Service program created. Service program is
'/QSYS.LIB/MYLIB.LIB/STOCKQUOTE.SRVPGM'.
$
Les fichiers sources et programmes générés sont les suivants :
/home/webservices |
DESCRIPTION |
StockQuoteSoap.c StockQuoteSoap.h |
Stub Axis en C++ (Corps et Entête) ayant servi à créer le module WSC0 dans la bibliothèque MYLIB |
StockQuoteSoap.cl |
Programme CLLE ayant servi à créer le programme de service STOCKQUOTE dans la bibliothèque MYLIB par assemblage des modules WSC0, WSR1 et WSR2 |
StockQuoteSoap.rpgle StockQuoteSoap.rpgleinc |
Procédures du Web Service (Corps et Entête) compilés dans le module WSR1 |
StockQuoteSoap_util.rpgle StockQuoteSoap_util.rpgleinc |
Utilitaires RPGLE (Corps et Entête) ) compilés dans le module WSR2 |
StockQuoteSoap_xsdtypes.rpgleinc |
Types standards de données utilisés en /COPY |
Bibliothèque MYLIB |
Type |
DESCRIPTION |
STOCKQUOTE |
*SVRPGM |
StockQuoteSoap Web service |
WSC0 |
*MODULE |
StockQuoteSoap.c |
WSR1 |
*MODULE |
StockQuoteSoap.rpgle |
WSR2 |
*MODULE |
StockQuoteSoap_util.rpgle |
Le seul fichier source qui va nous intéresser par la suite est StockQuoteSoap.rpgle ainsi que le programme de service STOCKQUOTE.SVRPGM.
Visualisons maintenant le contenu du source StockQuoteSoap.rpgle généré automatiquement. Trois procédures y sont définies :
1. stub_create_StockQuoteSoap
2. stub_destroy_StockQuoteSoap
3. stub_op_GetQuote
Voir Listing ci-dessous :
Téléchargez cette ressource
Guide inmac wstore pour l’équipement IT de l’entreprise
Découvrez les dernières tendances et solutions IT autour des univers de Poste de travail, Affichage et Collaboration, Impression et Infrastructure, et notre dossier Green IT sur les actions engagés par inmac wstore pour réduire son impact environnemental