Skip to content

Latest commit

 

History

History
568 lines (518 loc) · 13.5 KB

api.md

File metadata and controls

568 lines (518 loc) · 13.5 KB

API

  • (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.

POST group_create(manifest)

Creates a new group from the given manifest and returns its id.

  • parameters
  • returns
    • the id of the created group.
  • example
    $ curl \
      --data '{"manifest":...}' \
      --fail \
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${DOMAIN}:${PORT}/group_create
    {"group_create":"dFg8Us"}

GET group_exists?(id)

Determines if a group with the given id exists.

  • parameters
    • id:String.
  • returns
    • true if a group with the given id exists, otherwise false.
  • example
    $ curl \
      --data '{"id":"dFg8Us"}' \
      --fail \
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${DOMAIN}:${PORT}/group_exists?
    {"group_exists?":true}

GET group_manifest(id)

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.
  • example
    $ curl \
      --data '{"id":"dFg8Us"}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${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": []
      }
    }  

POST group_join(id,indexes)

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, or null if the group is already full.
  • example
    $ curl \
      --data '{"id":"dFg8Us"}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request POST \
        http://${DOMAIN}:${PORT}/group_join
    {"group_join":"a8gVRN"}

GET group_joined(id)

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 \
        http://${DOMAIN}:${PORT}/group_joined | jq .
    {
      "group_joined": {
        "7": {
          "id": "a8gVRN",
          "events": [...]
        },
        "29": {
          "id": "gUNjUV",
          "events": [...]
        },
        ...
       }
    }

POST group_fork(id,index)

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.
  • example
    $ curl \
      --data '{"id":"dFg8Us", "index":23}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request POST \
        http://${DOMAIN}:${PORT}/group_fork
    {"group_fork":"a8gVRN"}

POST kata_create(manifest)

Creates a new kata from the given manifest and returns its id.


GET kata_exists?(id)

Determines if a kata exercise with the given id exists.

  • parameters
    • id:String.
  • returns
    • true if a kata with the given id exists, otherwise false.
  • example
    $ curl \
      --data '{"id":"4ScKVJ"}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${DOMAIN}:${PORT}/kata_exists?
    {"kata_exists?":false}

GET kata_manifest(id)

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.
  • example
    $ curl \
      --data '{"id":"4ScKVJ"}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${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": []
      }
    }  

GET kata_events(id)

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.
  • example
    $ curl \
      --data '{"id":"4ScKVJ"}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${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
        }
      ]
    }

GET kata_event(id,index)

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 and index.
  • example
    $ curl \
      --data '{"id":"4ScKVJ","index":2}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${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
       }
     }

GET katas_events(ids,indexes)

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 and indexes.
  • example
    $ curl \
      --data '{"ids":["4ScKVJ","De87Aa"],"indexes":[23,45]}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request GET \
        http://${DOMAIN}:${PORT}/katas_events | jq .
    {
       "katas_events": {
         "4ScKVJ": {
           "23": {
             "files": { ... },
             "stdout": { ... }  
             ...
           }
         },
         "De87Aa": {
           "45": {
             "files": { ... },
             "stdout": { ... }  
             ...
           }
         }
       }
     }

POST kata_ran_tests(id,index,files,stdout,stderr,status,summary)

Record a test event with no prediction.


POST kata_predicted_right(id,index,files,stdout,stderr,status,summary)

Record a test event with a correct prediction.


POST kata_predicted_wrong(id,index,files,stdout,stderr,status,summary)

Record a test event with an incorrect prediction.


POST kata_reverted(id,index,files,stdout,stderr,status,summary)

Revert back to a previous traffic-light.


POST kata_checked_out(id,index,files,stdout,stderr,status,summary)

Checkout a traffic-light from a different avatar.


GET kata_option_get(id,name)

Get a theme (dark/light) or colour (on/off) or prediction (on/off) option.


POST kata_option_set(id,name,value)

Set a theme (dark/light) or colour (on/off) or prediction (on/off) option.


POST kata_fork(id,index)

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.
  • example
    $ curl \
      --data '{"id":"dFg8Us", "index":23}' \
      --fail \    
      --header 'Content-type: application/json' \
      --silent \
      --request POST \
        http://${DOMAIN}:${PORT}/kata_fork
    {"kata_fork":"a8gVRN"}

GET alive?

Tests if the service is alive.
Used as a Kubernetes liveness probe.

  • parameters
    • none
  • result
    • true
  • example
    $ curl --fail --silent --request GET http://${DOMAIN}:${PORT}/alive?
    {"alive?":true}

GET ready?

Tests if the service is ready to handle requests.
Used as a Kubernetes readiness probe.

  • parameters
    • none
  • result
    • true when the service is ready
    • false when the service is not ready
  • example
    $ curl --fail --silent --request GET http://${DOMAIN}:${PORT}/ready?
    {"ready?":false}

GET sha

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 http://${DOMAIN}:${PORT}/sha
    {"sha":"41d7e6068ab75716e4c7b9262a3a44323b4d1448"}

JSON in

  • All methods pass their argument in a json hash in the http request body.
    • For alive?,ready? and sha you can use '' (which is the default for curl --data) instead of '{}'.

JSON out

  • 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 http://${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 http://${DOMAIN}:${PORT}/run | jq      
      {
        "exception": {
          "path": "/run",
          "body": "not-json-hash",
          "class": "SaverService",
          "message": "...",
          "backtrace": [
            ...
            "/usr/bin/rackup:23:in `<main>'"
          ]
        }
      }