Line 34: Line 34:
 
|-
 
|-
 
! http verb !! Request !! Response!!Description
 
! http verb !! Request !! Response!!Description
 +
|-
 +
| GET
 +
|| /api/starlings
 +
|| returns all the starlings registered for the given user
 +
|| validates the user and returns any starlings registered in JSON
 +
|-
 +
| GET
 +
|| /api/starling/{id}
 +
|| returns a particular starling
 +
|| validates the user and returns the given starling data as JSON
 +
|-
 +
| PUT
 +
|| /api/starling/{id}
 +
|| edits a particular starling
 +
|| the parameter need to send as form or url encoded data
 +
|-
 +
| DEL
 +
|| /api/starling/{id}
 +
|| deletes the starling with the given ID
 +
|| use with caution
 
|-
 
|-
 
| POST
 
| POST
|| /api/authenticate
+
|| /api/starling
|| token
+
|| pass the parameters in the form body
||Pass email and password as body parameter to obtain a web token
+
|| Creates a new starling after validating the data
 
|}
 
|}
  
 
=Messaging=
 
=Messaging=

Revision as of 17:49, 31 December 2015

Authentication

Starling API works on javascript web-tokens. The default validity for the tokens is 1 year. It will be changed to shorter duration soon.

Base URL for all requests: http://starling.exploreembedded.com

Obtaining the token

http verb Request Response Description
POST /api/authenticate token Pass email and password as body parameter to obtain a web token

Example with CURL

  • Request
curl -X POST -F "[email protected]" -F "password=password" \ 
'http://starling.exploreembedded.com/api/authenticate'
  • Response
{"token":"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXUyJ9.eyJzdWIiOiIyIiwiaXNzIjoiaHR0c
DpcL1wvc3RhcmxpbmcuZXhwbG9yZWVtYmVkasdfdsfNvbVwvYXBpXC9hdXRoZW50.
iwiZXhwIjoiMTQsdfeaeSEFEA0NiIsIm5iZiI6IjE0NTE1NjMwNDYiLCJqdGkiOiI4asdfew}
  • You may also use the postman client

example with postman

Starling device Registration and access

Every API request should include the token obtained above as a parameter in url or header.

http verb Request Response Description
GET /api/starlings returns all the starlings registered for the given user validates the user and returns any starlings registered in JSON
GET /api/starling/{id} returns a particular starling validates the user and returns the given starling data as JSON
PUT /api/starling/{id} edits a particular starling the parameter need to send as form or url encoded data
DEL /api/starling/{id} deletes the starling with the given ID use with caution
POST /api/starling pass the parameters in the form body Creates a new starling after validating the data

Messaging