Overview
Kalo API
The base URL of the Kalo API is https://api.kalohq.com/
, and exposes projects, tasks, invoices and freelancers at:
- https://api.kalohq.com/projects/
- https://api.kalohq.com/tasks/
- https://api.kalohq.com/freelancers/
- https://api.kalohq.com/invoices/
Creating Kalo Apps
In order to use the Kalo API, you’ll first need to create a Kalo app, going to the kalo app management page. You can think of a Kalo app as an integration point binto the Kalo platform.
A Kalo app allows you to define one or more Kalo app keys. Kalo apps and kalo apps keys can only be created by admin users, and keys will have admin rights on the team resources, so they should not be shared with others.
REST API
The Kalo API is a RESTful json API, and follows the json api specification.
Each request needs to be authenticated using the authentication key previously generated, using the X-Kalo-Api-Key
authentication header, which would look like this:
X-Kalo-Api-Key: ea4fa026c1874a4fb40d1c4880d97bb4
For write http requests you also need to pass the content type, so in that case the header would look like:
X-Kalo-Api-Key: ea4fa026c1874a4fb40d1c4880d97bb4
Content-Type: application/json
The general status codes you can expect from the API are the following:
-
200: ok
The request was successful. PATCH and GET requests will return 200 on success, with information about the fetched/patched objects in the response body.
-
201: created
Resource successfully created, only POST requests will return this status code.
-
400: bad request
Something wrong with the data passed in, for example missing required fields, mismatching field types and other similar issues. The response body in this case should help detecting what the issue is.
-
401: unauthorized
Most likely a wrong authentication key.
-
403: forbidden
The authentication succeeded but you are trying to access data you are not allowed to access with that key.
-
404: not found
The page does not exists or some of the resources that were trying to be accessed during the request do not exist in the database.
-
500: server error
Most likely a bug in the Kalo API code, or something wrong in the request which should actually return a 400 but it's not handled correctly. These gets all logged to our tracking system and we will have enough context to be able to reproduce the problem.
Request types
Allowed requests to the API can be split into these categories:
URL | Method | Operation |
---|---|---|
/$resource/$id/ |
GET |
Fetch a single resource |
/$resource/ |
GET |
Fetch all the resources (paginating the result) |
/$resource/$id/ |
PATCH |
Modify an existing resource |
/$resource/ |
POST |
Create a new resource |
Pagination
All the requests of the type GET /$resource/
are paginated,
which is a standard practice to avoid fetching too much data all at
once.
The current limit of resources fetched per call is currently 30
,
so it means that for example to fetch 100 resources you need to do
4 API calls, returning in order 30 + 30 + 30 + 10 == 100
resources.
Pagination is controlled by passing two query arguments:
page[offset]
: which indicates how many resources to skippage[limit]
: which indicates the number of resources to get (max 30 as mentioned above)
To see an example, assume we have 100 projects and we need to get all of them, the API calls will be something like:
GET /projects/
=> resources 0-30GET /projects/?page[offset]=30
=> resources 30-60GET /projects/?page[offset]=60
=> resources 60-90GET /projects/?page[offset]=90
=> resources 90-100
To help the client understanding when all the resources are fetched
each API response you will find two attributes total
and offset
.
{'meta': {'total': #tot-number-of-resources, 'offset': #offset-used}}
With this information an easy way to fetch all the available resources would be:
- keep track of the total from the first call.
- keep track of the number of resources already fetched.
- when the number of resources fetched
==
total, then all resources were fetched correctly.