Skip to content

Endpoints

Arravind Sudhakar edited this page Mar 17, 2021 · 12 revisions

Authentication

The headers of all the requests need to have the token authentication format as specified by HTTP Authentication scheme. The format is:

{
    "Authorization": "Bearer <token>"
}

Courses need to use the tokens they specified for themselves to the admin. Worker nodes need to use the cluster token.

Response Format

All API responses have the following format:

{
    "data": <body dict specified in the endpoint docs below>,
    "status": <string describing the status of this request>
}

Client Endpoints

These are the endpoints used by registered courses.


Grading Config

Used to add or get the grading config for an assignment under a particular course.

Endpoint - /api/v1/grading_config/[course_id]/[assignment_name]

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course
  • assignment_name - unique identifier for an assignment within a course

GET - Returns the grading config if it exists. The response body will have the exact same config that was uploaded.

POST - Body should be the grading config. Saves the assignment config under the given course and assignment name.


Grading Run

Used to start an autograder run for an assignment. Schedules all the grading jobs in the correct order. The preprocessing job is run first if it exists. Once that is successful, the student grading jobs are scheduled and executed parallelly across multiple graders. Once all the student grading jobs have finished executing (succeeded or failed), the post-processing job will be scheduled.

Endpoint - /api/v1/grading_run/[course_id]/[assignment_name]

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course
  • assignment_name - unique identifier for an assignment within a course

POST - Body should be the run-time environment variables config. This will determine the number of student grading jobs.

Response Format:

{
    "grading_run_id": <unique grading run id>
}

Grading Run Status

Used to get the grading run status

Endpoint - /api/v1/grading_run_status/[course_id]/[run_id]

Tokens allowed: admin or query

URI Parameters:

  • course_id- unique identifier for a course
  • run_id - unique identifier for a grading run

GET - Shows the state of all the grading jobs under this grading request. The response contains job-id to state mappings. These job ids are important to get the logs for that job. Hence this endpoint can also be used to get all the job ids.

The grading job state is a string which will represent one of the following states:

  • QUEUED - the grading job has been added to the run queue
  • STARTED - the grading job has been polled by a worker node and is being currently run
  • FAILED - the worker node was unsuccessful in running the chain of container specified
  • SUCCEEDED - the worker node successfully ran all the specified containers

The grading run state is a string which will represent one of the following states:

  • READY - grading run is ready to be started
  • PRE_PROCESSING_STAGE - the pre-processing job has been scheduled and is potentially running
  • STUDENTS_STAGE - the students grading jobs have been scheduled and are running (implies that if there was a pre-processing job, it was successful)
  • POST_PROCESSING_STAGE - the post-processing job has been scheduled and is potentially running
  • FINISHED - Grading run is complete. pre/post-processing jobs (if they existed) were successful. All grading jobs have finished executing.
  • FAILED - Grading run failed. Either pre/post-processing jobs failed.

Response Format:

{
     "state": <grading run state>
     "pre_processing_job": {<pre-processing-job-id>: <grading job state>},
     "post_processing_job": {<post-processing-job-id>: <grading job state>},
     "student_jobs": {
              <job-id>: <grading job state>, ...
     }
}

Grading Run Environment

Used to get the grading run status

Endpoint - /api/v1/grading_run_env/[course_id]/[run_id]

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course
  • run_id - unique identifier for a grading run

GET - Shows the environments for each grading job within the specifies grading run. The response consists of job-id to env mappings, and each environment is itself a mapping between env-variable's and a list of env-value's. We use a list because each job has multiple stages, so we retain the env-value's from every stage if they are different.

Response Format:

{
     "pre_processing_env": {<pre-processing-job-id>: {<env-variable>: [<env-value>, ...]}},
     "post_processing_job": {<post-processing-job-id>: {<env-variable>: [<env-value>, ...]}},
     "student_jobs": {
              <job-id>: {<env-variable>: [<env-value>, ...]}, ...
     }
}

Grading Job Log

Used to get grading job logs.

Endpoint - /api/v1/grading_job_log/[course_id]/[job_id]

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course
  • job_id - unique identifier for a grading job

GET - Used to get grading job logs. This will be the stdout and stderr from all the containers which were run. This is meant to be used for debugging purposes.

Response Format:

{
    "stdout": <concatenation of all stdout output from the sequence of containers>,
    "stderr": <concatenation of all stderr output from the sequence of containers>
}

Course Worker Status

Used to assess system health.

Endpoint - /api/v1/worker/[course_id]/[scope]

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course
  • scope - the filter applied to the response.
Scope Description
all Returns all the worker nodes available for this course.

GET - Shows the worker nodes available for a specific course filtered by the scope the user wants. This endpoint shows the worker node status (alive/dead, busy/available, number of jobs processes, hostname). It can be used to get an overview of the system's health. Currently, all worker nodes are available to all courses but later we can have a quota or some policy as to how much of the grading cluster a course has access to.

Response Format:

{
     "worker_nodes": [
             {
                  "hostname": <hostname of the machine on which the grader is running>,
                  "jobs_processed": <number of jobs processed since joining the cluster>,
                  "busy": <True/False>,
                  "alive": <True/False>
             }, ...
       ]
}

Course Queue Length

Used to determine how many grading jobs are queued for a given course.

Endpoint - /api/v1/queue/[course_id]/length

Tokens allowed: admin only

URI Parameters:

  • course_id- unique identifier for a course

GET - Used to get the length of a course's grading job queue.

Response Format:

{
    "length": <queue length>
}

Grading Job Queue Position

Used to determine how many grading jobs are in front of a given job within its course's queue.

Endpoint - /api/v1/queue/[course_id]/[job_id]/position

Tokens allowed: admin or query

URI Parameters:

  • course_id- unique identifier for a course
  • job_id - unique identifier for a grading job

GET - Used to get how many grading jobs are in front of a given job. For example, if 0 is returned, the given job is at the front of the course's queue.

Response Format:

{
    "position": <queue position>
}

Grading Job Information Stream

Subscribe to server-sent events regarding the progress of a grading job.

Endpoint - /api/v1/stream/[course_id]/[job_id]

Tokens allowed: admin or query

URI Parameters:

  • course_id- unique identifier for a course
  • job_id - unique identifier for a grading job

GET - Receive events from the server about the selected job.

SSE event name - status_update

Response format:

event: status_update\ndata: [JSON_BLOB]\n\n

Example response:

event: status_update\ndata: {"type": "state", "data": "STARTED"}\n\n

JSON blob format:

{
  "type": [update type],
  "data": [relevant data]
}
Update Type Data Value Description
"state" "STARTED" Sent when a job is pulled from the queue and started
"state" "FINISHED" Sent when a job successfully finishes
"state" "FAILED" Sent when a job fails
"position" A non-negative integer The job's new position in the queue. Sent when a job is pulled from the queue.
Clone this wiki locally