g2core REST Examples - synthetos/g2 GitHub Wiki
PRELIMINARY - FOR DISCUSSION
These preliminary design pages are for discussion of the g2core REST interface: 
Provides an endpoint for system and API version information that is independent of the machine or any other resource
REQUEST:
  GET /version HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"fv":0.99,"fb":100.12,"fbs":"100.12-14-g375c-dirty","fbc":"settings_makeblock.h","hp":3,"hv":0,"id":"0084-7bd6-29c6-8ce","msg":"SYSTEM READY"}
The machine REST endpoint is used to query machine state and to query and set machine parameters in the machine resource. It is intended for JSON commands that execute synchronously, as most configuration gets and sets do.
- 
The API can handle single values, JSON objects, or composite JSON documents consisting of multiple values and/or objects. It will accept as arguments pretty much anything supported in the configuration for the board's firmware version. Examples are provided for some common cases. 
- 
The machine resource can be called with or without a URI resource path. 
- 
In addition, the nodes_onlyquery parameter may be set to return only nodes, no leaves. This is useful for resource discovery.
Note: To send Gcode or to invoke long-running JSON commands that require asynchronous handling see operation.
Return machine objects and/or attributes by a JSON specification in the request body. The following calling styles are supported. Any can return all object data, or nodes only if ?nodes_only=true is used:
(body omitted)              no body provided. Return entire machine
{ }                         key is empty object. Return entire machine
{"stat":null}               key is freestanding; not part of an object (system state)
{"x":null}                  key is an object (X axis)
{"x":{"vm":null}}           key is part of an object (X axis max velocity)
{"xvm":null}                key is flattened version of above (may be deprecated later)
{"x.vm":null}               key is flattened version of above (planned for future)
{"x":null,"y":null}         key described multiple objects (X and Y axes)
{"x":null,"y":{"jm":null}}  key is mixed objects and attributes
{"posx":null,"posy":null,"posz":null,"vel":null,"stat":null} key has multiple attributes
REQUEST:
  GET /machine HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
{"value":
{
"sys":{"fb":100.12,"fbs":"100.12-14-g375c-dirty", "fbc":"settings_makeblock.h","fv":0.99,"hp":3,"hv":0, "id":"0084-7bd6-29c6-4ad", "jt":0.75,"ct":0.1,"sl":0,"lim":0,"saf":1,"m48e":1,"mfoe":0,"mfo":1,"mtoe":0,"mto":1,"mt":2,"spep":1,"spdp":0,"spph":1,"spdw":1,"ssoe":0,"sso":1,"cofp":1,"comp":1,"coph":0,"tv":1,"ej":1,"jv":2,"qv":0,"sv":1,"si":250,"gpl":0,"gun":1,"gco":1,"gpa":2,"gdi":0},
"x":{"am":1,"vm":40000,"fr":40000,"tn":0,"tm":420,"jm":5000,"jh":20000,"hi":1,"hd":0,"sv":3000,"lv":100,"lb":4,"zb":2},
"y":{"am":1,"vm":40000,"fr":40000,"tn":0,"tm":420,"jm":5000,"jh":20000,"hi":3,"hd":0,"sv":3000,"lv":100,"lb":4,"zb":2},
"z":{"am":1,"vm":1200,"fr":1200,"tn":-95,"tm":0,"jm":500,"jh":1000,"hi":6,"hd":1,"sv":800,"lv":25,"lb":4,"zb":2},
"a":{"am":0,"vm":393701,"fr":393701,"tn":-1,"tm":-1,"jm":49213,"jh":49213,"ra":5.821,"hi":0,"hd":0,"sv":196850,"lv":39370.08,"lb":5,"zb":2},
"b":{"am":0,"vm":393701,"fr":393701,"tn":-1,"tm":-1,"jm":49213,"jh":49213,"ra":5.821,"hi":0,"hd":0,"sv":196850,"lv":39370.08,"lb":5,"zb":2},
"c":{"am":0,"vm":393701,"fr":393701,"tn":-1,"tm":-1,"jm":49213,"jh":49213,"ra":5.821,"hi":0,"hd":0,"sv":196850,"lv":39370.08,"lb":5,"zb":2},
"1":{"ma":0,"sa":1.8,"tr":36.576,"mi":8,"su":43.74453,"po":0,"ep":1,"pm":2,"pl":0.4},
"2":{"ma":1,"sa":1.8,"tr":36.576,"mi":8,"su":43.74453,"po":0,"ep":1,"pm":2,"pl":0.4},
"3":{"ma":2,"sa":1.8,"tr":1.25,"mi":8,"su":1280,"po":0,"ep":1,"pm":2,"pl":0.4},
"4":{"ma":3,"sa":1.8,"tr":360,"mi":8,"su":4.44444,"po":0,"ep":1,"pm":0,"pl":0},
"do1":{"mo":1},
"do2":{"mo":1},
"do3":{"mo":1},
"do4":{"mo":1},
"do5":{"mo":1},
"do6":{"mo":1},
"do7":{"mo":1},
"do8":{"mo":1},
"do9":{"mo":1},
"di1":{"mo":0,"ac":0,"fn":0},
"di2":{"mo":0,"ac":0,"fn":0},
"di3":{"mo":0,"ac":0,"fn":0},
"di4":{"mo":0,"ac":0,"fn":0},
"di5":{"mo":0,"ac":0,"fn":0},
"di6":{"mo":0,"ac":0,"fn":0},
"di7":{"mo":0,"ac":0,"fn":0},
"di8":{"mo":0,"ac":0,"fn":0},
"di9":{"mo":0,"ac":0,"fn":0},
"he1":{"e":false,"p":9,"i":0.12,"d":400,"st":0,"t":-1,"op":0,"tr":-1,"at":false,"an":0,"fp":1,"fm":0.4,"fl":40,"fh":40},
"he2":{"e":false,"p":9,"i":0.12,"d":400,"st":0,"t":-1,"op":0,"tr":-1,"at":false,"an":0,"fp":1,"fm":0.4,"fl":40,"fh":40},
"he3":{"e":false,"p":9,"i":0.12,"d":400,"st":0,"t":-1,"op":0,"tr":-1,"at":false,"an":0,"fp":1,"fm":0.4,"fl":40,"fh":40},
"g54":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g55":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g56":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g57":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g58":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g59":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g92":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g28":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0},
"g30":{"x":0,"y":0,"z":0,"a":0,"b":0,"c":0}
},"code":0,"description":"OK"
}Return top level objects in a machine
REQUEST:
  GET /machine?nodes_only=true HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"sys":null,"x":null,"y":null,"z":null,"a":null,"b":null,"c":null,"1":null,"2":null,"3":null,"4":null,"do1":null,"do2":null,"do3":null,"do4":null,"do5":null,"do6":null,"do7":null,"do8":null,"do9":null,"di1":null,"di2":null,"di3":null,"di4":null,"di5":null,"di6":null,"di7":null,"di8":null,"di9":null,"he1":null,"he2":null,"he3":null,"g54":null,"g55":null,"g56":null,"g57":null,"g58":null,"g59":null,"g92":null,"g28":null,"g30":null},"code":0,"description":"OK"}Response prettified:
{
  	"value": {
  		"sys": null,
  		"x": null,
  		"y": null,
  		"z": null,
  		"a": null,
  		"b": null,
  		"c": null,
  		"1": null,
  		"2": null,
  		"3": null,
  		"4": null,
  		"do1": null,
  		"do2": null,
  		"do3": null,
  		"do4": null,
  		"do5": null,
  		"do6": null,
  		"do7": null,
  		"do8": null,
  		"do9": null,
  		"di1": null,
  		"di2": null,
  		"di3": null,
  		"di4": null,
  		"di5": null,
  		"di6": null,
  		"di7": null,
  		"di8": null,
  		"di9": null,
  		"he1": null,
  		"he2": null,
  		"he3": null,
  		"g54": null,
  		"g55": null,
  		"g56": null,
  		"g57": null,
  		"g58": null,
  		"g59": null,
  		"g92": null,
  		"g28": null,
  		"g30": null
  	},
  	"code": 0,
  	"description": "OK"
  }A {key} can be any of the following. The examples illustrate these cases.
