summaryrefslogtreecommitdiff
path: root/opendc/api/v1/simulations/simulationId
diff options
context:
space:
mode:
authorGeorgios Andreadis <g.andreadis@student.tudelft.nl>2017-08-13 23:12:16 +0300
committerGeorgios Andreadis <g.andreadis@student.tudelft.nl>2017-08-13 23:12:16 +0300
commitf589682b0840aab0624122052eb863cf8dc3a0b9 (patch)
treeea97449f7a83b7f911aa196976266551f834fc9d /opendc/api/v1/simulations/simulationId
parentdb460a0e734f9f1cf60088f63a3c05eaed255074 (diff)
Convert API codebase to flat model
Diffstat (limited to 'opendc/api/v1/simulations/simulationId')
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/endpoint.py43
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/endpoint.py111
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/endpoint.py140
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/endpoint.py123
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/endpoint.py89
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/endpoint.py245
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/endpoint.py122
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/endpoint.py170
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/endpoint.py138
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/endpoint.py39
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/endpoint.py51
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/endpoint.py51
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/endpoint.py51
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/endpoint.py44
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/endpoint.py51
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/branches/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/branches/endpoint.py166
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/endpoint.py44
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/sections/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/sections/endpoint.py43
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/__init__.py0
-rw-r--r--opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/endpoint.py44
39 files changed, 0 insertions, 1765 deletions
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/endpoint.py
deleted file mode 100644
index c9c78a8a..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/endpoint.py
+++ /dev/null
@@ -1,43 +0,0 @@
-from opendc.models.datacenter import Datacenter
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Datacenter."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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
-
- if not datacenter.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(datacenter))
-
- # Return this Datacenter
-
- datacenter.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(datacenter),
- datacenter.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/endpoint.py
deleted file mode 100644
index 1127ce95..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/endpoint.py
+++ /dev/null
@@ -1,111 +0,0 @@
-from opendc.models.room import Room
-from opendc.models.datacenter import Datacenter
-from opendc.util import database, 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 = {
- 'simulationId': 'int',
- 'datacenterId': 'int'
- }
- )
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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 = {
- 'simulationId': 'int',
- 'datacenterId': 'int'
- },
- body = {
- 'room': {
- 'id': 'int',
- 'datacenterId': 'int',
- 'roomType': 'string'
- }
- }
- )
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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 not 'name' 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 Exception as e:
- 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/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/endpoint.py
deleted file mode 100644
index 44ed82d6..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/endpoint.py
+++ /dev/null
@@ -1,140 +0,0 @@
-from opendc.models.room import Room
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Room."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Room from the database
-
- room = Room.from_primary_key((request.params_path['roomId'],))
-
- # Make sure this Room exists
-
- if not room.exists():
- return Response(404, '{} not found.'.format(room))
-
- # Make sure this user is authorized to view this Room
-
- if not room.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(room))
-
- # Return this Room
-
- room.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(room),
- room.to_JSON()
- )
-
-def PUT(request):
- """Update this Room's name and type."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int'
- },
- body = {
- 'room': {
- 'name': 'string',
- 'roomType': 'string'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Room from the database
-
- room = Room.from_primary_key((request.params_path['roomId'],))
-
- # Make sure this Room exists
-
- if not room.exists():
- return Response(404, '{} not found.'.format(room))
-
- # Make sure this user is authorized to edit this Room
-
- if not room.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from updating {}.'.format(room))
-
- # Update this Room
-
- room.name = request.params_body['room']['name']
- room.type = request.params_body['room']['roomType']
-
- try:
- room.update()
- except exceptions.ForeignKeyError:
- return Response(400, 'Invalid `roomType` or existing `name`.')
-
- # Return this Room
-
- return Response(
- 200,
- 'Successfully updated {}.'.format(room),
- room.to_JSON()
- )
-
-def DELETE(request):
- """Delete this Room."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Room and make sure it exists
-
- room = Room.from_primary_key((request.params_path['roomId'],))
-
- if not room.exists():
- return Response(404, '{} not found.'.format(room))
-
- # Make sure this user is authorized to delete this Room
-
- if not room.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from deleting {}.'.format(room))
-
- # Delete this Room
-
- room.delete()
-
- # Return this Room
-
- return Response(
- 200,
- 'Sucessfully deleted {}.'.format(room),
- room.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/endpoint.py
deleted file mode 100644
index f615a6d4..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/endpoint.py
+++ /dev/null
@@ -1,123 +0,0 @@
-from opendc.models.tile import Tile
-from opendc.models.room import Room
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Room's Tiles."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Room from the database
-
- room = Room.from_primary_key((request.params_path['roomId'],))
-
- # Make sure this Room exists
-
- if not room.exists():
- return Response(404, '{} not found.'.format(room))
-
- # Make sure this user is authorized to view this Room's Tiles
-
- if not room.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Tiles for {}.'.format(room))
-
- # Get and return the Tiles
-
- tiles = Tile.query('room_id', room.id)
-
- for tile in tiles:
- tile.read()
-
- return Response(
- 200,
- 'Successfully retrieved Tiles for {}.'.format(room),
- [x.to_JSON() for x in tiles]
- )
-
-def POST(request):
- """Add a Tile."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int'
- },
- body = {
- 'tile': {
- 'roomId': 'int',
- 'positionX': 'int',
- 'positionY': 'int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- if request.params_path['roomId'] != request.params_body['tile']['roomId']:
- return Response(400, 'ID mismatch')
-
- # Instantiate a Room from the database
-
- room = Room.from_primary_key((request.params_path['roomId'],))
-
- # Make sure this Room exists
-
- if not room.exists():
- return Response(404, '{} not found.'.format(room))
-
- # Make sure this user is authorized to edit this Room's Tiles
-
- if not room.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from adding Tiles to {}.'.format(room))
-
- # Clean the tile JSON
-
- tile_json = request.params_body['tile']
-
- tile_json['objectId'] = None
- tile_json['objectType'] = None
-
- # Instantiate a Tile
-
- tile = Tile.from_JSON(tile_json)
-
- # Try to insert this Tile
-
- try:
- tile.insert()
-
- except exceptions.ForeignKeyError as e:
-
- if e.message == 'OccupiedTilePosition':
- return Response(409, 'Tile position occupied.')
-
- elif e.message == 'InvalidTilePosition':
- return Response(400, 'Invalid Tile position (new Tiles must neighbor existing Tiles).')
-
- # Return this Tile
-
- tile.read()
-
- return Response(
- 200,
- 'Successfully added {}.'.format(tile),
- tile.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/endpoint.py
deleted file mode 100644
index b15a10f7..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/endpoint.py
+++ /dev/null
@@ -1,89 +0,0 @@
-from opendc.models.tile import Tile
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Tile."""
-
- # Make sure request parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to view this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(tile))
-
- # Return this Tile
-
- tile.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(tile),
- tile.to_JSON()
- )
-
-def DELETE(request):
- """Delete this Tile."""
-
- # Make sure request parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to edit this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from deleting {}.'.format(tile))
-
- # Delete this Tile
-
- tile.delete()
-
- # Return this Tile
-
- return Response(
- 200,
- 'Successfully deleted {}.'.format(tile),
- tile.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/endpoint.py
deleted file mode 100644
index d9fb1959..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/endpoint.py
+++ /dev/null
@@ -1,245 +0,0 @@
-from opendc.models.rack import Rack
-from opendc.models.tile import Tile
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Tile's Rack."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- },
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to view this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from editing {}'.format(tile))
-
- # Instantiate a Rack from the database
-
- rack = Rack.from_primary_key((tile.object_id,))
-
- # Make sure this Rack exists
-
- if not rack.exists():
- return Response(404, '{} not found'.format(rack))
-
- # Return the Rack
-
- rack.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(rack),
- rack.to_JSON()
- )
-
-def POST(request):
- """Add a Rack to this Tile if it is empty."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- },
- body = {
- 'rack': {
- 'name': 'string',
- 'capacity': 'int',
- 'powerCapacityW': 'int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to edit this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from editing {}'.format(tile))
-
- # Make sure this Tile isn't occupied
-
- if tile.object_id is not None:
- return Response(409, '{} occupied.'.format(tile))
-
- # Instantiate a Rack and insert it into the database
-
- rack = Rack.from_JSON(request.params_body['rack'])
- rack.insert()
-
- # Try to add this Rack to this Tile
-
- tile.object_id = rack.id
- tile.object_type = 'RACK'
- tile.update()
-
- # Return this Rack
-
- rack.read()
-
- return Response(
- 200,
- 'Successfully added {}.'.format(rack),
- rack.to_JSON()
- )
-
-def PUT(request):
- """Update the Rack on this Tile."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- },
- body = {
- 'rack': {
- 'name': 'string',
- 'capacity': 'int',
- 'powerCapacityW': 'int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to edit this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from editing {}'.format(tile))
-
- # Instantiate a Rack from the database
-
- rack = Rack.from_primary_key((tile.object_id,))
-
- # Make sure this Rack exists
-
- if not rack.exists():
- return Response(404, '{} not found'.format(rack))
-
- # Update this Rack
-
- rack.name = request.params_body['rack']['name']
- rack.capacity = request.params_body['rack']['capacity']
-
- rack.update()
-
- # Return this Rack
-
- rack.read()
-
- return Response(
- 200,
- 'Successfully updated {}.'.format(rack),
- rack.to_JSON()
- )
-
-def DELETE(request):
- """Delete this Tile's Rack."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- },
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Tile from the database
-
- tile = Tile.from_primary_key((request.params_path['tileId'],))
-
- # Make sure this Tile exists
-
- if not tile.exists():
- return Response(404, '{} not found.'.format(tile))
-
- # Make sure this user is authorized to edit this Tile
-
- if not tile.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from editing {}'.format(tile))
-
- # Instantiate a Rack from the database
-
- rack = Rack.from_primary_key((tile.object_id,))
-
- # Make sure this Rack exists
-
- if not rack.exists():
- return Response(404, '{} not found'.format(rack))
-
- # Remove this Rack from this Tile
-
- tile.object_id = None
- tile.object_type = None
-
- tile.update()
-
- # Delete this Rack
-
- rack.delete()
-
- # Return this Rack
-
- return Response(
- 200,
- 'Successfully deleted {}.'.format(rack),
- rack.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/endpoint.py
deleted file mode 100644
index a67bb1c3..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/endpoint.py
+++ /dev/null
@@ -1,122 +0,0 @@
-from opendc.models.machine import Machine
-from opendc.models.rack import Rack
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Rack's Machines."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Rack from the database
-
- rack = Rack.from_tile_id(request.params_path['tileId'])
-
- # Make sure this Rack exists
-
- if not rack.exists():
- return Response(404, '{} not found.'.format(rack))
-
- # Make sure this user is authorized to view this Rack's Machines
-
- if not rack.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing {}.'.format(rack))
-
- # Get and return the Machines
-
- machines = Machine.query('rack_id', rack.id)
-
- for machine in machines:
- machine.read()
-
- return Response(
- 200,
- 'Successfully retrieved Machines for {}.'.format(rack),
- [x.to_JSON() for x in machines]
- )
-
-def POST(request):
- """Add a Machine to this rack."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int'
- },
- body = {
- 'machine': {
- 'rackId': 'int',
- 'position': 'int',
- 'tags': 'list-string',
- 'cpuIds': 'list-int',
- 'gpuIds': 'list-int',
- 'memoryIds': 'list-int',
- 'storageIds': 'list-int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Rack from the database
-
- rack = Rack.from_tile_id(request.params_path['tileId'])
-
- # Make sure this Rack exists
-
- if not rack.exists():
- return Response(404, '{} not found.'.format(rack))
-
- # Make sure this Rack's ID matches the given rack ID
-
- if rack.id != request.params_body['machine']['rackId']:
- return Response(400, 'Rack ID in `machine` and path do not match.')
-
- # Make sure this user is authorized to edit this Rack's Machines
-
- if not rack.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing {}.'.format(rack))
-
- # Instantiate a Machine
-
- machine = Machine.from_JSON(request.params_body['machine'])
-
- # Try to insert this Machine
-
- try:
- machine.insert()
-
- except exceptions.ForeignKeyError:
- return Response(409, 'Rack position occupied.')
-
- except:
- return Response(400, 'Invalid Machine.')
-
- # Return this Machine
-
- machine.read()
-
- return Response(
- 200,
- 'Successfully added {}.'.format(machine),
- machine.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/__init__.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/endpoint.py b/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/endpoint.py
deleted file mode 100644
index e33da5d6..00000000
--- a/opendc/api/v1/simulations/simulationId/datacenters/datacenterId/rooms/roomId/tiles/tileId/rack/machines/position/endpoint.py
+++ /dev/null
@@ -1,170 +0,0 @@
-from opendc.models.machine import Machine
-from opendc.models.rack import Rack
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get the Machine at this location in this Rack."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int',
- 'position': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Machine from the database
-
- machine = Machine.from_tile_id_and_rack_position(request.params_path['tileId'], request.params_path['position'])
-
- # Make sure this Machine exists
-
- if not machine.exists():
- return Response(404, '{} not found.'.format(machine))
-
- # Make sure this user is authorized to view this Machine
-
- if not machine.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(machine))
-
- # Return this Machine
-
- machine.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(machine),
- machine.to_JSON()
- )
-
-def PUT(request):
- """Update the Machine at this location in this Rack."""
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int',
- 'position': 'int'
- },
- body = {
- 'machine': {
- 'rackId': 'int',
- 'position': 'int',
- 'tags': 'list-string',
- 'cpuIds': 'list-int',
- 'gpuIds': 'list-int',
- 'memoryIds': 'list-int',
- 'storageIds': 'list-int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Machine from the database
-
- machine = Machine.from_tile_id_and_rack_position(request.params_path['tileId'], request.params_path['position'])
-
- # Make sure this Machine exists
-
- if not machine.exists():
- return Response(404, '{} not found.'.format(machine))
-
- # Make sure this Machine's rack ID is right
-
- rack = Rack.from_tile_id(request.params_path['tileId'])
-
- if not rack.exists() or rack.id != request.params_body['machine']['rackId']:
- return Response(400, 'Mismatch in Rack IDs.')
-
- # Make sure this user is authorized to edit this Machine
-
- if not machine.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from retrieving {}.'.format(machine))
-
- # Update this Machine
-
- machine.positoin = request.params_body['machine']['position']
- machine.tags = request.params_body['machine']['tags']
- machine.cpu_ids = request.params_body['machine']['cpuIds']
- machine.gpu_ids = request.params_body['machine']['gpuIds']
- machine.memory_ids = request.params_body['machine']['memoryIds']
- machine.storage_ids = request.params_body['machine']['storageIds']
-
- try:
- machine.update()
-
- except exceptions.ForeignKeyError:
- return Response(409, 'Rack position occupied.')
-
- except Exception as e:
- print e
- return Response(400, 'Invalid Machine.')
-
- # Return this Machine
-
- machine.read()
-
- return Response(
- 200,
- 'Successfully updated {}.'.format(machine),
- machine.to_JSON()
- )
-
-def DELETE(request):
- """Delete the Machine at this location in this Rack."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'datacenterId': 'int',
- 'roomId': 'int',
- 'tileId': 'int',
- 'position': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Machine from the database
-
- machine = Machine.from_tile_id_and_rack_position(request.params_path['tileId'], request.params_path['position'])
-
- # Make sure this Machine exists
-
- if not machine.exists():
- return Response(404, '{} not found.'.format(machine))
-
- # Make sure this user is authorized to edit this Machine
-
- if not machine.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from retrieving {}.'.format(machine))
-
- # Delete this Machine
-
- machine.delete()
-
- # Return this Machine
-
- return Response(
- 200,
- 'Successfully deleted {}.'.format(machine),
- machine.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/endpoint.py
deleted file mode 100644
index 7af62b92..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/endpoint.py
+++ /dev/null
@@ -1,138 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment."""
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(experiment))
-
- # Return this Experiment
-
- experiment.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(experiment),
- experiment.to_JSON()
- )
-
-def PUT(request):
- """Update this Experiment's Path, Trace, Scheduler, and/or name."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- },
- body = {
- 'experiment': {
- 'pathId': 'int',
- 'traceId': 'int',
- 'schedulerName': 'string',
- 'name': 'string'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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 edit this Experiment
-
- if not experiment.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from updating {}.'.format(experiment))
-
- # Update this Experiment
-
- experiment.path_id = request.params_body['experiment']['pathId']
- experiment.trace_id = request.params_body['experiment']['traceId']
- experiment.scheduler_name = request.params_body['experiment']['schedulerName']
- experiment.name = request.params_body['experiment']['name']
-
- try:
- experiment.update()
-
- except exceptions.ForeignKeyError:
- return Response(400, 'Foreign key error.')
-
- # Return this Experiment
-
- return Response(
- 200,
- 'Successfully updated {}.'.format(experiment),
- experiment.to_JSON()
- )
-
-def DELETE(request):
- """Delete this Experiment."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment and make sure it exists
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- if not experiment.exists():
- return Response(404, '{} not found.'.format(experiment))
-
- # Make sure this user is authorized to delete this Experiment
-
- if not experiment.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from deleting {}.'.format(experiment))
-
- # Delete and return this Experiment
-
- experiment.delete()
-
- return Response(
- 200,
- 'Successfully deleted {}.'.format(experiment),
- experiment.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/endpoint.py
deleted file mode 100644
index d39fafe4..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/last-simulated-tick/endpoint.py
+++ /dev/null
@@ -1,39 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment's last simulated tick."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment from the database
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- # Make sure this Experiment exisits
-
- if not experiment.exists():
- return Response(404, '{} not found.'.format(experiment))
-
- # Make sure this user is authorized to view this Experiment's last simulated tick
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing last simulated tick for {}.'.format(experiment))
-
- return Response(
- 200,
- 'Successfully retrieved last simulated tick for {}.'.format(experiment),
- {'lastSimulatedTick': experiment.last_simulated_tick}
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/endpoint.py
deleted file mode 100644
index c5ba0abe..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/machine-states/endpoint.py
+++ /dev/null
@@ -1,51 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.models.machine_state import MachineState
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment's Machine States."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment from the database
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- # Make sure this Experiment exisits
-
- if not experiment.exists():
- return Response(404, '{} not found.'.format(experiment))
-
- # Make sure this user is authorized to view this Experiment's Machine States
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Machine States for {}.'.format(experiment))
-
- # Get and return the Machine States
-
- if 'tick' in request.params_query:
- machine_states = MachineState.from_experiment_id_and_tick(
- request.params_path['experimentId'],
- request.params_query['tick']
- )
-
- else:
- machine_states = MachineState.from_experiment_id(request.params_path['experimentId'])
-
- return Response(
- 200,
- 'Successfully retrieved Machine States for {}.'.format(experiment),
- [x.to_JSON() for x in machine_states]
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/endpoint.py
deleted file mode 100644
index 6e71c496..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/rack-states/endpoint.py
+++ /dev/null
@@ -1,51 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.models.rack_state import RackState
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment's Tack States."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment from the database
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- # Make sure this Experiment exisits
-
- if not experiment.exists():
- return Response(404, '{} not found.'.format(experiment))
-
- # Make sure this user is authorized to view this Experiment's Rack States
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Rack States for {}.'.format(experiment))
-
- # Get and return the Rack States
-
- if 'tick' in request.params_query:
- rack_states = RackState.from_experiment_id_and_tick(
- request.params_path['experimentId'],
- request.params_query['tick']
- )
-
- else:
- rack_states = RackState.from_experiment_id(request.params_path['experimentId'])
-
- return Response(
- 200,
- 'Successfully retrieved Rack States for {}.'.format(experiment),
- [x.to_JSON() for x in rack_states]
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/endpoint.py
deleted file mode 100644
index d8c9fb45..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/room-states/endpoint.py
+++ /dev/null
@@ -1,51 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.models.room_state import RoomState
-from opendc.util import database, 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 = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment from the database
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- # Make sure this Experiment exisits
-
- 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]
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/endpoint.py
deleted file mode 100644
index 1bb60ca2..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/statistics/task-durations/endpoint.py
+++ /dev/null
@@ -1,44 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.models.task_duration import TaskDuration
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment's Task Durations."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate an Experiment from the database
-
- experiment = Experiment.from_primary_key((request.params_path['experimentId'],))
-
- # Make sure this Experiment exisits
-
- if not experiment.exists():
- return Response(404, '{} not found.'.format(experiment))
-
- # Make sure this user is authorized to view this Experiment's Task Durations
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Task Durations for {}.'.format(experiment))
-
- # Get and return the Task Durations
-
- task_durations = TaskDuration.from_experiment_id(request.params_path['experimentId'])
-
- return Response(
- 200,
- 'Successfully retrieved Task Durations for {}.'.format(experiment),
- [x.to_JSON() for x in task_durations]
- )
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/__init__.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/endpoint.py b/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/endpoint.py
deleted file mode 100644
index b11512c0..00000000
--- a/opendc/api/v1/simulations/simulationId/experiments/experimentId/task-states/endpoint.py
+++ /dev/null
@@ -1,51 +0,0 @@
-from opendc.models.experiment import Experiment
-from opendc.models.task_state import TaskState
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Experiment's Task States."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'experimentId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # 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 Task States for this Experiment
-
- if not experiment.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Task States for {}.'.format(experiment))
-
- # Get and return the Task States
-
- if 'tick' in request.params_query:
- task_states = TaskState.from_experiment_id_and_tick(
- request.params_path['experimentId'],
- request.params_query['tick']
- )
-
- else:
- task_states = TaskState.query('experiment_id', request.params_path['experimentId'])
-
- return Response(
- 200,
- 'Successfully retrieved Task States for {}.'.format(experiment),
- [x.to_JSON() for x in task_states]
- )
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/__init__.py b/opendc/api/v1/simulations/simulationId/paths/pathId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/branches/__init__.py b/opendc/api/v1/simulations/simulationId/paths/pathId/branches/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/branches/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/branches/endpoint.py b/opendc/api/v1/simulations/simulationId/paths/pathId/branches/endpoint.py
deleted file mode 100644
index 2aa34238..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/branches/endpoint.py
+++ /dev/null
@@ -1,166 +0,0 @@
-from datetime import datetime
-
-from opendc.models.datacenter import Datacenter
-from opendc.models.machine import Machine
-from opendc.models.object import Object
-from opendc.models.path import Path
-from opendc.models.rack import Rack
-from opendc.models.room import Room
-from opendc.models.section import Section
-from opendc.models.tile import Tile
-from opendc.util import database, exceptions
-from opendc.util.rest import Request, Response
-
-def POST(request):
- """Create a new Path that branches off of this Path at the specified tick."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'pathId': 'int'
- },
- body = {
- 'section': {
- 'startTick': 'int'
- }
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate the current Path from the database
-
- current_path = Path.from_primary_key((request.params_path['pathId'],))
-
- # Make sure the current Path exists
-
- if not current_path.exists():
- return Response(404, '{} not found.'.format(current_path))
-
- # Make sure this user is authorized to branch off the current Path
-
- if not current_path.google_id_has_at_least(request.google_id, 'EDIT'):
- return Response(403, 'Forbidden from branching off {}.'.format(current_path))
-
- # Create the new Path
-
- new_path = Path(
- simulation_id = current_path.simulation_id,
- datetime_created = database.datetime_to_string(datetime.now())
- )
-
- new_path.insert()
-
- # Get the current Path's sections and add them to the new Path if they're before the branch
-
- current_sections = Section.query('path_id', current_path.id)
- last_section = None
-
- for current_section in current_sections:
-
- if current_section.start_tick < request.params_body['section']['startTick'] or current_section.start_tick == 0:
-
- new_section = Section(
- path_id = new_path.id,
- datacenter_id = current_section.datacenter_id,
- start_tick = current_section.start_tick
- )
-
- new_section.insert()
-
- last_section = current_section
-
- # Make a deep copy of the last section's datacenter, its rooms, their tiles, etc.
-
- path_parameters = {
- 'simulationId': new_path.simulation_id
- }
-
- # Copy the Datacenter
-
- old_datacenter = Datacenter.from_primary_key((last_section.datacenter_id,))
-
- message = old_datacenter.generate_api_call(path_parameters, request.token)
- response = Request(message).process()
-
- path_parameters['datacenterId'] = response.content['id']
-
- # Create the new last Section, with the IDs of the new Path and new Datacenter
-
- if last_section.start_tick != 0:
- new_section = Section(
- path_id = new_path.id,
- datacenter_id = path_parameters['datacenterId'],
- start_tick = request.params_body['section']['startTick']
- )
-
- new_section.insert()
-
- else:
- last_section.datacenter_id = path_parameters['datacenterId']
- last_section.update()
-
- # Copy the rest of the Datacenter, starting with the Rooms...
-
- old_rooms = Room.query('datacenter_id', old_datacenter.id)
-
- for old_room in old_rooms:
-
- old_room.datacenter_id = path_parameters['datacenterId']
-
- message = old_room.generate_api_call(path_parameters, request.token)
- response = Request(message).process()
-
- path_parameters['roomId'] = response.content['id']
-
- # ... then the Tiles, ...
-
- old_tiles = Tile.query('room_id', old_room.id)
-
- for old_tile in old_tiles:
-
- old_tile.room_id = path_parameters['roomId']
-
- message = old_tile.generate_api_call(path_parameters, request.token)
- response = Request(message).process()
-
- path_parameters['tileId'] = response.content['id']
-
- old_objects = Object.query('id', old_tile.object_id)
-
- # ... then the Tile's Rack, ...
-
- if len(old_objects) == 1 and old_objects[0].type == 'RACK':
-
- old_rack = Rack.query('id', old_objects[0].id)[0]
-
- message = old_rack.generate_api_call(path_parameters, request.token)
- response = Request(message).process()
-
- path_parameters['rackId'] = response.content['id']
-
- # ... then the Rack's Machines ...
-
- old_machines = Machine.query('rack_id', old_rack.id)
-
- for old_machine in old_machines:
-
- old_machine.read()
- old_machine.rack_id = path_parameters['rackId']
-
- message = old_machine.generate_api_call(path_parameters, request.token)
- response = Request(message).process()
-
- path_parameters['machineId'] = response.content['id']
-
- # Return the new Path
-
- return Response(
- 200,
- 'Successfully created {}.'.format(new_path),
- new_path.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/endpoint.py b/opendc/api/v1/simulations/simulationId/paths/pathId/endpoint.py
deleted file mode 100644
index 71d97a67..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/endpoint.py
+++ /dev/null
@@ -1,44 +0,0 @@
-from opendc.models.path import Path
-from opendc.models.simulation import Simulation
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Path."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'pathId': 'int'
- }
- )
-
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Path from the database
-
- path = Path.from_primary_key((request.params_path['pathId'],))
-
- # Make sure this Path exists
-
- if not path.exists():
- return Response(404, '{} not found.'.format(path))
-
- # Make sure this user is authorized to view this Path
-
- if not path.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from retrieving {}.'.format(path))
-
- # Return this Path
-
- path.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(path),
- path.to_JSON()
- )
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/__init__.py b/opendc/api/v1/simulations/simulationId/paths/pathId/sections/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/endpoint.py b/opendc/api/v1/simulations/simulationId/paths/pathId/sections/endpoint.py
deleted file mode 100644
index 775de346..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/endpoint.py
+++ /dev/null
@@ -1,43 +0,0 @@
-from opendc.models.section import Section
-from opendc.models.path import Path
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Path's Sections."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'pathId': 'int'
- }
- )
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
- # Instantiate a Path from the database
-
- path = Path.from_primary_key((request.params_path['pathId'],))
-
- # Make sure this Path exists
-
- if not path.exists():
- return Response(404, '{} not found.'.format(path))
-
- # Make sure this user is authorized to view this Path's Sections
-
- if not path.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing Sections for {}.'.format(path))
-
- # Get and return the Sections
-
- sections = Section.query('path_id', request.params_path['pathId'])
-
- return Response(
- 200,
- 'Successfully retrieved Sections for {}.'.format(path),
- [x.to_JSON() for x in sections]
- )
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/__init__.py b/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/__init__.py
deleted file mode 100644
index e69de29b..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/__init__.py
+++ /dev/null
diff --git a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/endpoint.py b/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/endpoint.py
deleted file mode 100644
index 9cd397d0..00000000
--- a/opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/endpoint.py
+++ /dev/null
@@ -1,44 +0,0 @@
-from opendc.models.section import Section
-from opendc.util import database, exceptions
-from opendc.util.rest import Response
-
-def GET(request):
- """Get this Path's Sections."""
-
- # Make sure required parameters are there
-
- try:
- request.check_required_parameters(
- path = {
- 'simulationId': 'int',
- 'pathId': 'int',
- 'sectionId': 'int'
- }
- )
- except exceptions.ParameterError as e:
- return Response(400, e.message)
-
-
- # Instantiate a Section from the database
-
- section = Section.from_primary_key((request.params_path['sectionId'],))
-
- # Make sure this Section exists
-
- if not section.exists():
- return Response(404, '{} not found.'.format(section))
-
- # Make sure this user is authorized to view this Section
-
- if not section.google_id_has_at_least(request.google_id, 'VIEW'):
- return Response(403, 'Forbidden from viewing {}.'.format(section))
-
- # Return the Section
-
- section.read()
-
- return Response(
- 200,
- 'Successfully retrieved {}.'.format(section),
- section.to_JSON()
- )