From 61cf27a9529e503d3c56854c9d664f2d9520213a Mon Sep 17 00:00:00 2001 From: jc0b Date: Thu, 25 Jun 2020 22:11:25 +0200 Subject: GET for topologies with tests --- opendc/api/v2/topologies/topologyId/endpoint.py | 34 +++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 opendc/api/v2/topologies/topologyId/endpoint.py (limited to 'opendc/api/v2/topologies/topologyId/endpoint.py') diff --git a/opendc/api/v2/topologies/topologyId/endpoint.py b/opendc/api/v2/topologies/topologyId/endpoint.py new file mode 100644 index 00000000..ef541daa --- /dev/null +++ b/opendc/api/v2/topologies/topologyId/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.topology import Topology +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get this Topology.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters(path={'topologyId': 'int'}) + except exceptions.ParameterError as e: + return Response(400, str(e)) + + # Instantiate a Topology from the database + + topology = Topology.from_id(request.params_path['topologyId']) + + # Make sure this Topology exists + + validation_error = topology.validate() + if validation_error is not None: + return validation_error + + # Make sure this user is authorized to view this Topology + + access_error = topology.validate_user_access(request.google_id, False) + if access_error is not None: + return access_error + + # Return this Topology + + return Response(200, 'Successfully retrieved topology.', topology.obj) -- cgit v1.2.3