From f589682b0840aab0624122052eb863cf8dc3a0b9 Mon Sep 17 00:00:00 2001 From: Georgios Andreadis Date: Sun, 13 Aug 2017 23:12:16 +0300 Subject: Convert API codebase to flat model --- .../simulationId/paths/pathId/__init__.py | 0 .../simulationId/paths/pathId/branches/__init__.py | 0 .../simulationId/paths/pathId/branches/endpoint.py | 166 --------------------- .../simulationId/paths/pathId/endpoint.py | 44 ------ .../simulationId/paths/pathId/sections/__init__.py | 0 .../simulationId/paths/pathId/sections/endpoint.py | 43 ------ .../paths/pathId/sections/sectionId/__init__.py | 0 .../paths/pathId/sections/sectionId/endpoint.py | 44 ------ 8 files changed, 297 deletions(-) delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/__init__.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/branches/__init__.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/branches/endpoint.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/endpoint.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/sections/__init__.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/sections/endpoint.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/__init__.py delete mode 100644 opendc/api/v1/simulations/simulationId/paths/pathId/sections/sectionId/endpoint.py (limited to 'opendc/api/v1/simulations/simulationId/paths') 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 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 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 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 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() - ) -- cgit v1.2.3