summaryrefslogtreecommitdiff
path: root/opendc/api/v2/jobs
diff options
context:
space:
mode:
authorGeorgios Andreadis <info@gandreadis.com>2020-06-23 18:08:28 +0200
committerGeorgios Andreadis <info@gandreadis.com>2020-06-23 18:08:28 +0200
commit565ede0dc50c3b2df09c066ea3a28a4901cce547 (patch)
treee81a1bbed43d2eaf7e2be0bc61007963f807b62d /opendc/api/v2/jobs
parent6f41be7d9c244b67bfa5ff72f1e90d18fa45b590 (diff)
Add DB handlers and rename to v2
Diffstat (limited to 'opendc/api/v2/jobs')
-rw-r--r--opendc/api/v2/jobs/__init__.py0
-rw-r--r--opendc/api/v2/jobs/jobId/__init__.py0
-rw-r--r--opendc/api/v2/jobs/jobId/endpoint.py34
-rw-r--r--opendc/api/v2/jobs/jobId/tasks/__init__.py0
-rw-r--r--opendc/api/v2/jobs/jobId/tasks/endpoint.py37
5 files changed, 71 insertions, 0 deletions
diff --git a/opendc/api/v2/jobs/__init__.py b/opendc/api/v2/jobs/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v2/jobs/__init__.py
diff --git a/opendc/api/v2/jobs/jobId/__init__.py b/opendc/api/v2/jobs/jobId/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v2/jobs/jobId/__init__.py
diff --git a/opendc/api/v2/jobs/jobId/endpoint.py b/opendc/api/v2/jobs/jobId/endpoint.py
new file mode 100644
index 00000000..da4dcd9d
--- /dev/null
+++ b/opendc/api/v2/jobs/jobId/endpoint.py
@@ -0,0 +1,34 @@
+from opendc.models.job import Job
+from opendc.util import exceptions
+from opendc.util.rest import Response
+
+
+def GET(request):
+ """Get this Job."""
+
+ # Make sure required parameters are there
+
+ try:
+ request.check_required_parameters(
+ path={
+ 'jobId': 'int'
+ }
+ )
+
+ except exceptions.ParameterError as e:
+ return Response(400, e.message)
+
+ # Instantiate a Job and make sure it exists
+
+ job = Job.from_primary_key((request.params_path['jobId'],))
+
+ if not job.exists():
+ return Response(404, '{} not found.'.format(job))
+
+ # Return this Job
+
+ return Response(
+ 200,
+ 'Successfully retrieved {}.'.format(job),
+ job.to_JSON()
+ )
diff --git a/opendc/api/v2/jobs/jobId/tasks/__init__.py b/opendc/api/v2/jobs/jobId/tasks/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v2/jobs/jobId/tasks/__init__.py
diff --git a/opendc/api/v2/jobs/jobId/tasks/endpoint.py b/opendc/api/v2/jobs/jobId/tasks/endpoint.py
new file mode 100644
index 00000000..04ac5b8c
--- /dev/null
+++ b/opendc/api/v2/jobs/jobId/tasks/endpoint.py
@@ -0,0 +1,37 @@
+from opendc.models.job import Job
+from opendc.models.task import Task
+from opendc.util import exceptions
+from opendc.util.rest import Response
+
+
+def GET(request):
+ """Get this Job's Tasks."""
+
+ # Make sure required parameters are there
+
+ try:
+ request.check_required_parameters(
+ path={
+ 'jobId': 'int'
+ }
+ )
+
+ except exceptions.ParameterError as e:
+ return Response(400, e.message)
+
+ # Instantiate a Job and make sure it exists
+
+ job = Job.from_primary_key((request.params_path['jobId'],))
+
+ if not job.exists():
+ return Response(404, '{} not found.'.format(job))
+
+ # Get and return the Tasks
+
+ tasks = Task.query('job_id', request.params_path['jobId'])
+
+ return Response(
+ 200,
+ 'Successfully retrieved Tasks for {}.'.format(job),
+ [x.to_JSON() for x in tasks]
+ )