Skip to content

Latest commit

 

History

History
 
 

Exercise 02 - Creating a new CAP project

In this exercise you'll become familiar with the workflow of creating a new CAP project from the command line, and discover how quickly you can get to a basic OData service serving a simple metadata document.

One of the challenges of building a full stack app using OData has been the production of an OData service - the definition of the metadata and the creation of the backend components to service the OData operations.

With Core Data & Services (CDS) as the definition language and CAP as the framework providing out-of-the-box services that respond to OData requests, that challenge has disappeared. It's very easy to get a basic OData service up and running in only a few minutes. Being able to rapidly get to a working metadata document has various benefits which we'll discuss at the end of this exercise.

Steps

After completing these steps you'll be familiar with how you can use the cds command line tool to initialize a project with an OData service.

1. Initialize a new CAP project

Before you start creating a new project we recommend that you create a dedicated directory for this CodeJam within your home directory instead of any system directories (e.g. DO NOT work in C:\Windows\System32\).

For any new CAP based project you start by indirectly creating a directory containing various basic files. This can be achieved with the CDS command line tool cds which you installed in exercise 01.

The cds tool should be available in your executable path, having been installed globally as part of the Node.js @sap/cds-dk package.

user@host:~
=> cds

USAGE

    cds <command> [<args>]
    cds <src>  =  cds compile <src>
    cds        =  cds help

COMMANDS

    i | init       jump-start cds-based projects
    c | compile    process models selectively
    d | deploy     e.g. to databases or cloud
    s | serve      run servers locally
    w | watch      restart server on file changes
    m | import     add models from external sources
    r | repl       read-eval-event loop
    e | env        get/set cds configuration
    b | build      prepare for deployment
    v | version    get detailed version information
    ? | help       get detailed usage information

  Learn more about each with:
  cds help <command> or
  cds <command> ?

Note that with cds init a new project can be quickly initialized.

👉 Explore what options are available with cds init with the --help option:

user@host:~
=> cds init --help

👉 Use some of these options to initialize a new project directory called bookshop thus:

user@host:~
=> cds init bookshop --add hana,mta

You should see output that looks similar to this:

[cds] - creating new project in current folder
> applying template 'hana'...
> applying template 'mta'...
done.

Find samples on https://github.com/SAP-samples/cloud-cap-samples
Learn about next steps at https://cap.cloud.sap/docs/get-started

2. Open the project in VS Code

Now that the project has been initialized, it's time to explore it. The VS Code IDE is a comfortable environment in which to do so, so at this point you will open up the newly created bookshop directory in it.

👉 Open up the new bookshop directory in VS Code. One way to do this (if the installation of VS Code on your operating system put the binary in your executable path) is simply by invoking code on the command line, and specifying the directory to open:

user@host:~
=> code bookshop

If this approach is not available to you, simply start VS Code through your operating system's GUI and open the directory manually (with menu path "File → Open").

3. Explore the initialized project structure

The skeleton project that has been initialized is visible in VS Code. This is what it should look like.

initialized project in VS Code

👉 Examine what files have been populated in the project directory structure.

Briefly, the directories and contents can be described thus:

Directory or File Description
.vscode/ VS Code specific files for launch configurations (useful for debugging, which we will cover in exercise 08). This directory may or may not be visible in VS Code, depending on version and settings.
app/ Where any UI components live, in case you're building and serving a full stack app.
db/ Where the data models (in CDS) are specified.
srv/ Where the service definitions (in CDS) are specified.
.eslintrc Configuration for linting of the JavaScript with ESLint.
.gitignore Specification of what content should be ignored when using git for source code control, specifically for CAP-based projects.
mta.yaml This is the central descriptor file for the project. It defines all modules (microservices) and backing services (like databases). This information will be used to build the .mtar archive during design time and to deploy & provision the apps and services during deploy time.
package.json The standard package descriptor file for Node.js based (NPM) packages and projects.
README.md A small 'Getting Started' guide for this project.

4. Create a simple data model and service definition

👉 Create a new file called schema.cds in the db/ directory of the recently created project, copy the following lines to the file and save it:

namespace my.bookshop;

entity Books {
  key ID : Integer;
  title  : String;
  stock  : Integer;
}

You may wish to use VS Code's "auto save" feature, then again you may not. Just in case you do, you can turn it on via the File -> Auto Save menu option.

👉 Create a new file called service.cds in the srv/ directory of the recently created project, copy the following lines to the file and save it:

using my.bookshop as my from '../db/schema';

service CatalogService {
    entity Books as projection on my.Books;
}

You have now created a simple data model as well as a service definition for your project.

5. Examine the data model and service definition

The key files in this project as far as the business domain is concerned are the db/schema.cds and the srv/service.cds files that you just added.

👉 Have a brief look at the content of each of these files to get a basic understanding of what's there. Note the use of the namespace and how it is defined in the data model and referenced in the service definition. Note also the how the different parts of each file are syntax highlighted.

6. Install the dependencies

The package.json file that was created when you initialized the project directory contains a list of NPM packages upon which the project is dependent. Before we can start the service up, these dependencies must be installed. Now is a good time to do that.

VS Code has an integrated terminal which you can and should use for this and subsequent command line activities.

👉 Open the integrated terminal in VS Code. Do this by opening the Command Palette and searching for 'integrated terminal'. You may wish to use the keyboard shortcut for this - note there is a keyboard shortcut for toggling the integrated terminal in and out of view as well.

the integrated terminal options in the Command Palette

This should open up the terminal at the bottom of VS Code like this:

integrated terminal in view

Windows users: Please make sure to select cmd as your default shell before you continue: default shell

👉 In the integrated terminal, making sure first that you're in the project directory itself (where package.json is to be found), install the dependencies like this:

user@host:~/bookshop
=> npm install

You should see output that ends something like this:

npm notice created a lockfile as package-lock.json. You should commit this file.
added 129 packages from 181 contributors and audited 258 packages in 4.762s
found 0 vulnerabilities

Great. Now your fledgling service can already be started up!

7. Start up the service

👉 In the same integrated terminal, use the following command to start up the service:

user@host:~/bookshop
=> npm start

You should see output similar to this:

> bookshop@1.0.0 start /tmp/codejam/bookshop
> npx cds run

[cds] - connect to datasource - hana:undefined
[cds] - serving CatalogService at /catalog
[cds] - service definitions loaded from:

  srv/service.cds
  db/schema.cds

[cds] - launched in: 583.297ms
[cds] - server listening on http://localhost:4004 ...
[ terminate with ^C ]

The OData service is now running, and available via http://localhost:4004.

8. Explore the OData service

While we have no data in the OData service (we don't even have a persistence layer yet!) we can ask the OData service for the two well-known documents: the service document and the metadata document.

👉 Open http://localhost:4004 in your browser, to see something like this:

basic OData service

The catalog link will take you to the service document and the $metadata link will take you to the metadata document.

👉 Explore the metadata document and familiarize yourself with the content. Note the entityset definition and the entity type describing the Books entity.

👉 There is also a link to the Books entityset. Follow this link to see what the service returns. Check what happens to the Node.js cds process when you try to access the entityset.

Summary

With a single command, you've initialized a basic OData service project and with another command you've started it up and explored the metadata.

Questions

  1. Why is there a focus on "Contracts First" (As all you need to run a service is a service definition) - what advantages does that bring?
  1. What is the difference between the data model and the service definition? Why do we need both?
  1. What is returned in response to a request for the Books entityset resource right now?
  1. What happened to the cds process when you accessed the entityset? Can you think of reasons why this happened?
  1. What actually happens when you run npm start, and why?