- 
/machine/stat- key is freestanding; not part of an object (system state)
- 
/machine/x/vm- key is part of an object (X axis max velocity)
- 
/machine/xvm- flattened version of the above (may be deprecated in the future)
- 
/machine/x.vm- flattened version of the above planned for future
- 
/machine/x- key is entire object
Get the value of a single {key} of ct (chordal tolerance) as an example, which is a numeric type.
REQUEST:
  GET /machine/ct HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":0.01,"code":0,"description":"OK"}Get the value of a single {key} x/jm (max jerk in the X axis), which is a numeric type.
REQUEST:
  GET /machine/x/jm HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":1200,"code":0,"description":"OK"}Same as above using flattened notation xjm
REQUEST:
  GET /machine/xjm HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":1200,"code":0,"description":"OK"}Get the value of a single object {key} using the pos object as an example.
REQUEST:
  GET /machine/pos HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"pos":{"x":0,"y":0,"z":0,"a":0,"b":0}},"code":0,"description":"OK"}Using a {key} of xjm as an example, which is a numeric type.
REQUEST:
  GET /machine/xjm HTTP/1.1
  {"value":1200,"code":0,"description":"OK"}
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":1200,"code":0,"description":"OK"}Using a {key} of g54 as an example, which is an object type.
REQUEST:
  GET /machine/pos HTTP/1.1
  {"value":{"g54":{"x":0,"y":0,"z":0,"a":0,"b":0}},"code":0,"description":"OK"}
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"g54":{"x":0,"y":0,"z":0,"a":0,"b":0}},"code":0,"description":"OK"}See status report resource for operation.
Question: Is it useful for status_report to report back the operation ID and/or job ID it is reporting on?
Use a status report with no filter to return all keys configured in the status report
REQUEST:
  GET /status_report HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"line":101,"posx":10,"posy":20,"posz":-1,"posa":0,"posb":0,"posc":0,"feed":1000,"vel":1000,"momo":0,"stat":5},"code":0,"description":"OK"}Use a status report filter with null values to select which keys to return
