In this exercise we will implement additional application business logic using Node.js. The module we are creating will also expose the data from the HANA database via an automatically generated OData service, which can easily be consumed in SAPUI5 user interfaces later on. The easy support of OData exposition comes with the XSJS library delivered with XS Advanced, which also provides compatibility means for the XS Classic programming model.
- Right-click on the CPL166MTA project and select "New" -> "Node.js module".
- Call it
cpl166js
- Check the "Enable XSJS support" checkbox. This is required to make use of the OData provisioning capabilities via the XSJS library.
The setup wizard creates the new Node.js module which contains a number of default folders and files, for example, the file `lib/index.xsjs` with simple "Hello World" code. It would be runnable already, but we will keep that for later after doing some real coding. The module is also automatically added to our application descriptor `mta.yaml`.
- In your workspace right-click on the
cpl166js/lib
folder and create a new file calledeuro.xsodata
. Using this suffix will enable the file to define OData services via declarative syntax. Add the following content to this file
service {
"CPL166MTA.cpl166db::european_countries" as "euro" keys generate local "ID";
}
- Then save the file.
This will define a service namedeuro.xsodata
with an entity calledeuro
, based on theeuropean_countries
Calculation View we have defined in exercise 1. The entityeuro
uses an auto-generated key calledID
. Before we can test the service, we have to define a dependency from the Node.js module to the database module. - Open the MTA editor by double-clicking on
mta.yaml
in the project root folder and select thecpl166js
module. - Go to the "Requires" section and add the dependencies to
cpl166db
andhdi-container
We will also review necessary parameters to expose the service.
5. Therefore go to the "Provides" section and check that `cpl166js_api` with a property called `url` and the value `${default-url}` is there, which is automatically generated in case XSJS support is enabled for the module.
6. Don't forget to save your changes. You may also review what happened in the mta.yaml using the text based editor now.
- Open the file
cpl166js/package.json
and update the version dependency for @sap/xsjs to version "1.14.1". Then save the file. - Right-click on the module
cpl166js
and choose "Run" -> "Run as Node.js Application" in the context menu. The command automatically builds the application, too. You can view the build/run progress in the run console at the bottom of the SAP Web IDE screen. - When the application has started successfully, you will see a link on top of the run console to navigate to it in the browser.
- Since we did not change the code in application start-up file
index.xsjs
, the Web browser still displays the text "Hello World". However, you can use a modified URL to test the OData service. Just replace the URL segment/index.xsjs
after the port number with/euro.xsodata/euro?$format=json
, which should result in an output like this
While OData supports create/modify/delete actions to tables, most applications use application logic to validate the input values first. We will do this by writing a JavaScript that receives inputs over a REST interface and writes the (validated) data into the database.
- Right-click the
cpl166js/lib/
folder, and create a new file with "New" -> "File". Entercountry/country.xsjs
. - Add the following JavaScript code to the file, and save it.
function saveCountry(country) {
var conn = $.hdb.getConnection();
var output = JSON.stringify(country);
var fnCreateCountry = conn.loadProcedure("CPL166MTA.cpl166db::createCountry");
var result = fnCreateCountry({IM_COUNTRY: country.name, IM_CONTINENT: country.partof});
conn.commit();
conn.close();
if (result && result.EX_ERROR != null) {
return result.EX_ERROR;
}
else { return output; }
}
var country = {
name: $.request.parameters.get("name"),
partof: $.request.parameters.get("continent")
};
// validate the inputs here!
var output = saveCountry(country);
$.response.contentType = "application/json";
$.response.setBody(output);
The code snippet reads the values of two "GET" parameters, "name" and "continent" respectively, passes them to a function that calls the SQLScript procedure createCountry, which is used to write these values to the 'country' table, and displays a confirmation message.
Note:
To keep things simple, we uses the HTTP GET method to access the service used to create database entries; productive applications should always use http update methods (for example, POST, PUT, or DELETE) to make changes or modifications to the database.
- Right-click on the module
cpl166js
and choose "Run" -> "Run as Node.js Application" in the context menu. The command automatically builds the application, too. - As before, you can click on the link which is displayed on top of the Run Console after successful build to start the application in a new browser tab.
- In your web browser, replace the URL element
/index.xsjs
with the string/country/country.xsjs?name=China&continent=Asia
. Add some more countries like
.../country.xsjs?name=Albania&continent=Europe
.../country.xsjs?name=Sweden&continent=Europe
The output should look like this (depending on the browser)
{
"name": "China"
"partof": "Asia"
}
{
"name": "Albania"
"partof": "Europe"
}
{
"name": "Sweden"
"partof": "Europe"
}
The built-in debugger in Web IDE enables you to perform standard debugging tasks, such as adding breakpoints to the code and starting, stepping through, and resuming code execution. You can also inspect variables and check the validity of expressions.
- In the previous step we already started the application. If you stopped it, do "Run" -> "Run as" -> "Node.js Application"
- Choose "View" -> "Debugger" in the tool bar or click on the bug symbol on the right pane, to display the built-in JavaScript debugging tools.
3. Choose (attach) in the debugger pane and select your running Node.js application in the dialog.
4. Set a breakpoint in `country.xsjs` at the line where saveCountry is called
5. Now use a new browser tab to insert a new country like ".../country.xsjs?name=Andorra&continent=Europe"
6. In the debug tool you can examine the call stack and see the value assigned to any variable in the function "saveCountry". If you want to modify variables in the context of the current breakpoint, you can use the Debug Console to type in any valid JavaScript statement, including variable assignments. Feel free to experiment with the debug controls.
7. Choose "Resume" to complete execution of the JavaScript
Continue with Exercise3