summaryrefslogtreecommitdiff
path: root/web-server/opendc/api/v2/simulations/simulationId/topologies/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/simulations/simulationId/topologies/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/simulations/simulationId/topologies/endpoint.py')
-rw-r--r--web-server/opendc/api/v2/simulations/simulationId/topologies/endpoint.py29
1 files changed, 29 insertions, 0 deletions
diff --git a/web-server/opendc/api/v2/simulations/simulationId/topologies/endpoint.py b/web-server/opendc/api/v2/simulations/simulationId/topologies/endpoint.py
new file mode 100644
index 00000000..ab7b7006
--- /dev/null
+++ b/web-server/opendc/api/v2/simulations/simulationId/topologies/endpoint.py
@@ -0,0 +1,29 @@
+from datetime import datetime
+
+from opendc.models.simulation import Simulation
+from opendc.models.topology import Topology
+from opendc.util import exceptions
+from opendc.util.rest import Response
+from opendc.util.database import Database
+
+
+def POST(request):
+ """Add a new Topology to the specified simulation and return it"""
+
+ request.check_required_parameters(path={'simulationId': 'string'}, body={'topology': {'name': 'string'}})
+
+ simulation = Simulation.from_id(request.params_path['simulationId'])
+
+ simulation.check_exists()
+ simulation.check_user_access(request.google_id, True)
+
+ topology = Topology({'name': request.params_body['topology']['name']})
+ topology.set_property('datetimeCreated', Database.datetime_to_string(datetime.now()))
+ topology.set_property('datetimeLastEdited', Database.datetime_to_string(datetime.now()))
+ topology.insert()
+
+ simulation.obj['topologyIds'].append(topology.obj['_id'])
+ simulation.set_property('datetimeLastEdited', Database.datetime_to_string(datetime.now()))
+ simulation.update()
+
+ return Response(200, 'Successfully inserted topology.', topology.obj)