diff options
Diffstat (limited to 'opendc/api/v2/specifications')
21 files changed, 260 insertions, 0 deletions
diff --git a/opendc/api/v2/specifications/__init__.py b/opendc/api/v2/specifications/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/__init__.py diff --git a/opendc/api/v2/specifications/cpus/__init__.py b/opendc/api/v2/specifications/cpus/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/cpus/__init__.py diff --git a/opendc/api/v2/specifications/cpus/endpoint.py b/opendc/api/v2/specifications/cpus/endpoint.py new file mode 100644 index 00000000..5cdbb9ec --- /dev/null +++ b/opendc/api/v2/specifications/cpus/endpoint.py @@ -0,0 +1,18 @@ +from opendc.models.cpu import CPU +from opendc.util.rest import Response + + +def GET(request): + """Get a list of the specifications of all CPUs.""" + + # Get the CPUs + + cpus = CPU.query() + + # Return the CPUs + + return Response( + 200, + 'Successfully retrieved CPUs.', + [x.to_JSON() for x in cpus] + ) diff --git a/opendc/api/v2/specifications/cpus/id/__init__.py b/opendc/api/v2/specifications/cpus/id/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/cpus/id/__init__.py diff --git a/opendc/api/v2/specifications/cpus/id/endpoint.py b/opendc/api/v2/specifications/cpus/id/endpoint.py new file mode 100644 index 00000000..c2453e51 --- /dev/null +++ b/opendc/api/v2/specifications/cpus/id/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.cpu import CPU +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get the specs of a CPU.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters( + path={ + 'id': 'int' + } + ) + + except exceptions.ParameterError as e: + return Response(400, e.message) + + # Instantiate a CPU and make sure it exists + + cpu = CPU.from_primary_key((request.params_path['id'],)) + + if not cpu.exists(): + return Response(404, '{} not found.'.format(cpu)) + + # Return this CPU + + return Response( + 200, + 'Successfully retrieved {}.'.format(cpu), + cpu.to_JSON() + ) diff --git a/opendc/api/v2/specifications/failure-models/__init__.py b/opendc/api/v2/specifications/failure-models/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/failure-models/__init__.py diff --git a/opendc/api/v2/specifications/failure-models/endpoint.py b/opendc/api/v2/specifications/failure-models/endpoint.py new file mode 100644 index 00000000..fff668c0 --- /dev/null +++ b/opendc/api/v2/specifications/failure-models/endpoint.py @@ -0,0 +1,18 @@ +from opendc.models.failure_model import FailureModel +from opendc.util.rest import Response + + +def GET(request): + """Get all Failure Models.""" + + # Get the FailureModels + + failure_models = FailureModel.query() + + # Return the FailureModels + + return Response( + 200, + 'Successfully retrieved FailureModels.', + [x.to_JSON() for x in failure_models] + ) diff --git a/opendc/api/v2/specifications/failure-models/id/__init__.py b/opendc/api/v2/specifications/failure-models/id/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/failure-models/id/__init__.py diff --git a/opendc/api/v2/specifications/failure-models/id/endpoint.py b/opendc/api/v2/specifications/failure-models/id/endpoint.py new file mode 100644 index 00000000..0797c9c9 --- /dev/null +++ b/opendc/api/v2/specifications/failure-models/id/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.failure_model import FailureModel +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get this Failure Model.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters( + path={ + 'id': 'int' + } + ) + + except exceptions.ParameterError as e: + return Response(400, e.message) + + # Instantiate a FailureModel and make sure it exists + + failure_model = FailureModel.from_primary_key((request.params_path['id'],)) + + if not failure_model.exists(): + return Response(404, '{} not found.'.format(failure_model)) + + # Return this FailureModel + + return Response( + 200, + 'Successfully retrieved {}.'.format(failure_model), + failure_model.to_JSON() + ) diff --git a/opendc/api/v2/specifications/gpus/__init__.py b/opendc/api/v2/specifications/gpus/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/gpus/__init__.py diff --git a/opendc/api/v2/specifications/gpus/endpoint.py b/opendc/api/v2/specifications/gpus/endpoint.py new file mode 100644 index 00000000..5676f62b --- /dev/null +++ b/opendc/api/v2/specifications/gpus/endpoint.py @@ -0,0 +1,18 @@ +from opendc.models.gpu import GPU +from opendc.util.rest import Response + + +def GET(request): + """Get a list of the specifications of all GPUs.""" + + # Get the GPUs + + gpus = GPU.query() + + # Return the GPUs + + return Response( + 200, + 'Successfully retrieved GPUs.', + [x.to_JSON() for x in gpus] + ) diff --git a/opendc/api/v2/specifications/gpus/id/__init__.py b/opendc/api/v2/specifications/gpus/id/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/gpus/id/__init__.py diff --git a/opendc/api/v2/specifications/gpus/id/endpoint.py b/opendc/api/v2/specifications/gpus/id/endpoint.py new file mode 100644 index 00000000..81113dc3 --- /dev/null +++ b/opendc/api/v2/specifications/gpus/id/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.gpu import GPU +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get the specs of a GPU.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters( + path={ + 'id': 'int' + } + ) + + except exceptions.ParameterError as e: + return Response(400, e.message) + + # Instantiate a GPU and make sure it exists + + gpu = GPU.from_primary_key((request.params_path['id'],)) + + if not gpu.exists(): + return Response(404, '{} not found.'.format(gpu)) + + # Return this GPU + + return Response( + 200, + 'Successfully retrieved {}.'.format(gpu), + gpu.to_JSON() + ) diff --git a/opendc/api/v2/specifications/memories/__init__.py b/opendc/api/v2/specifications/memories/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/memories/__init__.py diff --git a/opendc/api/v2/specifications/memories/endpoint.py b/opendc/api/v2/specifications/memories/endpoint.py new file mode 100644 index 00000000..271824b3 --- /dev/null +++ b/opendc/api/v2/specifications/memories/endpoint.py @@ -0,0 +1,18 @@ +from opendc.models.memory import Memory +from opendc.util.rest import Response + + +def GET(request): + """Get a list of the specifications of all Memories.""" + + # Get the Memories + + memories = Memory.query() + + # Return the Memories + + return Response( + 200, + 'Successfully retrieved Memories.', + [x.to_JSON() for x in memories] + ) diff --git a/opendc/api/v2/specifications/memories/id/__init__.py b/opendc/api/v2/specifications/memories/id/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/memories/id/__init__.py diff --git a/opendc/api/v2/specifications/memories/id/endpoint.py b/opendc/api/v2/specifications/memories/id/endpoint.py new file mode 100644 index 00000000..863099ca --- /dev/null +++ b/opendc/api/v2/specifications/memories/id/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.memory import Memory +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get the specs of a Memory.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters( + path={ + 'id': 'int' + } + ) + + except exceptions.ParameterError as e: + return Response(400, e.message) + + # Instantiate a Memory and make sure it exists + + memory = Memory.from_primary_key((request.params_path['id'],)) + + if not memory.exists(): + return Response(404, '{} not found.'.format(memory)) + + # Return this Memory + + return Response( + 200, + 'Successfully retrieved {}.'.format(memory), + memory.to_JSON() + ) diff --git a/opendc/api/v2/specifications/storages/__init__.py b/opendc/api/v2/specifications/storages/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/storages/__init__.py diff --git a/opendc/api/v2/specifications/storages/endpoint.py b/opendc/api/v2/specifications/storages/endpoint.py new file mode 100644 index 00000000..28f33177 --- /dev/null +++ b/opendc/api/v2/specifications/storages/endpoint.py @@ -0,0 +1,18 @@ +from opendc.models.storage import Storage +from opendc.util.rest import Response + + +def GET(request): + """Get a list of the specifications of all Storages.""" + + # Get the Storages + + storages = Storage.query() + + # Return the Storages + + return Response( + 200, + 'Successfully retrieved Storages.', + [x.to_JSON() for x in storages] + ) diff --git a/opendc/api/v2/specifications/storages/id/__init__.py b/opendc/api/v2/specifications/storages/id/__init__.py new file mode 100644 index 00000000..e69de29b --- /dev/null +++ b/opendc/api/v2/specifications/storages/id/__init__.py diff --git a/opendc/api/v2/specifications/storages/id/endpoint.py b/opendc/api/v2/specifications/storages/id/endpoint.py new file mode 100644 index 00000000..ebe65857 --- /dev/null +++ b/opendc/api/v2/specifications/storages/id/endpoint.py @@ -0,0 +1,34 @@ +from opendc.models.storage import Storage +from opendc.util import exceptions +from opendc.util.rest import Response + + +def GET(request): + """Get the specs of a Storage.""" + + # Make sure required parameters are there + + try: + request.check_required_parameters( + path={ + 'id': 'int' + } + ) + + except exceptions.ParameterError as e: + return Response(400, e.message) + + # Instantiate a Storage and make sure it exists + + storage = Storage.from_primary_key((request.params_path['id'],)) + + if not storage.exists(): + return Response(404, '{} not found.'.format(storage)) + + # Return this CPU + + return Response( + 200, + 'Successfully retrieved {}.'.format(storage), + storage.to_JSON() + ) |
