MDRest4i Commands
MDRCBLCPY - Create COBOL Copybook
Creates a COBOL copybook with schemas used by MDR_DATA-GEN and MDR-DATA-INTO functions from MDRFRAME. See here for details of this command and its purpose.
MDRCVT12 - Copy the V12 Specs to V14
This command is the first step in a two stage process, used to import SWAGGER specs from V12 into v14
It copies V12 specs from the V12 SDK folders, into the V14 file MDRDOAPI.
After this command has been run, The SDK import function provided in the Site Admin section for importing these specs in bulk, and converting the MDRest4i OAPI extensions to V14 format.
MDRest4i Copy V12 specs in V14 (MDRCVT12)
Type choices, press Enter.
Instance Name . . . . . . . . . INSTANCE *DFT
User Name . . . . . . . . . . . USERNM *ALL
Sufix Value . . . . . . . . . . SUFIX V12
...
Bottom
F3=Exit F4=Prompt F5=Refresh F12=Cancel F13=How to use this display
F24=More keys
Parameter Definitions:
Parameter | Description |
---|---|
INSTANCE | MDRest4i Instance name for the V12 SDK. For most this will be DFT, which means the MDRest4i library name for V12 is MDRST* |
USERNM | Which user name in the V12 SDK registered users, should SWAGGER specifications be imported for. |
SUFIX | This is a suffix that will be added to the imported specs |
MDRHTTPAPI - Create API Server
To setup your own HTTP instances for development or production purposes, then prompt the MDRHTTPAPI command. The following screen will appear:
MDRest4i Create SDK Server (MDRHTTPAPI)
Type choices, press Enter.
HTTP Server Name . . . . . . . . MDRSTAPI Instance Name
HTTP Instance Root Path . . . . '/www/mdrstapi'
Port Number . . . . . . . . . . 4546 TCP Port Number for Server
Program ASP . . . . . . . . . . Leave blank for *SYSBASE
API Library Name/s . . . . . . . YOURAPILIB List of API Object Libs
+ for more values
Authority Profile . . . . . . . MDOWNER Character value
Start TCP/IP Server . . . . . . Y Y, N
Bottom
F3=Exit F4=Prompt F5=Refresh F12=Cancel F13=How to use this display
F24=More keys
Parameter Definitions:
Parameter | Description |
---|---|
HTTP Server Name | Name of the HTTP server instance |
HTTP Instance Root Path | Specify the value of IFS path used to store docs for this HTTP instance. For example, if server name is MDRDEMO then the value of Server Root parameter could be: /www/mdrdemo. It is easier to name them the same for auditing and admin purposes. |
Port Number | Port Number for the HTTP Server (default value is 80) Please check with your networking, infrastructure admin if allocating a port other than 80. Also check if the port you are using is not already in use on the LPAR you are hosting the server instance being setup. |
Program ASP | System ASP where the MDRST instance is installed. |
API Library Name/s | Name the library that contains the API programs generated by MDRest4i SDK. |
Authority Profile | This profile used to execute the CGI APIs and system APIs used when running REST CGi programs. By Default this is set as MDOWNER which was created during the MDREST4INS installation earlier. |
Start TCP/IP Server | Start the new HTTP server instance. This will start the instance after it is setup by the command. To start the server manually later use command below (Considering the Server Name as MDRSTAPI) : STRTCPSVR SERVER(*HTTP) HTTPSVR(MDRSTAPI) |
Once the command has successfully executed, you can see the HTTP server instance configuration stored in IFS path using below command (Considering the Server Root as “/www/mdrstapi):
Wrklnk '/www/mdrstapi/conf/httpd.conf'
To see the active jobs running for this server instance use this command on the IBM i:
WRKACTJOB SBS(QHTTPSVR) JOB(MDRSTAPI)
Where “MDRSTAPI” is the server name from the MDRHTTPAPI command above
Testing the API Server
Tip
If this is a first time installation, conduct these tests after the license installation.
Using a web browser, test the Helloworld REST API shipped with the MDREST4i product and found in library MDRST:
http://[your serverip or host]:[yourport]/mdrapi/mdrhello?firstName=Mike&lastName=Smith&Title=Mr
You should see the following response in the browser:
MDRRHTTP - Maintain HTTP Servers
This command allows a user to mange the variosu aspects of IBM i Apache HTTP Server instances, created with commands MDRSDKINS, MDRHTTPAPI.
MDRRHTTP MDRSTT14 5.08.24
MDRRHTTP - Maintain HTTP Servers 16:12:53
Type options, press Enter.
2=Edit 4=Delete 5=View 6=Start 7=Stop 9=Stats L=Logs J=JobD
Opt Server Name PortNo Status Started JobD
___ MDRSTT14 2514 *ACTIVE 2024-02-26-18.02.21 MDRSTT14
___ MDRSTT14A 2515 *STOPPED 2024-05-28-17.16.50 MDRSTT14A
___ STUART13 2593 *ACTIVE 2024-04-05-15.24.10 STUART13
___ MDWEB 2566 *ACTIVE 2024-05-29-10.43.40 MDWEB
___ MDVISRASHI 2599 *STOPPED 2024-07-22-12.50.14 MDVISRASHI
Bottom
F6=Add Server F3=Exit F5=Refresh
Options
Option | Description |
---|---|
2=Edit | This updates the data in the MDRST/MDRDHTTP table, and if requested, the server instance httpd.conf. |
4=Delete | Deletes the server instance. Also deletes the file server ifs folder if selected on the conformation screen. |
5=View | Displays the server instance details view |
6=Start | Start the server instance |
7=Stop | Stop the server instance |
9=Stats | If the server is active, it displays basic statistics since the the last start of the server. |
L=Logs | Opens the ifs folder for the HTTP server instance, as defined in the httpd.conf for that instance |
J=JobD | Opens Work with Job Descriptions IBM i screen for the Job Description defined for that server. See the HTTPStartJobDesc MDRSTT14/MDRSTT14 directive in the httpd.conf for that server. |
MDRSDKINS - Install MDRest4i SDK
Details for this command are in the SDK installation page:
MDRSDKTEMP - Init JSON Templates
This command is used to reset the SWAGGER/OAPI templates used by the SDK when creating a new Consumer or Provider specification, back to their shipped state.
MDRSDKUPD - Updating the SDK Web Application
Warning
To run this command, the MDRest4i SDK web application must be already installed for this instance. Run command MDRSDKINS to install the SDK web application
The MDRSDKUPD command has no parameters. It only executes if the SDK has already been installed. It backs up the existing config files for the MDRest4i SDK web UI, installs the new code base, and copies back the SDK web UI config files.
The SDK web UI is backed up to IFS folder: /mdrest4i/sdkbu-mdrst
Note
The backup path is based uon the instance name for MDRest4i. If the MDRest4i instance is 'V14' for example, the backup folder for te SDK update will be: /mdrest4i/sdkbu-mdrst
To run the command:
ADDLIBLE MDRST
MDRSDKUPD
command and enter
MDRSDKUSR - Add/Update SDK User
This command is an alternative to the Site Admin>manage Users option in the SDK web UI.
MDRest4i- Add/Update SDK User (MDRSDKUSR)
Type choices, press Enter.
User Name . . . . . . . . . . . Name
Name . . . . . . . . . . . . . . 'REST4i USER'
Email address . . . . . . . . . 'youremail@yourdomain.com'
Domain Name . . . . . . . . . . CONS Name
User Class . . . . . . . . . . . ADM
Activated . . . . . . . . . . . Y Y, N
Default Object Library . . . . . 'YOURAPILIB'______________________
_____________________________________________________________________
...
Default Source file . . . . . . '/QSYS.LIB/MDRST.LIB/EXAMPLE.FILE'
_____________________________________________________________________
...
Default Server URL . . . . . . . 'http://yourhost:yourport/yourlib'___
Variable | Description |
---|---|
USERNAME | A valid IBM i user name. |
NAME | User's actual name |
User's email address | |
DOMAIN | Valid Values: CONS for Console and Documenter DOCU for MDRest4i Portal ONLY |
ACTIVATED | Users must be activated before they can login. Valid values are Y or N |
DFTOBJL | Specify the default object library to use for new OAPI specs. |
DFTSRCF | Specify the default source file to use for new OAPI specs. |
DFTURL | Specify the default testing URL to use for new OAPI specs. |
MDRSTCFG - API Path and Logging Configuration
MDRDCFG is a DB 2 table that holds the configuration details of API programs called by MDRAPI. It can be edited programmatically, by using command: MDRST/MDRSTCFG, or by MDCMS Data Group attributes.
It controls the following for each API program(Provider) called by MDRAPI:
- URI resource name to pgm object mapping
- Logging
To edit details in this file, invoke command MDRST/MDRSCFG
Edit MDRest4i Provider Configs
2=Edit 4=Delete
Logging
Opt Root Resource IFS DTQ PF
/CLIENTS Y N N
Bottom
F3=Exit F5=Refresh F6=Add
Selecting 2 to edit will bring up the following screen:
Edit Config
Root Resource: /CLIENTS
Program: PGM001
Library:
Log to (Y/N): IFS: Y DATAQ: N PF: N
Log Name:
IFS: /mylogs/pgm001-%F.txt
DATAQ:
PF:
Log Details (Y/N): For Request For Response
Path: Y
Headers: Y Y
Body: Y Y
F12=Cancel
Variable | Description |
---|---|
Root Resource | This is user friendly resource name used to invoke the API. MDRAPI will resolve this and call the Program below |
Program | Name of the API program called by MDRAPI |
Library | Library name used in the call. No value will cause MDRAPI to use *LIBL to make the call |
Log to | Possible values: Y or N. There are three logging mechanisms that MDREst4i MDRFRAME provides for a REST Provider. Each option will causes MDRAPI create a log using the details in the relevant Log Name below: IFS - Creates a log file in the IFS DATAQ - Creates a log in a DATAQ. |
Log Name IFS | The format of these is as follows: /folder/subfolder/file-%F.txt The "%F" is substitute syntax handled by the MDRFRAME framework when creating the file. It is used to set date and time stamp values in the name. So the above example would look like this: /folder/subfolder/file-2024-02-11.txt for full detaisl on logging name options see LOGFILEOPTS |
Log Name DATAQ | Use format LIBNAME/DTAQNAME. This creates a DATAQ of the specified library/name, and writes log entries to it. |
Log Name PF | The format of these is LIBNAME/PFNAME. This makes a copy of MDRST/MDRLOGS into the LIBNAME/PFNAME specified, and logs requests there each time this Provider program is called |
Log Details | These values specify the content that will appear in the log |