Not Auth, Is Alive
curl localhost:8000/gosd/api/v2/ok
{"ok":"2021-01-16 17:55:51.768278076 +0800 CST m=+3.689842946"}
First of all, Need login get
token
/oauth/token
example:
curl http://localhost:8000/gosd/oauth/token \
-F grant_type="password" \
-F username="<Your Username>" \
-F password="<Your Password>" \
-F client_id="<Client Id>" \
-F client_secret="<Client Secret>"
Field | Type | Description |
---|---|---|
grant_type | string | Only support password |
username | string | Username |
password | string | Password |
client_id | string | Client Password rfc6749#section-2.3.1 |
client_secret | string | Need send email to: contact@sb.im |
{
"access_token": "3587cee2fac536268e0dae099339b0697efd7ee1896eebf9e839cfb7126dd599",
"token_type": "bearer",
"expires_in": 7200,
"created_at": 1591863615
}
Field | Type | Description |
---|---|---|
access_token | string | Token |
token_type | string | rfc6749#section-7.1 |
expires_in | uint | Expires in (s) |
created_at | uint | 10 Timestamp |
BASE_URL
+ api + auth header
The BASE_URL
default http://localhost:8000/gosd
For example:
curl http://localhost:8000/gosd/api/v1/nodes/ -H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
GET /api/v1/nodes/
curl http://localhost:8000/gosd/api/v1/nodes/ -H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
[
{
"id":1,
"name":"Drone",
"description":"A Test Drone",
"points":[{
"id":1,
"name":"aa",
"node_id":1,
"point_type_id":2,
"point_type_name":"livestream_flv"
}],
"type_name":"air"
},{
"id":2,
"name":"Depot",
"description":"A Test Depot",
"points":[],
"type_name":"depot"
}
]
Field | Type | Description |
---|---|---|
id | uint | Globally unique device id |
name | string | Name |
description | string | Description |
points | array | How many features are available |
points.type | string | Enum: reference SDWC |
points.params | object | reference SDWC |
POST /api/v2/blobs/
curl -X POST \
-F c1=@go.mod \
-F c2=@go.sum \
localhost:8000/gosd/api/v2/blobs/ \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
{"c1":"8","c2":"9"}
Key is Any value
NOTE: value must String
PUT /api/v2/blobs/:id
curl -X PUT \
-F c=@go.mod \
localhost:8000/gosd/api/v2/blobs/20 \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
{"id":20,"filename":"go.mod"}
c
Can be any value
curl -X PUT \
-F c=@go.mod \
-F c2=@go.sum \
localhost:8000/gosd/api/v2/blobs/20 \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
{"id":20,"filename":"go.mod"}
If has Multiple file, Random select a file
DELETE /api/v2/blobs/:id
curl -X DELETE \
localhost:8000/gosd/api/v2/blobs/1 \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
POST /api/v2/plans/
curl -X POST localhost:8000/gosd/api/v2/plans/ \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27" \
-H 'content-type: application/json' \
-d '{
"name":"233",
"description":"test",
"node_id":1,
"files": {
"file":"30"
},
"extra":{
"key1":"value1",
"key2":"value2",
"key3":"value3"
}
}'
response
{
"id": 35,
"name": "233",
"description": "test",
"node_id": 1,
"files": {
"file": "30"
},
"extra":{
"key1": "value1",
"key2": "value2",
"key3": "value3"
}
}
Field | Type | Description |
---|---|---|
id | uint | Globally unique plan id |
name | string | Name |
description | string | Description |
node_id | uint | Run Plan node |
files | object | map[string]string key is type, value is blob_id |
extra | object | map[string]string key is type, value is text |
GET /api/v2/plans/
[
{
"id": 1,
"name": "233",
"description": "",
"node_id": 1,
"files": {
"file": "1"
},
"extra": {null}
},{
"id": 2,
"name": "233",
"description": "",
"node_id": 1,
"files": {
"file": "1"
},
"extra":{
"key1": "value1",
"key2": "value2",
"key3": "value3"
}
}
]
PUT /api/v2/plans/:id
Only PUT
curl -X PUT localhost:8000/gosd/api/v2/plans/1 \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27" \
-H 'content-type: application/json' \
-d '{
"name":"233",
"description":"test",
"node_id":1,
"files": {
"file":"30"
},
"extra":{
"key1":"value1",
"key2":"value2",
"key3":"value3"
}
}'
response
{
"id": 1,
"name": "233",
"description": "test",
"node_id": 1,
"files": {
"file": "30"
},
"extra":{
"key1": "value1",
"key2": "value2",
"key3": "value3"
}
}
DELETE /api/v2/plans/:id
curl -X DELETE localhost:8000/gosd/api/v2/plans/1 \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27" \
response
{
"id": 1,
"name": "233",
"description": "test",
"node_id": 1,
"files": {
"file": "30"
},
"extra":{
"key1": "value1",
"key2": "value2",
"key3": "value3"
}
}
POST /api/v2/plans/:id/jobs/
Run This plan
curl -X POST localhost:8000/gosd/api/v2/plans/1/jobs/ \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
response
{
"id":4,
"job_id":3,
"plan_id":1,
"files":{},
"extra":{},
"created_at":"2021-03-20T09:02:20.386117Z",
"updated_at":"2021-03-20T09:02:20.386117Z"
}
POST /api/v2/plans/:id/jobs/:job_id/cancel
Emergency, stop
curl -X POST localhost:8000/gosd/api/v2/plans/3/jobs/cancel \
-H "Authorization: Bearer 6b6e69e4e3166d3433bed7412bd3c2caf4fd6aebf7ae7b03834c8494e6c4cf27"
Or:
(Not recommended for use)
DELETE /api/v2/plans/:id/jobs/running
GET /api/v2/plans/:id/jobs/
[
{
"id":431,
"job_id":369,
"plan_id":0,
"files":{},
"extra":{},
"created_at":"2020-09-23T16:16:07.736495+08:00",
"updated_at":"2020-09-23T16:16:07.736495+08:00"
},{
"id":432,
"job_id":370,
"plan_id":0,
"files":{},
"extra":{},
"created_at":"2020-09-23T16:19:49.510395+08:00",
"updated_at":"2020-09-23T16:19:49.510395+08:00"
}
]