> Tech > Services Web en RPG ILE, Écrire un programme HLL

Services Web en RPG ILE, Écrire un programme HLL

Tech - Par Patrick Thomas - Publié le 25 septembre 2013
email

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

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

Tech - Par Patrick Thomas - Publié le 25 septembre 2013