auth
auth.login
auth.login
On success, token is a valid token and error is empty. On failure, token is empty and error is a message.
CredentialsIn
CredentialsOut
auth.logout
auth.logout
misc
misc.getApiVersion
misc.getApiVersion
ApiVersion
misc.getFortune
misc.getFortune
misc.getTime
misc.getTime
Time
misc.getHomepageStats
misc.getHomepageStats
HomepageStats
misc.getLogo
misc.getLogo
misc.getAvatarPacks
misc.getAvatarPacks
Avatars are used in exams and contests to identify students or participants.
misc.getExamIcons
misc.getExamIcons
Exam icon are used in exams and contests to identify problems.
TagsDict
misc.getColors
misc.getColors
Color mappings may be used to colorize keys in the frontends. Color names are as defined in https://github.com/timoxley/colornames
ColorMapping
misc.getHexColors
misc.getHexColors
Color mappings may be used to colorize keys in the frontends.
ColorMapping
tables
tables.get
tables.get
Returns all compilers, countries, drivers, languages, proglangs, and verdicts in a single request. This data does not change often, so you should only request it once per session.
AllTables
tables.getLanguages
tables.getLanguages
Returns all languages as a dictionary of objects, indexed by id.
Language
tables.getCountries
tables.getCountries
Returns all countries as a dictionary of objects, indexed by id.
Country
tables.getCompilers
tables.getCompilers
Returns all compilers as a dictionary of objects, indexed by id.
Compiler
tables.getDrivers
tables.getDrivers
Returns all drivers as a dictionary of objects, indexed by id.
Driver
tables.getVerdicts
tables.getVerdicts
Returns all verdicts as a dictionary of objects, indexed by id.
Verdict
tables.getProglangs
tables.getProglangs
Returns all proglangs (porgramming languages) as a dictionary of objects, indexed by id.
Proglang
problems
problems.getAllAbstractProblems
problems.getAllAbstractProblems
Includes problems.
AbstractProblem
problems.getAbstractProblems
problems.getAbstractProblems
Includes problems.
AbstractProblem
problems.getAbstractProblemsInList
problems.getAbstractProblemsInList
Includes problems.
AbstractProblem
problems.getAbstractProblem
problems.getAbstractProblem
Includes owner and problems
AbstractProblem
problems.getAbstractProblemSuppl
problems.getAbstractProblemSuppl
Includes accepted compilers and accepted proglangs
AbstractProblemSuppl
problems.getProblem
problems.getProblem
Includes abstract problem, which includes owner
Problem
problems.getProblemRich
problems.getProblemRich
Includes abstract problem, which includes owner, statements, testcases, etc.
ProblemRich
problems.getProblemSuppl
problems.getProblemSuppl
Includes accepted compilers, accepted proglangs, official solutions checks and handler specifications
ProblemSuppl
problems.getSampleTestcases
problems.getSampleTestcases
Testcase
problems.getPublicTestcases
problems.getPublicTestcases
Public testcases are like sample testcases, but are not meant to be show in the problem statatement, because of their long length.
Testcase
problems.getHtmlStatement
problems.getHtmlStatement
Currently, this is suboptimal, but I already know how to improve it.
problems.getTextStatement
problems.getTextStatement
problems.getMarkdownStatement
problems.getMarkdownStatement
problems.getPdfStatement
problems.getPdfStatement
problems.getZipStatement
problems.getZipStatement
student.keys
student.keys.get
student.keys.get
AllKeys
student.keys.getProblems
student.keys.getProblems
student.keys.getEnrolledCourses
student.keys.getEnrolledCourses
student.keys.getAvailableCourses
student.keys.getAvailableCourses
student.keys.getLists
student.keys.getLists
student.profile
student.profile.get
student.profile.get
Profile
student.profile.getAvatar
student.profile.getAvatar
student.profile.update
student.profile.update
NewProfile
student.profile.updateAvatar
student.profile.updateAvatar
student.profile.updatePassword
student.profile.updatePassword
Receives the old password and the new one, and changes the password if the old one is correct and the new one strong enough.
NewPassword
student.dashboard
student.dashboard.getAbsoluteRanking
student.dashboard.getAbsoluteRanking
student.dashboard.getAllDistributions
student.dashboard.getAllDistributions
AllDistributions
student.dashboard.getCompilersDistribution
student.dashboard.getCompilersDistribution
Distribution
student.dashboard.getDashboard
student.dashboard.getDashboard
Dashboard
student.dashboard.getHeatmapCalendar
student.dashboard.getHeatmapCalendar
HeatmapCalendar
student.dashboard.getProglangsDistribution
student.dashboard.getProglangsDistribution
Distribution
student.dashboard.getStats
student.dashboard.getStats
Distribution
student.dashboard.getLevel
student.dashboard.getLevel
student.dashboard.getSubmissionsByHour
student.dashboard.getSubmissionsByHour
Distribution
student.dashboard.getSubmissionsByWeekDay
student.dashboard.getSubmissionsByWeekDay
Distribution
student.dashboard.getVerdictsDistribution
student.dashboard.getVerdictsDistribution
Distribution
student.submissions
student.submissions.indexForAbstractProblem
student.submissions.indexForAbstractProblem
Grouped by problem.
Submission
student.submissions.indexForProblem
student.submissions.indexForProblem
Submission
student.submissions.getAll
student.submissions.getAll
Flat array of submissions in chronological order.
Submission
student.submissions.submit
student.submissions.submit
problem_id | string |
compiler_id | string |
code | string |
annotation | string |
student.submissions.submitFull
student.submissions.submitFull
NewSubmissionIn
NewSubmissionOut
student.submissions.get
student.submissions.get
problem_id | string |
submission_id | string |
Submission
student.submissions.getCodeAsB64
student.submissions.getCodeAsB64
problem_id | string |
submission_id | string |
student.submissions.getCodeMetrics
student.submissions.getCodeMetrics
See https://github.com/jutge-org/jutge-code-metrics for details.
problem_id | string |
submission_id | string |
student.submissions.getAwards
student.submissions.getAwards
problem_id | string |
submission_id | string |
student.submissions.getAnalysis
student.submissions.getAnalysis
problem_id | string |
submission_id | string |
SubmissionAnalysis
student.submissions.getTestcaseAnalysis
student.submissions.getTestcaseAnalysis
problem_id | string |
submission_id | string |
testcase | string |
TestcaseAnalysis
student.courses
student.courses.indexAvailable
student.courses.indexAvailable
BriefCourse
student.courses.indexEnrolled
student.courses.indexEnrolled
BriefCourse
student.courses.getAvailable
student.courses.getAvailable
Includes owner and lists.
Course
student.courses.getEnrolled
student.courses.getEnrolled
Includes owner and lists.
Course
student.courses.enroll
student.courses.enroll
student.courses.unenroll
student.courses.unenroll
student.lists
student.lists.getAll
student.lists.getAll
BriefList
student.lists.get
student.lists.get
Includes items, owner.
List
student.statuses
student.statuses.getAll
student.statuses.getAll
AbstractStatus
student.statuses.getForAbstractProblem
student.statuses.getForAbstractProblem
AbstractStatus
student.statuses.getForProblem
student.statuses.getForProblem
Status
student.awards
student.awards.getAll
student.awards.getAll
BriefAward
student.awards.get
student.awards.get
Award
instructor.documents
instructor.documents.index
instructor.documents.index
Document
instructor.documents.get
instructor.documents.get
The PDF file is not included in the response.
Document
instructor.documents.getPdf
instructor.documents.getPdf
instructor.documents.create
instructor.documents.create
Document
instructor.documents.update
instructor.documents.update
Document
instructor.documents.remove
instructor.documents.remove
instructor.lists
instructor.lists.index
instructor.lists.index
InstructorBriefList
instructor.lists.get
instructor.lists.get
InstructorList
instructor.lists.create
instructor.lists.create
InstructorList
instructor.lists.update
instructor.lists.update
InstructorList
instructor.lists.remove
instructor.lists.remove
instructor.lists.getArchived
instructor.lists.getArchived
At some point, endpoints related to archiving lists should change as the archive bit will be an attribute of each list.
instructor.lists.archive
instructor.lists.archive
instructor.lists.unarchive
instructor.lists.unarchive
instructor.courses
instructor.courses.index
instructor.courses.index
InstructorBriefCourse
instructor.courses.get
instructor.courses.get
InstructorCourse
instructor.courses.create
instructor.courses.create
Only invited students and tutors are taken into account. Enrolled and pending students and tutors are ignored, as these are managed by the system.
InstructorCourse
instructor.courses.update
instructor.courses.update
Only invited students and tutors are taken into account. Enrolled and pending students and tutors are ignored, as these are managed by the system.
InstructorCourse
instructor.courses.remove
instructor.courses.remove
A course should not be deleted. Ask a system administrator to remove it if you really need it.
instructor.courses.sendInviteToStudents
instructor.courses.sendInviteToStudents
Please do not abuse.
instructor.courses.sendInviteToTutors
instructor.courses.sendInviteToTutors
Please do not abuse.
instructor.courses.getStudentProfiles
instructor.courses.getStudentProfiles
StudentProfile
instructor.courses.getTutorProfiles
instructor.courses.getTutorProfiles
StudentProfile
instructor.courses.getArchived
instructor.courses.getArchived
At some point, endpoints related to archiving courses should change as the archive bit will be an attribute of each course.
instructor.courses.archive
instructor.courses.archive
instructor.courses.unarchive
instructor.courses.unarchive
instructor.exams
instructor.exams.index
instructor.exams.index
InstructorBriefExam
instructor.exams.get
instructor.exams.get
InstructorExam
instructor.exams.getDocuments
instructor.exams.getDocuments
InstructorExamDocument
instructor.exams.getProblems
instructor.exams.getProblems
InstructorExamProblem
instructor.exams.getStudents
instructor.exams.getStudents
InstructorExamStudent
instructor.exams.getStudent
instructor.exams.getStudent
exam_nm | string |
string |
InstructorExamStudent
instructor.exams.getSubmissions
instructor.exams.getSubmissions
This endpoint prepares a ZIP file to download the submissions of an exam. Preparing the ZIP file takes some time, an href link to the ZIP will be returned. This ZIP file will be available for download for a limited time.
exam_nm | string |
options | InstructorExamSubmissionsOptions |
Pack
instructor.exams.getStatistics
instructor.exams.getStatistics
ExamStatistics
instructor.exams.create
instructor.exams.create
InstructorExamCreation
instructor.exams.update
instructor.exams.update
InstructorExamUpdate
instructor.exams.updateDocuments
instructor.exams.updateDocuments
exam_nm | string |
document_nms | array of string |
instructor.exams.updateCompilers
instructor.exams.updateCompilers
exam_nm | string |
compiler_ids | array of string |
instructor.exams.updateProblems
instructor.exams.updateProblems
exam_nm | string |
problems | array of InstructorExamProblem |
instructor.exams.updateStudents
instructor.exams.updateStudents
exam_nm | string |
students | array of InstructorExamStudent |
instructor.exams.addStudents
instructor.exams.addStudents
exam_nm | string |
students | array of InstructorExamStudent |
instructor.exams.removeStudents
instructor.exams.removeStudents
exam_nm | string |
emails | array of string |
instructor.exams.remove
instructor.exams.remove
Note: An exam can only be deleted if it has not started.
instructor.exams.getArchived
instructor.exams.getArchived
At some point, endpoints related to archiving exams should change as the archive bit will be an attribute of each exam.
instructor.exams.archive
instructor.exams.archive
instructor.exams.unarchive
instructor.exams.unarchive
instructor.exams.getRanking
instructor.exams.getRanking
Under development.
Ranking
instructor.problems
instructor.problems.getOwnProblems
instructor.problems.getOwnProblems
instructor.problems.getPasscode
instructor.problems.getPasscode
Returns an empty string if the problem has no passcode.
instructor.problems.setPasscode
instructor.problems.setPasscode
The passcode must be at least 8 characters long and contain only alphanumeric characters. The passcode will be stored in the database in plain text.
problem_nm | string |
passcode | string |
instructor.problems.removePasscode
instructor.problems.removePasscode
instructor.problems.sharePasscode
instructor.problems.sharePasscode
No emails are sent. Emails that are not registered in the system are ignored.
problem_nm | string |
emails | array of string |
instructor.problems.deprecate
instructor.problems.deprecate
problem_nm | string |
reason | string |
instructor.problems.undeprecate
instructor.problems.undeprecate
instructor.problems.download
instructor.problems.download
Quick and dirty implementation, should be improved. Returns a ZIP file with the abstract problem and all its problems.
instructor.problems.legacyCreate
instructor.problems.legacyCreate
At some point, this endpoint will be deprecated. It is a bit slow (about one minute). Returns the problem_nm of the new problem. Does not provide any feedback.
instructor.problems.legacyUpdate
instructor.problems.legacyUpdate
At some point, this endpoint will be deprecated. It is a bit slow (about one minute). Does not provide any feedback.
instructor.queries
instructor.queries.getCourseProblemSubmissions
instructor.queries.getCourseProblemSubmissions
Returns a list of submissions for a given problem for all students of a given course. Each submission includes the email, time, problem name, problem id, verdict, and IP address. The list is ordered by email and time. Known as ricard01 in the past.
course_nm | string |
problem_nm | string |
SubmissionsQuery
instructor.queries.getCourseListSubmissions
instructor.queries.getCourseListSubmissions
Returns a list of submissions for all problems in a given list for all students of a given course. Each submission includes the email, time, problem name, problem id, verdict, and IP address. The list is ordered by email, problem id and time. Known as ricard02 in the past.
course_nm | string |
list_nm | string |
SubmissionsQuery
admin.instructors
admin.instructors.get
admin.instructors.get
InstructorEntries
admin.instructors.add
admin.instructors.add
string | |
username | string |
admin.instructors.remove
admin.instructors.remove
admin.users
admin.users.count
admin.users.count
admin.users.create
admin.users.create
UserCreation
admin.users.remove
admin.users.remove
admin.users.setPassword
admin.users.setPassword
string | |
password | string |
message | string |
admin.users.getAllWithEmail
admin.users.getAllWithEmail
UsersEmailsAndNames
admin.users.getSpamUsers
admin.users.getSpamUsers
admin.users.removeSpamUsers
admin.users.removeSpamUsers
admin.dashboard
admin.dashboard.getAll
admin.dashboard.getAll
AdminDashboard
admin.dashboard.getFreeDiskSpace
admin.dashboard.getFreeDiskSpace
FreeDiskSpace
admin.dashboard.getRecentConnectedUsers
admin.dashboard.getRecentConnectedUsers
RecentConnectedUsers
admin.dashboard.getRecentLoadAverages
admin.dashboard.getRecentLoadAverages
RecentLoadAverages
admin.dashboard.getRecentSubmissions
admin.dashboard.getRecentSubmissions
RecentSubmissions
admin.dashboard.getSubmissionsHistograms
admin.dashboard.getSubmissionsHistograms
SubmissionsHistograms
admin.dashboard.getZombies
admin.dashboard.getZombies
Zombies
admin.dashboard.getUpcomingExams
admin.dashboard.getUpcomingExams
daysBefore | integer |
daysAfter | integer |
UpcomingExams
admin.queue
admin.queue.getQueue
admin.queue.getQueue
SubmissionQueueItems
admin.queue.getQueueZombies
admin.queue.getQueueZombies
SubmissionQueueItems
admin.queue.getQueueFatals
admin.queue.getQueueFatals
SubmissionQueueItems
admin.queue.getQueueSetterErrors
admin.queue.getQueueSetterErrors
SubmissionQueueItems
admin.tasks
admin.tasks.purgeAuthTokens
admin.tasks.purgeAuthTokens
Purge expired access tokens (call it from time to time, it does not hurt)
admin.tasks.clearCaches
admin.tasks.clearCaches
admin.tasks.fatalizeIEs
admin.tasks.fatalizeIEs
admin.tasks.fatalizePendings
admin.tasks.fatalizePendings
admin.tasks.resubmitIEs
admin.tasks.resubmitIEs
admin.tasks.resubmitPendings
admin.tasks.resubmitPendings
admin.stats
admin.stats.getCounters
admin.stats.getCounters
admin.stats.getDistributionOfVerdicts
admin.stats.getDistributionOfVerdicts
admin.stats.getDistributionOfVerdictsByYear
admin.stats.getDistributionOfVerdictsByYear
admin.stats.getDistributionOfCompilers
admin.stats.getDistributionOfCompilers
admin.stats.getDistributionOfProglangs
admin.stats.getDistributionOfProglangs
admin.stats.getDistributionOfUsersByYear
admin.stats.getDistributionOfUsersByYear
admin.stats.getDistributionOfUsersByCountry
admin.stats.getDistributionOfUsersByCountry
admin.stats.getDistributionOfUsersBySubmissions
admin.stats.getDistributionOfUsersBySubmissions
admin.stats.getRankingOfUsers
admin.stats.getRankingOfUsers
UserRanking
admin.stats.getDistributionOfSubmissionsByHour
admin.stats.getDistributionOfSubmissionsByHour
admin.stats.getDistributionOfSubmissionsByProglang
admin.stats.getDistributionOfSubmissionsByProglang
admin.stats.getDistributionOfSubmissionsByCompiler
admin.stats.getDistributionOfSubmissionsByCompiler
admin.stats.getDistributionOfSubmissionsByWeekday
admin.stats.getDistributionOfSubmissionsByWeekday
admin.stats.getDistributionOfSubmissionsByYear
admin.stats.getDistributionOfSubmissionsByYear
admin.stats.getDistributionOfSubmissionsByYearForProglang
admin.stats.getDistributionOfSubmissionsByYearForProglang
admin.stats.getDistributionOfSubmissionsByDay
admin.stats.getDistributionOfSubmissionsByDay
admin.stats.getHeatmapCalendarOfSubmissions
admin.stats.getHeatmapCalendarOfSubmissions
DateRange
admin.stats.getDistributionOfDomains
admin.stats.getDistributionOfDomains
admin.problems
admin.problems.getSolutions
admin.problems.getSolutions
admin.problems.getSolutionAsB64
admin.problems.getSolutionAsB64
problem_id | string |
proglang | string |
admin.problems.getSolutionAsFile
admin.problems.getSolutionAsFile
problem_id | string |
proglang | string |
testing.check
testing.check.checkUser
testing.check.checkUser
testing.check.checkInstructor
testing.check.checkInstructor
testing.check.checkAdmin
testing.check.checkAdmin
testing.check.throwError
testing.check.throwError
testing.playground
testing.playground.upload
testing.playground.upload
Name
testing.playground.negate
testing.playground.negate
testing.playground.download
testing.playground.download
Name
testing.playground.download2
testing.playground.download2
Name
testing.playground.ping
testing.playground.ping
testing.playground.toUpperCase
testing.playground.toUpperCase
testing.playground.add2i
testing.playground.add2i
TwoInts
testing.playground.add2f
testing.playground.add2f
TwoFloats
testing.playground.inc
testing.playground.inc
TwoInts
TwoInts
testing.playground.add3i
testing.playground.add3i
a | integer |
b | integer |
c | integer |
testing.playground.something
testing.playground.something
SomeType
SomeType