- (JSON-in) All methods pass their argument in a json hash in the HTTP request body.
- (JSON-out) All methods return a json hash in the HTTP response body.
- GET is used for queries.
- POST is used for modifiers.
- Paths are not REST-ful.
Creates a new group from the given manifest and returns its id.
- parameters
- manifest:Hash created by creator from languages-start-points and exercises-start-points or custom-start-points.
- returns
- the
id
of the created group.
- the
- example
$ curl \ --data '{"manifest":...}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/group_create
{"group_create":"dFg8Us"}
Determines if a group with the given id
exists.
- parameters
- id:String.
- returns
true
if a group with the givenid
exists, otherwisefalse
.
- example
$ curl \ --data '{"id":"dFg8Us"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/group_exists?
{"group_exists?":true}
Gets the manifest used to create the group with the given id
.
- parameters
- id:String.
- returns
- the manifest of the group with the given
id
.
- the manifest of the group with the given
- example
$ curl \ --data '{"id":"dFg8Us"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/group_manifest | jq .
{ "group_manifest": { "display_name": "Bash, bats", "image_name": "cyberdojofoundation/bash_bats:53d0c9c", "filename_extension": [ ".sh" ], "tab_size": 4, "visible_files": { "test_hiker.sh": { "content": "..." }, "bats_help.txt": { "content": "..." }, "hiker.sh": { "content": "..." }, "cyber-dojo.sh": { "content": "..." }, "readme.txt": { "content": "..." } }, "exercise": "LCD Digits", "version": 1, "created": [2020,10,19,12,51,32,991192], "id": "REf1t8", "highlight_filenames": [], "max_seconds": 10, "progress_regexs": [] } }
Creates a new kata in the group with the given id
and returns the kata's id.
- parameters
- id:String.
- indexes:Array[int] Currently unused (and defaulted). For a planned feature.
- returns
- the
id
of the created kata, ornull
if the group is already full.
- the
- example
$ curl \ --data '{"id":"dFg8Us"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request POST \ https://${DOMAIN}:${PORT}/group_join
{"group_join":"a8gVRN"}
Returns the kata-id and kata-events-summary keyed against the kata's avatar-index (0-63)
for the katas that have joined a group. The id can be the group's id
or the id
of any kata in the group.
- parameters
- id:String.
- returns
- a Hash.
- example
$ curl \ --data '{"id":"dFg8Us"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/group_joined | jq .
{ "group_joined": { "7": { "id": "a8gVRN", "events": [...] }, "29": { "id": "gUNjUV", "events": [...] }, ... } }
Creates a new group whose starting files are a copy of the files in the kata with
the given id
at the given index
. The new group is not a fork in the git sense;
that is, it is not a 'deep' copy, the history of commits (one per test event)
that exist in the kata being forked are not copied.
- parameters
- id:String.
- index:int
- returns
- the
id
of the created group.
- the
- example
$ curl \ --data '{"id":"dFg8Us", "index":23}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request POST \ https://${DOMAIN}:${PORT}/group_fork
{"group_fork":"a8gVRN"}
Creates a new kata from the given manifest and returns its id.
- parameters
- manifest:Hash created by creator from languages-start-points and exercises-start-points or custom-start-points.
- returns
- the
id
of the created kata.
- the
- example
$ curl \ --data '{"manifest":...}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/kata_create
{"kata_create":"dFg8Us"}
Determines if a kata exercise with the given id
exists.
- parameters
- id:String.
- returns
true
if a kata with the givenid
exists, otherwisefalse
.
- example
$ curl \ --data '{"id":"4ScKVJ"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/kata_exists?
{"kata_exists?":false}
Gets the manifest used to create the kata exercise with the given id
.
- parameters
- id:String.
- returns
- the manifest of the kata with the given
id
.
- the manifest of the kata with the given
- example
$ curl \ --data '{"id":"4ScKVJ"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/kata_manifest | jq .
{ "kata_manifest": { "display_name": "Bash, bats", "image_name": "cyberdojofoundation/bash_bats:53d0c9c", "filename_extension": [ ".sh" ], "tab_size": 4, "visible_files": { "test_hiker.sh": { "content": "..." }, "bats_help.txt": { "content": "..." }, "hiker.sh": { "content": "..." }, "cyber-dojo.sh": { "content": "..." }, "readme.txt": { "content": "..." } }, "exercise": "LCD Digits", "version": 1, "created": [2020,10,19,12,52,46,396907], "group_id": "REf1t8", "group_index": 44, "id": "4ScKVJ", "highlight_filenames": [], "max_seconds": 10, "progress_regexs": [] } }
Gets the summary of all current events for the kata with the given id
.
- parameters
- id:String.
- returns
- an Array holding the events summary of the kata with the given
id
.
- an Array holding the events summary of the kata with the given
- example
$ curl \ --data '{"id":"4ScKVJ"}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/kata_events | jq .
{ "kata_events": [ { "index": 0, "time": [2020,10,19,12,52,46,396907], "event": "created" }, { "time": [2020,10,19,12,52,54,772809], "duration": 0.491393, "colour": "red", "predicted": "none", "index": 1 }, { "time": [2020,10,19,12,52,58,547002], "duration": 0.426736, "colour": "amber", "predicted": "none", "index": 2 }, { "time": [2020,10,19,12,53,3,256202], "duration": 0.438522, "colour": "green", "predicted": "none", "index": 3 } ] }
Gets the full details for the kata event whose kata has the given id
whose event has the given index
.
- parameters
- id:String.
- index:int. Negative values count backwards, -1 is the last index.
- returns
- the event with the given
id
andindex
.
- the event with the given
- example
$ curl \ --data '{"id":"4ScKVJ","index":2}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/kata_event | jq .
{ "kata_event": { "files": { "test_hiker.sh": { "content": "..." }, "bats_help.txt": { "content": "..." }, "hiker.sh": { "content": "..." }, "cyber-dojo.sh": { "content": "..." }, "readme.txt": { "content": "..." } }, "stdout": { "content": "...", "truncated": false }, "stderr": { "content": "...", "truncated": false }, "status": "1", "time": [2020,10,19,12,52,58,547002], "duration": 0.426736, "colour": "amber", "predicted": "none", "index": 2 } }
Gets the full details for the kata events with the given ids
and indexes
.
A Batch-Method for kata_event(id,index).
- parameters
- ids:Array[String].
- index:Array[int].
- returns
- the events with the given
ids
andindexes
.
- the events with the given
- example
$ curl \ --data '{"ids":["4ScKVJ","De87Aa"],"indexes":[23,45]}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request GET \ https://${DOMAIN}:${PORT}/katas_events | jq .
{ "katas_events": { "4ScKVJ": { "23": { "files": { ... }, "stdout": { ... } ... } }, "De87Aa": { "45": { "files": { ... }, "stdout": { ... } ... } } } }
Record a test event with no prediction.
Record a test event with a correct prediction.
Record a test event with an incorrect prediction.
Revert back to a previous traffic-light.
Checkout a traffic-light from a different avatar.
Get a theme (dark/light) or colour (on/off) or prediction (on/off) option.
Set a theme (dark/light) or colour (on/off) or prediction (on/off) option.
Creates a new kata whose starting files are a copy of the files in the kata with
the given id
at the given index
. The new kata is not a fork in the git sense;
that is, it is not a 'deep' copy, the history of commits (one per test event)
that exist in the kata being forked are not copied.
- parameters
- id:String.
- index:int
- returns
- the
id
of the created kata.
- the
- example
$ curl \ --data '{"id":"dFg8Us", "index":23}' \ --fail \ --header 'Content-type: application/json' \ --silent \ --request POST \ https://${DOMAIN}:${PORT}/kata_fork
{"kata_fork":"a8gVRN"}
The runtime liveness probe to see if the service is alive.
- parameters
- none
- result
- true
- example
$ curl --fail --silent --request GET https://${DOMAIN}:${PORT}/alive?
{"alive?":true}
The runtime readiness probe to see if the service is ready to handle requests.
- parameters
- none
- result
- true when the service is ready
- false when the service is not ready
- example
$ curl --fail --silent --request GET https://${DOMAIN}:${PORT}/ready?
{"ready?":false}
The git commit sha used to create the Docker image.
- parameters
- none
- result
- the 40 character commit sha string.
- example
$ curl --fail --silent --request GET https://${DOMAIN}:${PORT}/sha
{"sha":"41d7e6068ab75716e4c7b9262a3a44323b4d1448"}
The base-image used in the Dockerfile's FROM statement.
- parameters
- none
- result
- the name of the base image.
- example
$ curl --fail --silent --request GET https://${DOMAIN}:${PORT}/base_image
{"base_image":"cyberdojo/sinatra-base:edb2887"}
- All methods pass their argument in a json hash in the http request body.
- If there are no arguments you can use
''
(which is the default forcurl --data
) instead of'{}'
.
- All methods return a json hash in the http response body.
- If the method does not raise, a string key equals the method's name. eg
$ curl --silent -X GET https://${DOMAIN}:${PORT}/ready?
{"ready?":true}
- If the method raises an exception, a string key equals
"exception"
, with a json-hash as its value. eg$ curl --data 'not-json-hash' --silent -X GET https://${DOMAIN}:${PORT}/run | jq
{ "exception": { "path": "/run", "body": "not-json-hash", "class": "SaverService", "message": "...", "backtrace": [ ... "/usr/bin/rackup:23:in `<main>'" ] } }