summaryrefslogtreecommitdiff
path: root/web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py
diff options
context:
space:
mode:
authorGeorgios Andreadis <info@gandreadis.com>2020-06-29 16:05:23 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2020-08-24 16:18:36 +0200
commit4f9a40abdc7836345113c047f27fcc96800cb3f5 (patch)
treee443d14e34a884b1a4d9c549f81d51202eddd5f7 /web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py
parentcd5f7bf3a72913e1602cb4c575e61ac7d5519be0 (diff)
Prepare web-server repository for monorepo
This change prepares the web-server Git repository for the monorepo residing at https://github.com/atlarge-research.com/opendc. To accomodate for this, we move all files into a web-server subdirectory.
Diffstat (limited to 'web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py')
-rw-r--r--web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py42
1 files changed, 42 insertions, 0 deletions
diff --git a/web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py b/web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py
new file mode 100644
index 00000000..db3f8b14
--- /dev/null
+++ b/web-server/opendc/api/v2/experiments/experimentId/room-states/endpoint.py
@@ -0,0 +1,42 @@
+from opendc.models_old.experiment import Experiment
+from opendc.models_old.room_state import RoomState
+from opendc.util import exceptions
+from opendc.util.rest import Response
+
+
+def GET(request):
+ """Get this Experiment's Room States."""
+
+ # Make sure required parameters are there
+
+ try:
+ request.check_required_parameters(path={'experimentId': 'int'})
+
+ except exceptions.ParameterError as e:
+ return Response(400, str(e))
+
+ # Instantiate an Experiment from the database
+
+ experiment = Experiment.from_primary_key((request.params_path['experimentId'], ))
+
+ # Make sure this Experiment exists
+
+ if not experiment.exists():
+ return Response(404, '{} not found.'.format(experiment))
+
+ # Make sure this user is authorized to view this Experiment's Room States
+
+ if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
+ return Response(403, 'Forbidden from viewing Room States for {}.'.format(experiment))
+
+ # Get and return the Room States
+
+ if 'tick' in request.params_query:
+ room_states = RoomState.from_experiment_id_and_tick(request.params_path['experimentId'],
+ request.params_query['tick'])
+
+ else:
+ room_states = RoomState.from_experiment_id(request.params_path['experimentId'])
+
+ return Response(200, 'Successfully retrieved Room States for {}.'.format(experiment),
+ [x.to_JSON() for x in room_states])