REQUEST:
  GET /status_report HTTP/1.1
  {"value":{"posx":null,"posy":null,"posz":null,"vel":null,"stat":null},"code":0,"description":"OK"}
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"posx":10,"posy":20,"posz":-1,"vel":1000,"stat":5},"code":0,"description":"OK"}Use a status report filter with non-null values to return only keys that have different values (have changed)
REQUEST:
  GET /status_report HTTP/1.1
  {"value":{"posx":10,"posy":20,"posz":-1,"vel":1000,"stat":5},"code":0,"description":"OK"}
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"value":{"posx":10.2},"code":0,"description":"OK"}Operations are started by specifying the operation type and the commands for the operation in the body of the POST. once running, they can be monitored and updated using GETs and PUTs.
Enums:
- Operation types (optype)
- run - run arbitrary Gcode, JSON or a mix
- sendfile - send a file
 
- Operation states (opstate)
- PEND
- RUN
- DONE
- ERROR
 
Start a new run operation to run one or more Gcode lines
Example of single line operation:
REQUEST:
  POST /operation HTTP/1.1
  {"optype":"run","value":"G28.2 z0"}
RESPONSE:
  HTTP/1.x 201 RESOURCE HAS BEEN CREATED
  Content-Type: application/json; charset=UTF-8
  42Example of multi-line operation:
REQUEST:
  POST /operation HTTP/1.1
  {"optype":"run","value":["G28.2 z0","G28.2 x0 y0"]}
RESPONSE:
  HTTP/1.x 201 RESOURCE HAS BEEN CREATED
  Content-Type: application/json; charset=UTF-8
  42Get return values from a current operation. Mostly what you want is the operation state - is it running, is it done, has it erred out? Some optypes may have specific information returned by a GET call. Note: In most cases a status_report is sufficient for monitoring additional information about an operation.
REQUEST:
  GET /operation/42 HTTP/1.1
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"opstate":"run","code":0,"description":"OK"}
---or possibly something that looks like this---
RESPONSE:
  HTTP/1.x 200 OK
  Content-Type: application/json; charset=UTF-8
  {"opstate":"done","value":{"stat":3,"hom":{"e":true,"x":true,"y":true,"z":true,"a":false,"b":false,"c":false}},"code":0,"description":"OK"}TBD
All error responses look like this:
HTTP/1.x 404 NOT FOUND
Content-Type: application/json; charset=UTF-8
{"status":{"code":100,"description":"Unrecognized command or config name","additional_description":"xyzzy is not supported at the current time"}}Defines the use of HTTP response codes and the mapping from g2core stat codes to HTTP codes
- 200 OK
- STAT_OK 0
 
- 201 Created
- 202 Accepted
- 
400 Bad Request - Syntax errors 101-103, 111-116, 200-203, 207-209
- Gcode specification errors 130-181
- Homing errors 240-247
- Probing errors 250-254
 
- 
404 Not Found - STAT_UNRECOGNIZED_NAME 100
- STAT_NO_SUCH_DEVICE 11
 
- 
405 Method Not Allowed - STAT_PARAMETER_IS_READ_ONLY 104
- STAT_PARAMETER_CANNOT_BE_READ 105
- STAT_COMMAND_NOT_ACCEPTED 106
- Soft limit errors 220-233
 
- 
408 Request Timeout - from host
 
- 
410 Gone - STAT_SHUTDOWN 5
- STAT_PANIC 6
- STAT_ALARM 18
- STAT_COMMAND_REJECTED_BY_ALARM 204
- STAT_COMMAND_REJECTED_BY_SHUTDOWN 205
- STAT_COMMAND_REJECTED_BY_PANIC 206
 
- 
413 Request Entity Too Large - STAT_FILE_SIZE_EXCEEDED 10
- STAT_INPUT_EXCEEDS_MAX_LENGTH 107
 
- 
416 Requested Range Not Satisfiable - STAT_INPUT_LESS_THAN_MIN_VALUE 108
- STAT_INPUT_EXCEEDS_MAX_VALUE 109
- STAT_INPUT_VALUE_RANGE_ERROR 110
 
- 
500 Internal Server Error - Internal errors 7-9, 12-17, 19-36, 88-99
 
- 
501 Not Implemented - from host
 
- 
504 Gateway Timeout 0 from host