How to create a REST API
Introduction
In this Velosimo Tutorial, we will create a basic REST API using the Velosimo Platform. The API will be able to create a new record and retrieve all records from a Velosimo database. We will create a Data Base, create a new API, and then test our new API using Postman.
Prerequisites and assumptions:
- Access to your Velosimo tenant and your Tenant Authorization Key and Token values.
- An account with Postman..
Global instructions
- Replace HIGHLIGHTED CAPITALIZED text with your specific information.
- The overlay menu is considered the main menu and is the launching point of many steps. It is accessed by clicking the Caret after the velosimo logo on the top left of the user interface.
data:image/s3,"s3://crabby-images/f83f5/f83f5f3228b5eb407bb663706b466ef7c9d46435" alt="Create API 1.png 334"
Table of Contents
Creating a Data Base
First, we need to create a database which is known as Data Type within Velosimo. The terms Database and Data Type are used interchangeably. The Data Type is a Definition of the data fields and types for our new JSON database within Velosimo.
Select Definitions under the Data section of the main menu:
data:image/s3,"s3://crabby-images/83fe6/83fe62abf542263bc4ed203c45441f02f4ebc72c" alt="Create API 2.png 386"
Next, click the Kebab icon next to "Json Types" and select "+ Add New."
data:image/s3,"s3://crabby-images/c9007/c90073a6558b7c73922f54876bdf1361b7b2c022" alt="Create API 3.png 1044"
Enter the details of your new Data Type and click Save.
data:image/s3,"s3://crabby-images/e8fa4/e8fa487a57bc843617b4339224c49219075593db" alt="Create API 4.png 1167"
Form Field | Description | Content |
---|---|---|
Namespace* | Unique name which is used for all components of your new API | [YOUR NAME]_api |
Name* | Name for your new Database/Data Type | [YOUR NAME]_api_records |
Schema | Field names and types. The JSON schema for the data structure. | See code below |
*Your Name Space and Data Type Names will be used later in this exercise
{
"type": "object",
"properties": {
"name": {
"type": "string"
},
"createdAt": {
"type": "string"
},
"data": {
"type": "string"
}
}
}
If the creation were successful, you would be redirected to the JSON Data Types listing page, where you will see your newly-created data type.
data:image/s3,"s3://crabby-images/d1ed4/d1ed45efe0eaef14f9f58b2e6ab455dbab086882" alt="Create API 5.png 1587"
Now that we have a database to use, it's time to create the API app, which will interact with the database. In Velosimo, APIs are a type of application.
Creating the API
Select Applications under the Compute section of the main menu:
data:image/s3,"s3://crabby-images/8860a/8860a5313160afed56ab889ec1728c96775b4a4c" alt="Create API - create 1.png 686"
You will be redirected to the Applications list page. Select "+ Add new" on the top menu of the page.
data:image/s3,"s3://crabby-images/b9324/b9324e2891ccf178456163a0b963b1922315d053" alt="Create API - create 2.png 1126"
Enter the initial values of your new Application, but do not hit save yet
data:image/s3,"s3://crabby-images/24c6f/24c6f418a134a16cc8d48ab479553c51025b64c5" alt="Create API - create 3.png 364"
Form Field | Description | Content |
---|---|---|
Namespace | Unique name which is used for all components of your new API | Enter your namespace from prior |
Name | Name for your new API Application | [YOUR NAME]_api_application |
Next we need to create Actions for the app. Actions in Velosimo are the API endpoints for an Application, the API calls. Each Action has an endpoint that executes a block of code when called.
For this tutorial, we will be creating two actions:
- POST / Create a new entry in the database
- GET / Retrieve all records from the database
P ST /Create a Record
The first action that will be created will be the action we call when we want to create a new record in our database (data type).
Click "+ Add new Action"
data:image/s3,"s3://crabby-images/b4c52/b4c5227eb888299db9019c5f7f3614a261909c6c" alt="Create API - create 4.png 376"
Enter the values for your new post action:
data:image/s3,"s3://crabby-images/de124/de124062ecb4a2943f7b8ab68b5f278bf9aa4174" alt="Create API - create 5.png 414"
Form Field | Description | Content |
---|---|---|
Method | The REST method to use for this action. We chose POST because we want to add a new record to the database when this action is called | Post |
Path* | The path for your new application used when calling this action. | [YOUR NAME]_api_create_record |
*Your POST Action path name will be used later in this exercise
Now we need to create the functionality for the Post Action by creating an algorithm. Algorithms are snippets of code that perform a specific function when executed.
Click "+ Add new Algorithm".
data:image/s3,"s3://crabby-images/7488a/7488a595da0b281747aa559f418cc14c0c01a956" alt="Create API - create 6.png 828"
Enter the values for your new algorithm:
data:image/s3,"s3://crabby-images/9144f/9144f45ddf24977cfc51facdd4aaf68cc233a18e" alt="Create API - create 7.png 355"
Form Field | Description | Content |
---|---|---|
Namepsace | Unique name which is used for all components of your new API | Enter your namespace from prior |
Name | Name for your new post algorithm | [YOUR NAME]_api_create_record |
Next we need to add a few parameters to the algorithm:
- controller - variable used to create JSON from data in the Ruby code.
- params - variable used to retrieve data passed through body params in the POST request.
Click "+ Add new Algorithm parameter.
data:image/s3,"s3://crabby-images/0dac9/0dac9a71e20f677236646577456f2b1d3bf65e69" alt="Create API - create 8.png 333"
Enter the name for your new algorithm parameter:
data:image/s3,"s3://crabby-images/07a11/07a11eb0ceb3bc38adda74894b7488dcd429b982" alt="Create API - create 9.png 325"
Form Field | Description | Content |
---|---|---|
Name | Name for your new algorithm parameter | controller |
Now let's add the second parameter. Click "+ Add new Algorithm parameter again.
data:image/s3,"s3://crabby-images/a64e8/a64e841cce41cca138649e52fa504514a96c1e14" alt="Create API - create 10.png 912"
Enter the name for your new algorithm parameter:
data:image/s3,"s3://crabby-images/3fd68/3fd680eb745fc1df711e8463374996fb2d1cee63" alt="Create API - create 11.png 317"
Form Field | Description | Content |
---|---|---|
Name | Name for your new algorithm parameter | params |
The final step is to create the block of code that executes when the Action/Algorithm is called. For this tutorial, we want to create an algorithm that receives the POST body data through params and converts it to a JSON object which can be used to create a new record in our data type.
Enter language type and code, then click save.
data:image/s3,"s3://crabby-images/56078/56078731e8587b05bbfe202b10de0c4774416542" alt="Create API - create 12.png 1015"
Form Field | Description | Content |
---|---|---|
Language | Your code language | Ruby |
Code | The code that executes when the Action/Algorithm is called. | See code below. Replace the CAPILAIZED text YOUR-NAME-SPACE and YOUR-DATA-TYPE with your values |
httpMethod = controller.action.http_method.to_s
Tenant.notify(message: "Params #{params}", type: :info)
dataLog = {}
dataLog["name"] = params["name"]
dataLog["createdAt"] = params["createdAt"]
dataLog["data"] = params["data"]
Tenant.notify(message: "DataLog #{dataLog}", type: :info)
recordDT = Cenit.namespace("YOUR-NAME-SPACE").data_type("YOUR-DATA-TYPE")
recordDT.create_from_json!(dataLog)
controller.controller.headers["Content-Type"] = "application/json"
You will be redirected back to your new application page, where you will see your newly created algorithm has been auto-selected for this action.
data:image/s3,"s3://crabby-images/21401/21401cf5197bf0c0dd0fe8fd61a38a8919570419" alt="Create API - create 13.png 447"
Now we have an Action that can create a new record entry from data passed in through Postman. The next step is to create an algorithm that will retrieve our record entries from the data type.
GET / Get All Records
Our next action that will be created will be the action we call when we want to retrieve all records from our database (data type). Click "+ Add new Action"
data:image/s3,"s3://crabby-images/496b2/496b294383b1d4cb988593c16934a5ff33e222a0" alt="Create API - create 14.png 772"
Enter the values for your new get action:
data:image/s3,"s3://crabby-images/d9e25/d9e25055a398d29dd7a2e3a5f90d68b597f5828e" alt="Create API - create 15.png 346"
Form Field | Description | Content |
---|---|---|
Method | The REST method to use for this action. We select GET because we want to add a new record to the database when calling this action. | get |
Path* | Name for your new get algorithm | [YOUR NAME]_api_get_records |
*Your GET action path will be used later in this exercise
Now we need to create the functionality for the Action by creating an algorithm. Algorithms are snippets of code that perform a specific function when executed. Click "+ Add new Algorithm".
data:image/s3,"s3://crabby-images/b1639/b1639c104a873aa9fa2d776b7b52e6623f735245" alt="Create API - create 16.png 828"
Enter the values for your new algorithm:
data:image/s3,"s3://crabby-images/8977a/8977a57e4e31511bebfd48acdc7de1fa592d5e21" alt="Create API - create 17.png 738"
Form Field | Description | Content |
---|---|---|
Namespace | Unique name which is used for all components of your new API | copy from prior steps |
Name* | Name for your new algorith | [YOUR NAME]_api__getrecords |
Add the controller Algorithm parameter to this Algorithm as well. Click "+ Add new Algorithm parameter.
data:image/s3,"s3://crabby-images/3b910/3b910c126791b4a20e4081800a8d973057437fa4" alt="Create API - create 18.png 328"
Enter the name for your new algorithm parameter:
data:image/s3,"s3://crabby-images/dd62d/dd62dadfb6105e54f7c291e516a5eb531e53b813" alt="Create API - create 19.png 323"
Form Field | Description | Content |
---|---|---|
Name | Name for your new algorithm parameter | controller |
Add the controller Params parameter to this Algorithm as well. Click "+ Add new Algorithm parameter".
data:image/s3,"s3://crabby-images/b92e1/b92e14cb133f5a8fb55711e4343e2519f95baa08" alt="Create API - create 20.png 298"
Enter the name for your new algorithm parameter:
data:image/s3,"s3://crabby-images/08fd3/08fd3a13457b3f948adacbecbec8bc42fa0fcefa" alt="Create API - create 21.png 294"
Form Field | Description | Content |
---|---|---|
Name | Name for your new algorithm parameter | params |
Next, let's add the code to retrieve records from the ou data type and convert the entries to a JSON object. Enter your Ruby Code and then click "Save."
data:image/s3,"s3://crabby-images/82faa/82faa3b7fc677bb526ef1619df39903f26b8bd0d" alt="Create API - create 22.png 263"
Form Field | Description | Content |
---|---|---|
Language | Your code language | Ruby |
Code | The code that executes when the Action/Algorithm is called. | See code below. Replace the CAPILAIZED text YOUR-NAME-SPACE and YOUR-DATA-TYPE with your values |
httpMethod = controller.action.http_method.to_s
recordDT = Cenit.namespace("YOUR-NAME-SPACE").data_type("YOUR-DATA-TYPE")
records = recordsDT.all
recordLogs = {}
recordLogs["status"] = "success"
recordLogs["messages"] = records
controller.controller.headers["Content-Type"] = "application/json"
recordLogs.to_json
Now that the Actions have been created, we can save our new API Application.
data:image/s3,"s3://crabby-images/b6722/b6722d08e67f00b68079e80c1a6644dc22c9c0f5" alt="Create API - create 23.png 644"
You will be redirected to your application list page, which will now show your new API application listed and a message confirming the application was created successfully.
data:image/s3,"s3://crabby-images/ca213/ca213b9bef0b1e46de0d1686ac0a81c89855892d" alt="Create API - create 24.png 830"
Next, we will add authentication, register our new app, and then test the endpoints on Postman. Select the Kabab menu on your application row and then click "Configure."
data:image/s3,"s3://crabby-images/eef2b/eef2beecbf66a09c2ab530086b659f88397296a3" alt="Create API - create 25.png 416"
To use your application, you must provide some form of Authentication. In Velosimo, there are two to choose from:
- User Credentials: Requires Tenant Authorization Key and Token to use app URL
- Application ID: Only requires the app slug name to be passed to the URL
We will use User Credentials for this tutorial because it is a more secure practice. Select "User Credentials" from the Authentication Method drop-down, then click the "Configure" button (which saves your changes).
data:image/s3,"s3://crabby-images/5be57/5be57cf8bf2f5bd575a2e5947ac0439c2d3624f1" alt="Create API - create 26.png 763"
Now we need to Register the app and set its slug/URL. Registering your app is a requirement for external use outside Velosimo. Select the Kabab menu on your application row and then click "Regist."
data:image/s3,"s3://crabby-images/f36eb/f36eb9032f90f2c6e6f8ebc5ecb3e5e2e3d367fd" alt="Create API - create 27.png 816"
Create a slug name for the app, enter the same name for the Oauth name input, and then click the Regist button (save).
data:image/s3,"s3://crabby-images/6b865/6b8654481dd121b5018ce2a120b667f6247bb2c6" alt="Create API - create 28.png 481"
Form Field | Description | Content |
---|---|---|
Slug* | Name used to call the app and its endpoints | [YOUR NAME]apidemo |
Oauth Name* | Same as above |
*The content entered for these values cannot include spaces
Using the API
Now that our new API application is registered, we can test our application post and get actions (test our new endpoints) using Postman.
Please obtain your Tenant Authorization Key and Token from Velosimo.
First, log in to Postman, navigate to your workspace and click "Create new collection."
data:image/s3,"s3://crabby-images/14318/143184bd2196a7009539fccfd6fd231316fcbc7d" alt="Create API - using 1.png 448"
Name your new workspace the same as your Velosimo Namespace in this tutorial.
data:image/s3,"s3://crabby-images/ec5e9/ec5e9ccf40e517b3e5f27a5ee319282705b34de5" alt="Create API - using 2.png 1335"
Next, click the Caret and then select the "Add a request "link
data:image/s3,"s3://crabby-images/92c3f/92c3f7265e4c0637654d3e01cf521b3520e5b2e5" alt="Create API - using 3.png 1327"
Next select "Post" from the drop-down
data:image/s3,"s3://crabby-images/5abf0/5abf075e10d3af5fa6769d629c6a51df0cca7cc8" alt="Create API - using 4.png 474"
Set the name of your new Postman POST request to “velosimo_api_create_record” and then click the "Headers" link.
data:image/s3,"s3://crabby-images/d8208/d8208a064777271aa924c3e062466ed0a0eb0489" alt="Create API - using 5.png 468"
Add two entries or rows (Key/Value pairs) - the Access key and Token authentication values to access your new Velosimo API application.
data:image/s3,"s3://crabby-images/28e31/28e31a67b4692018a6fc2d6ed284d3d9cff051dc" alt="Create API - using 6.png 1110"
ROW | KEY | VALUE |
---|---|---|
1 | X-User-Access-Key | YOUR-ACCESS-KEY |
2 | X-User-Access-Token | YOUR-ACCESS-TOKEN |
Next, click "Body."
data:image/s3,"s3://crabby-images/b51d2/b51d230c9d10e277d4950f338ed2530dd79ab143" alt="Create API - using 7.png 1120"
Next, click "raw," and then click "Text" and select "JSON."
data:image/s3,"s3://crabby-images/1dfd6/1dfd64e774a8117615142efdc764846270fddcfb" alt="Create API - using 8.png 1124"
Next, create a JSON data object based on the schema of the data type you made.
data:image/s3,"s3://crabby-images/59928/599287bfede5fbb186444f3ddadb5e56afc245fc" alt="Create API - using 9.png 1119"
{
"name": "YOUR-NAME API Demo Record",
"createdAt": "10/24/2022 9:00 AM",
"data": [
{
"name": "success",
"value": "Create Record was successful!",
"type": "string"
},
{
"name": "success",
"value": "You have successfully created a working POST request with Velosimo",
"type": "string"
}
]
}
Next, enter the request URL and click "Save."
data:image/s3,"s3://crabby-images/19c4d/19c4d59f76c3b3cdd3d23c3b597a4af5ac675ce0" alt="Create API - using 10.png 1107"
Form Field | Description | Content |
---|---|---|
Request URL | https:/dev.velosimo.io/app/ | YOUR-APP-SLUG/YOUR-POST-ACTION-PATH_api |
Now it's time to send our test post request to send and create a new record in our Velosimo Database with the use of Postman.
Click "Send"
data:image/s3,"s3://crabby-images/0602e/0602ef1de8f4470347bf15ddf252a8e9281125ce" alt="Create API - using 11.png 1460"
If successful, you will see "application/Json" at the bottom of the screen
data:image/s3,"s3://crabby-images/8540c/8540ce63d661726c5fbc6dea76f71c0c07d4feae" alt="Create API - using 12a.png 1436"
Let's look in our database and confirm the API worked and a record was created. Head back to Velosimo and select Definitions under the Data section of the main menu:
data:image/s3,"s3://crabby-images/b4008/b4008fb7388db45bc7dce2aad237b65391390b51" alt="Create API - using 12.png 386"
Next, click the Kebab icon next to "Json Types" and select "List."
data:image/s3,"s3://crabby-images/592ad/592adc7ab4d5d3e89303df13ada4a7b0eee52f2d" alt="Create API - using 13.png 799"
Select the Kabab menu on your Data Type (Data Base) row and then click "Records."
data:image/s3,"s3://crabby-images/fe7cc/fe7cc08ba4cb424f64c3099c57bf4f334dd2e66b" alt="Create API - using 14.png 820"
Here you will see the list of records in your database.
data:image/s3,"s3://crabby-images/3ec7d/3ec7d4c43e5be665f09a04c4fa27ba46fd3eb618" alt="Create API - using 15.png 1093"
Select the Kabab menu on your new record to see the details and click "Show."
data:image/s3,"s3://crabby-images/8c8ea/8c8ead103a7b51a2a9e8f7e35d96daabe46e6ad6" alt="Create API - using 16.png 1090"
Now that we've successfully created a new record with our POST action request, let's test out the GET request that will retrieve all rows from the database.
Go back to Postman, select the Kabab menu on your collection, and click "Add request." Note that it will default to a "GET" request, so we do not need to set that value.
data:image/s3,"s3://crabby-images/ea145/ea145fb88717f1d4d6571491cd105138ecb54351" alt="Create API - using 17.png 985"
Set the name and request URL
data:image/s3,"s3://crabby-images/29b15/29b159bb2f4d2ca6aa0a683fb299ebf5258fa3b8" alt="Create API - using 18.png 1006"
Form Field | Description | Content |
---|---|---|
Request Name | Request Name in Postman | velosimo_api_get_records |
Request URL | URL to submit a get request to your new API application | https:/dev.velosimo.io/app/YOUR-APP-SLUG/YOUR-POST-ACTION-PATH_api |
Click "Headers" and add two entries or rows (Key/Value pairs) - the Access key and Token authentication values to access your new Velosimo API application. These entries are identical to those entered for the POST request in Postman prior.
data:image/s3,"s3://crabby-images/9182f/9182fc2d093bf1e1396f820243be7d8378ec871d" alt="Create API - using 19.png 849"
Click "Save," then "Send."
data:image/s3,"s3://crabby-images/a3245/a32452e2ffe314e33e8f117a9f7d065f44b0cab7" alt="Create API - using 20.png 1159"
data:image/s3,"s3://crabby-images/66a4b/66a4ba6d6ae8ceddab9cc3f08678bc42c56dd687" alt="Create API - using 21.png 1183"
Congratulations! You have successfully created and tested a new API Application with get and post actions and a Velosimo Database.
Updated over 2 years ago