summaryrefslogtreecommitdiff
path: root/opendc/api/v1/specifications
diff options
context:
space:
mode:
Diffstat (limited to 'opendc/api/v1/specifications')
-rw-r--r--opendc/api/v1/specifications/__init__.py0
-rw-r--r--opendc/api/v1/specifications/cpus/__init__.py0
-rw-r--r--opendc/api/v1/specifications/cpus/endpoint.py17
-rw-r--r--opendc/api/v1/specifications/cpus/id/__init__.py0
-rw-r--r--opendc/api/v1/specifications/cpus/id/endpoint.py33
-rw-r--r--opendc/api/v1/specifications/failure-models/__init__.py0
-rw-r--r--opendc/api/v1/specifications/failure-models/endpoint.py17
-rw-r--r--opendc/api/v1/specifications/failure-models/id/__init__.py0
-rw-r--r--opendc/api/v1/specifications/failure-models/id/endpoint.py33
-rw-r--r--opendc/api/v1/specifications/gpus/__init__.py0
-rw-r--r--opendc/api/v1/specifications/gpus/endpoint.py17
-rw-r--r--opendc/api/v1/specifications/gpus/id/__init__.py0
-rw-r--r--opendc/api/v1/specifications/gpus/id/endpoint.py33
-rw-r--r--opendc/api/v1/specifications/memories/__init__.py0
-rw-r--r--opendc/api/v1/specifications/memories/endpoint.py17
-rw-r--r--opendc/api/v1/specifications/memories/id/__init__.py0
-rw-r--r--opendc/api/v1/specifications/memories/id/endpoint.py33
-rw-r--r--opendc/api/v1/specifications/storages/__init__.py0
-rw-r--r--opendc/api/v1/specifications/storages/endpoint.py17
-rw-r--r--opendc/api/v1/specifications/storages/id/__init__.py0
-rw-r--r--opendc/api/v1/specifications/storages/id/endpoint.py33
21 files changed, 250 insertions, 0 deletions
diff --git a/opendc/api/v1/specifications/__init__.py b/opendc/api/v1/specifications/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/__init__.py
diff --git a/opendc/api/v1/specifications/cpus/__init__.py b/opendc/api/v1/specifications/cpus/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/cpus/__init__.py
diff --git a/opendc/api/v1/specifications/cpus/endpoint.py b/opendc/api/v1/specifications/cpus/endpoint.py
new file mode 100644
index 00000000..5c856255
--- /dev/null
+++ b/opendc/api/v1/specifications/cpus/endpoint.py
@@ -0,0 +1,17 @@
+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/v1/specifications/cpus/id/__init__.py b/opendc/api/v1/specifications/cpus/id/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/cpus/id/__init__.py
diff --git a/opendc/api/v1/specifications/cpus/id/endpoint.py b/opendc/api/v1/specifications/cpus/id/endpoint.py
new file mode 100644
index 00000000..158576cb
--- /dev/null
+++ b/opendc/api/v1/specifications/cpus/id/endpoint.py
@@ -0,0 +1,33 @@
+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/v1/specifications/failure-models/__init__.py b/opendc/api/v1/specifications/failure-models/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/failure-models/__init__.py
diff --git a/opendc/api/v1/specifications/failure-models/endpoint.py b/opendc/api/v1/specifications/failure-models/endpoint.py
new file mode 100644
index 00000000..2530d032
--- /dev/null
+++ b/opendc/api/v1/specifications/failure-models/endpoint.py
@@ -0,0 +1,17 @@
+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/v1/specifications/failure-models/id/__init__.py b/opendc/api/v1/specifications/failure-models/id/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/failure-models/id/__init__.py
diff --git a/opendc/api/v1/specifications/failure-models/id/endpoint.py b/opendc/api/v1/specifications/failure-models/id/endpoint.py
new file mode 100644
index 00000000..8a7d2e1d
--- /dev/null
+++ b/opendc/api/v1/specifications/failure-models/id/endpoint.py
@@ -0,0 +1,33 @@
+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/v1/specifications/gpus/__init__.py b/opendc/api/v1/specifications/gpus/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/gpus/__init__.py
diff --git a/opendc/api/v1/specifications/gpus/endpoint.py b/opendc/api/v1/specifications/gpus/endpoint.py
new file mode 100644
index 00000000..8728d203
--- /dev/null
+++ b/opendc/api/v1/specifications/gpus/endpoint.py
@@ -0,0 +1,17 @@
+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/v1/specifications/gpus/id/__init__.py b/opendc/api/v1/specifications/gpus/id/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/gpus/id/__init__.py
diff --git a/opendc/api/v1/specifications/gpus/id/endpoint.py b/opendc/api/v1/specifications/gpus/id/endpoint.py
new file mode 100644
index 00000000..41b5a9e4
--- /dev/null
+++ b/opendc/api/v1/specifications/gpus/id/endpoint.py
@@ -0,0 +1,33 @@
+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/v1/specifications/memories/__init__.py b/opendc/api/v1/specifications/memories/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/memories/__init__.py
diff --git a/opendc/api/v1/specifications/memories/endpoint.py b/opendc/api/v1/specifications/memories/endpoint.py
new file mode 100644
index 00000000..b275b6f0
--- /dev/null
+++ b/opendc/api/v1/specifications/memories/endpoint.py
@@ -0,0 +1,17 @@
+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/v1/specifications/memories/id/__init__.py b/opendc/api/v1/specifications/memories/id/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/memories/id/__init__.py
diff --git a/opendc/api/v1/specifications/memories/id/endpoint.py b/opendc/api/v1/specifications/memories/id/endpoint.py
new file mode 100644
index 00000000..3132efab
--- /dev/null
+++ b/opendc/api/v1/specifications/memories/id/endpoint.py
@@ -0,0 +1,33 @@
+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/v1/specifications/storages/__init__.py b/opendc/api/v1/specifications/storages/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/storages/__init__.py
diff --git a/opendc/api/v1/specifications/storages/endpoint.py b/opendc/api/v1/specifications/storages/endpoint.py
new file mode 100644
index 00000000..875ed987
--- /dev/null
+++ b/opendc/api/v1/specifications/storages/endpoint.py
@@ -0,0 +1,17 @@
+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/v1/specifications/storages/id/__init__.py b/opendc/api/v1/specifications/storages/id/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/opendc/api/v1/specifications/storages/id/__init__.py
diff --git a/opendc/api/v1/specifications/storages/id/endpoint.py b/opendc/api/v1/specifications/storages/id/endpoint.py
new file mode 100644
index 00000000..b0d254a4
--- /dev/null
+++ b/opendc/api/v1/specifications/storages/id/endpoint.py
@@ -0,0 +1,33 @@
+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()
+ )