Use the Custom Entity API
Requirements:
- Follow the Create a Custom Entity guide first
Goals:
- Create an API Key
- GET: List all the tasks
- POST: Create a task
- GET: Get a specific task
- PUT: Update a task
- DELETE: Delete a task
- View the API Key Logs
Steps
💿 Go to the /app/acme-corp-1/settings/api/keys/new
to create an API Key with /tasks permissions.
data:image/s3,"s3://crabby-images/e6446/e644657577c5a966c5c87628f2955578d8f93034" alt="Created API Key"
💿 Install Thunder Client for VS Code.
💿 Create a GET request with the following values:
- Method: GET
- URL: http://localhost:3000/api/tasks
- Headers: add the "X-API-Key" header with your API Key (click on Copy to clipboard)
💿 Click Send.
You should get all the tasks in JSON format:
data:image/s3,"s3://crabby-images/38c76/38c76dc0c6505946f1f56fd9a16404acd3f6bc62" alt="GET - List all tasks"
💿 Before making a POST request to create a task, go to /app/acme-corp-1/projects
, click on Edit on any project row and copy the ID from the URL.
It should look something like this: cl3me5utq3138gohsoss1mqyv
.
💿 Create a POST request with the following values:
- Method: POST
- URL: http://localhost:3000/api/tasks
- Headers: set the "X-API-Key" header
Set the following JSON values:
{
"project": "cl3tlewvp2739e7hsz7apld93",
"order": 2,
"name": "Task 2",
"dueDate": "2022-12-31",
"priority": "High",
"completed": false,
"attachments[]": [
{
"name": "My image.png",
"type": "image/png",
"title": "My image",
"file": "https://via.placeholder.com/1000x500.png?text=My%20image"
}
],
}
You should get a 201 - Created response.
data:image/s3,"s3://crabby-images/48e85/48e852465438da6dd1d748a1d5153e87f2fbf190" alt="POST - Create task"
💿 Grab de ID, and make a GET request:
- Method: GET
- URL: http://localhost:3000/api/tasks/cl3tlv1yc8446e7hsn07ac3gd
- Headers: set the "X-API-Key" header
data:image/s3,"s3://crabby-images/16bbb/16bbbcaa2f6be038f5349ffcbe73731a67aaf11a" alt="PUT - Get task"
💿 Now, let's update the Task with a PUT request.
- Method: PUT
- URL: http://localhost:3000/api/tasks/cl3tlv1yc8446e7hsn07ac3gd
- Headers: set the "X-API-Key" header
JSON body:
{
"name": "New task name"
}
data:image/s3,"s3://crabby-images/dfd07/dfd07603d30f430e438fe3ecc89ff25a5f711864" alt="PUT - Update task"
💿 Delete the Task:
- Method: PUT
- URL: http://localhost:3000/api/tasks/cl3tm7c9012472e7hs7n476m9x
- Headers: set the "X-API-Key" header
data:image/s3,"s3://crabby-images/f3320/f3320643323c558d9e1bff62d7cffeb59f340eef" alt="DELETE - Delete task"
💿 Finally, view the API Key logs
.
data:image/s3,"s3://crabby-images/2c9f3/2c9f37edf06be0f6a399684cebdf89b2cd90ae49" alt="API Key Logs"
I hope this quick guide was useful! Let me know if you have any question.