In this developer journey, we demonstrate how to access and interact with VSAM datasets using Node.js on z/OS. We will use the popular Node.js web application framework, Express, to create a web server application to build service endpoints to query and manipulate VSAM datasets and records.
The backend Node.js application communicates with VSAM datasets on the z/OS and provides APIs to query and manage the VSAM file and records.
- Create a Node.js web application with Express framework.
- Create routes for the web server.
- Create controller function and develop the logic to interact with VSAM datasets and records on z/OS.
- Test the newly created APIs.
- Node.js - An asynchronous event driven JavaScript runtime, designed to build scalable applications
- Express - A popular Node.js web application framework
- npm - package manager for the JavaScript programming language included with Node.js installation
Node.js - Node.js is the server-side JavaScript platform. To install Node.js on z/OS, see IBM SDK for Node.js on z/OS. Please note, you can get a free trial version of Node.js on z/OS for testing at free 90-day trial (SMP/E format) with installations instructions here or at IBM SDK for Node.js - z/OS trial (pax format) (downloads and instructions). Please follow the installation instructions provided, in particular for the pax format trial version. Make sure you install the C/C++ compiler, as described in the documentation, as it is needed for this exercise.
Verify installation with:
node --version
Git - Git is a distributed version control system. You can get git for z/OS from Rocket Software..
cURL - cURL is command line tool for transfer data in different protocols. To run it on z/OS, you can get cURL for z/OS from Rocket Software..
VSAM - Virtual Storage Access Method (VSAM) is a file storage access method used in MVS, z/OS and OS/390 operating systems. Please make sure you have privileges to create and access VSAM datasets.
In this section, we provide step-by-step instructions to create and run a Node.js application that interacts with VSAM datasets on z/OS. In our example, we use Key Sequence Data Set (KSDS) VSAM data set. The application allows you to create and delete VSAM files, and then manipulate VSAM records via CRUD functionality to create, read, delete and update records.
The section is divided into two parts:
-
Part A guides you in deploying, running and testing a Node.js VSAM application on z/OS. Upon completion, you will have a running application that provides basic capabilities to fully interact with VSAM datasets.
-
Part B guides you in creating your own Node.js application that communicates with VSAM datasets. Upon completion, you will have the basic understanding of Express framework and the knowledge to access and manipulate VSAM datasets from Node.js application using the vsam.js npm module.
This part guides you through the steps to clone the git repository and deploy the Node.js vsam application on z/OS, run the application and test it.
To clone the repository on z/OS run the following:
git clone git://github.com/irisbaron/vsam-express-demo
Alternatively, download the developer journey code as a zip file. On z/OS, use unzip -a
to unzip.
In the developer journey code directory, execute the following commands to install the Node.js module dependencies using npm, and launch the application.
cd vsam-express-demo
npm install # Install the Node.js module and its depdencies
node server.js # Launch the Node.js application
The STDOUT output will be:
Server is up for VSAM application
Server is listening on port 3000
Use the cURL command from the command-line in a separate shell/terminal, ether locally or remotely. Make sure to replace the dataset name, USER.TEST.VSAM.KSDS, with a customized one that matches your environment.
If you are launching the cURL commands remotely, update localhost
in the examples below to match the hostname of your target machine hosting the Node.js application. The cURL command will print out the http response.
In a browser you can use http://localhost:3000/vsam/records/USER.TEST.VSAM.KSDS to see the records in the dataset and followup with the changes as you do the testing exercises below.
Create VSAM file:
curl -X POST "http://localhost:3000/vsam/USER.TEST.VSAM.KSDS"
Create a VSAM record:
curl -X POST "http://localhost:3000/vsam/record/USER.TEST.VSAM.KSDS&123&James&MALE"
Read a VSAM record:
curl -X GET "http://localhost:3000/vsam/record/USER.TEST.VSAM.KSDS"
Read all VSAM records:
curl -X GET "http://localhost:3000/vsam/records/USER.TEST.VSAM.KSDS"
Update a VSAM record:
curl -X PUT "http://localhost:3000/vsam/record/USER.TEST.VSAM.KSDS&123&IRIS&FEMALE"
Delete a vsam record:
curl -X DELETE "http://localhost:3000/vsam/record/USER.TEST.VSAM.KSDS&123"
Delete Vsam file:
curl -X DELETE "http://localhost:3000/vsam/USER.TEST.VSAM.KSDS"
This part guides you through the following steps to create your own vsam application on z/OS:
- Create an Express Project
- Set up a Web Server
- Define Routes
- Write the Controller Functions
- Add Application Logic
- Test your applicaiton
We start by creating a Node.js empty project:
mkdir vsam-express-demo
cd vsam-express-demo
npm init
The ‘npm init’ will create and populate the package.json with the definition for the project. Press Enter to confirm the questions. Next we create dependencies using npm. Next we install the dependencies for our project, including Express and VSAM.js.
npm install express vsam.js chai async --save
As a result, node_modules directory will be populated with the required dependencies, e.g. the vsam.js directory is created and populated.
In the root folder, the vsam-express-demo, create a new file, server.js, and populate it with the information below. This will be the main entry point of our application.
var express = require('express');
// create express app
var app = express();
console.log("Server is up for VSAM application");
// define a simple route
app.get('/', function(req, res){
res.json({"message": "Welcome to VSAM application."});
});
// listen for requests
app.listen(3000, function(){
console.log("Server is listening on port 3000");
});
The code, starts an express application, which is a web server framework. We then defined a GET route which returns a welcome message, and lastly, set up the server to listen to port 3000.
We now create the routes for the VSAM application, that is the URL handling code. In the root folder, create a new file called routes.js with the following contents:
module.exports = function(app) {
var vsam_controller = require('./controller.js');
// Create a new VSAM file
app.post('/vsam/:path', vsam_controller.createFile);
// Delete a VSAM file
app.delete('/vsam/:path', vsam_controller.deleteFile);
// Create a new VSAM record
app.post('/vsam/record/:path&:key&:name&:gender', vsam_controller.createRecord);
// Read a single VSAM record
app.get('/vsam/record/:path', vsam_controller.readRecord);
// Update a VSAM record
app.put('/vsam/record/:path&:key&:name&:gender', vsam_controller.updateRecord);
// Delete a VSAM record
app.delete('/vsam/record/:path&:key', vsam_controller.deleteRecord);
// Read all VSAM records
app.get('/vsam/records/:path', vsam_controller.readAllRecords);
}
This declares the handler functions for all the resource endpoints we need for our application. For each route, it specifies the HTTP form (GET, POST, PUT and DELETE) and the method handler. The code contains a require statement for controller.js file, which we define the next section.
In order to use the routes in the application, we need to include the routes.js file in server.js. For this open the server.js file and add the following require statement before app.listen() line.
// ........
// Require VSAM routes
require('./routes.js')(app);
// ........
The controller will contain methods for handling all the CRUD operations for our application.
In the root directory, create a new file called controller.js with the following contents:
const vsam = require('vsam.js');
const async = require('async');
const fs = require('fs');
const expect = require('chai').expect;
const assert = require('chai').assert;
const obj = JSON.parse(fs.readFileSync('test.json'));
const tableify = require('html-tableify');
exports.createFile = function(req, res) {
//create a vsam file
};
exports.deleteFile = function(req, res) {
// Delete a vsam file
};
exports.createRecord = function(req, res) {
//create a vsam record (and the vsam file if not yet created.
};
exports.readRecord = function(req, res) {
//read a vsam record
};
exports.readAllRecords = function(req, res) {
// reads all records from a vsam file
};
exports.updateRecord = function(req, res) {
//update a record in a vsam file
};
exports.deleteRecord = function(req, res) {
// delete a record from a vsam file
};
In our example we used the test.json
file definition, to specify the record object configuration.
We are now ready to add the logic.
Code is available in the controller.js
file. Clone or download the github code, and copy over the controller.js
file.
Run the application
node server.js
And follow the steps in section Test the Application.