summaryrefslogtreecommitdiff
path: root/opendc/api/v2/topologies/topologyId
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 /opendc/api/v2/topologies/topologyId
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 'opendc/api/v2/topologies/topologyId')
-rw-r--r--opendc/api/v2/topologies/topologyId/__init__.py0
-rw-r--r--opendc/api/v2/topologies/topologyId/endpoint.py16
-rw-r--r--opendc/api/v2/topologies/topologyId/rooms/__init__.py0
-rw-r--r--opendc/api/v2/topologies/topologyId/rooms/endpoint.py93
-rw-r--r--opendc/api/v2/topologies/topologyId/test_endpoint.py46
5 files changed, 0 insertions, 155 deletions
diff --git a/opendc/api/v2/topologies/topologyId/__init__.py b/opendc/api/v2/topologies/topologyId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v2/topologies/topologyId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v2/topologies/topologyId/endpoint.py b/opendc/api/v2/topologies/topologyId/endpoint.py
deleted file mode 100644
index 6c6ab9c2..00000000
--- a/opendc/api/v2/topologies/topologyId/endpoint.py
+++ /dev/null
@@ -1,16 +0,0 @@
-from opendc.models.topology import Topology
-from opendc.util import exceptions
-from opendc.util.rest import Response
-
-
-def GET(request):
- """Get this Topology."""
-
- request.check_required_parameters(path={'topologyId': 'int'})
-
- topology = Topology.from_id(request.params_path['topologyId'])
-
- topology.check_exists()
- topology.check_user_access(request.google_id, False)
-
- return Response(200, 'Successfully retrieved topology.', topology.obj)
diff --git a/opendc/api/v2/topologies/topologyId/rooms/__init__.py b/opendc/api/v2/topologies/topologyId/rooms/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v2/topologies/topologyId/rooms/__init__.py
+++ /dev/null
diff --git a/opendc/api/v2/topologies/topologyId/rooms/endpoint.py b/opendc/api/v2/topologies/topologyId/rooms/endpoint.py
deleted file mode 100644
index 96ee7028..00000000
--- a/opendc/api/v2/topologies/topologyId/rooms/endpoint.py
+++ /dev/null
@@ -1,93 +0,0 @@
-from opendc.models_old.datacenter import Datacenter
-from opendc.models_old.room import Room
-from opendc.util import exceptions
-from opendc.util.rest import Response
-
-
-def GET(request):
- """Get this Datacenter's Rooms."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(path={'datacenterId': 'int'})
- except exceptions.ParameterError as e:
- return Response(400, str(e))
-
- # Instantiate a Datacenter from the database
-
- datacenter = Datacenter.from_primary_key((request.params_path['datacenterId'], ))
-
- # Make sure this Datacenter exists
-
- if not datacenter.exists():
- return Response(404, '{} not found.'.format(datacenter))
-
- # Make sure this user is authorized to view this Datacenter's Rooms
-
- if not datacenter.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Rooms for {}.'.format(datacenter))
-
- # Get and return the Rooms
-
- rooms = Room.query('datacenter_id', datacenter.id)
-
- return Response(200, 'Successfully retrieved Rooms for {}.'.format(datacenter), [x.to_JSON() for x in rooms])
-
-
-def POST(request):
- """Add a Room."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(path={'datacenterId': 'int'},
- body={'room': {
- 'id': 'int',
- 'datacenterId': 'int',
- 'roomType': 'string'
- }})
- except exceptions.ParameterError as e:
- return Response(400, str(e))
-
- # Make sure the passed object's datacenter id matches the path datacenter id
-
- if request.params_path['datacenterId'] != request.params_body['room']['datacenterId']:
- return Response(400, 'ID mismatch.')
-
- # Instantiate a Datacenter from the database
-
- datacenter = Datacenter.from_primary_key((request.params_path['datacenterId'], ))
-
- # Make sure this Datacenter exists
-
- if not datacenter.exists():
- return Response(404, '{} not found.'.format(datacenter))
-
- # Make sure this user is authorized to edit this Datacenter's Rooms
-
- if not datacenter.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from adding a Room to {}.'.format(datacenter))
-
- # Add a name if not provided
-
- if 'name' not in request.params_body['room']:
- room_count = len(Room.query('datacenter_id', datacenter.id))
- request.params_body['room']['name'] = 'Room {}'.format(room_count)
-
- # Instantiate a Room
-
- room = Room.from_JSON(request.params_body['room'])
-
- # Try to insert this Room
-
- try:
- room.insert()
- except:
- return Response(400, 'Invalid `roomType` or existing `name`.')
-
- # Return this Room
-
- room.read()
-
- return Response(200, 'Successfully added {}.'.format(room), room.to_JSON())
diff --git a/opendc/api/v2/topologies/topologyId/test_endpoint.py b/opendc/api/v2/topologies/topologyId/test_endpoint.py
deleted file mode 100644
index e54052aa..00000000
--- a/opendc/api/v2/topologies/topologyId/test_endpoint.py
+++ /dev/null
@@ -1,46 +0,0 @@
-from opendc.util.database import DB
-
-'''
-GET /topologies/{topologyId}
-'''
-
-def test_get_topology(client, mocker):
- mocker.patch.object(DB, 'fetch_one', return_value={
- '_id': '1',
- 'authorizations': [{
- 'topologyId': '1',
- 'authorizationLevel': 'EDIT'
- }]
- })
- res = client.get('/api/v2/topologies/1')
- assert '200' in res.status
-
-def test_get_topology_non_existing(client, mocker):
- mocker.patch.object(DB, 'fetch_one', return_value=None)
- assert '404' in client.get('/api/v2/topologies/1').status
-
-def test_get_topology_not_authorized(client, mocker):
- mocker.patch.object(DB, 'fetch_one', return_value={
- '_id': '1',
- 'authorizations': [{
- 'topologyId': '2',
- 'authorizationLevel': 'OWN'
- }]
- })
- res = client.get('/api/v2/topologies/1')
- assert '403' in res.status
-
-def test_get_topology_no_authorizations(client, mocker):
- mocker.patch.object(DB, 'fetch_one', return_value={'authorizations': []})
- res = client.get('/api/v2/topologies/1')
- assert '403' in res.status
-
-
-'''
-PUT /topologies/{topologyId}
-'''
-
-
-'''
-DELETE /topologies/{topologyId}
-''' \ No newline at end of file