summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjc0b <j@jc0b.computer>2020-07-07 16:53:37 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2020-08-24 19:47:27 +0200
commit9ff1e3c6bae253372a468dbdc9b8369ab8dd2c6f (patch)
tree11cafe20ed2769937c982af644aaa71c1db3d161
parent86e1ec7585bcbc44b5f7f32b87b73b2e2bda0cba (diff)
added some more prefabs-related content
-rw-r--r--web-server/opendc/api/v2/prefabs/__init__.py0
-rw-r--r--web-server/opendc/api/v2/prefabs/endpoint.py23
-rw-r--r--web-server/opendc/api/v2/prefabs/prefabId/__init__.py0
-rw-r--r--web-server/opendc/api/v2/prefabs/prefabId/endpoint.py0
-rw-r--r--web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py0
-rw-r--r--web-server/opendc/api/v2/prefabs/test_endpoint.py21
-rw-r--r--web-server/opendc/models/prefab.py4
7 files changed, 46 insertions, 2 deletions
diff --git a/web-server/opendc/api/v2/prefabs/__init__.py b/web-server/opendc/api/v2/prefabs/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/__init__.py
diff --git a/web-server/opendc/api/v2/prefabs/endpoint.py b/web-server/opendc/api/v2/prefabs/endpoint.py
new file mode 100644
index 00000000..d7e23450
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/endpoint.py
@@ -0,0 +1,23 @@
+from datetime import datetime
+
+from opendc.models.prefab import Prefab
+from opendc.models.user import User
+from opendc.util.database import Database
+from opendc.util.rest import Response
+
+
+def POST(request):
+ """Create a new prefab, and return that new prefab."""
+
+ request.check_required_parameters(body={'prefab': {'name': 'string'}})
+
+ prefab = Prefab(request.params_body['prefab'])
+ prefab.set_property('datetimeCreated', Database.datetime_to_string(datetime.now()))
+ prefab.set_property('datetimeLastEdited', Database.datetime_to_string(datetime.now()))
+ prefab.insert()
+
+ user = User.from_google_id(request.google_id)
+ user.obj['authorizations'].append({'prefabId': prefab.get_id(), 'authorizationLevel': 'OWN'})
+ user.update()
+
+ return Response(200, 'Successfully created prefab.', prefab.obj)
diff --git a/web-server/opendc/api/v2/prefabs/prefabId/__init__.py b/web-server/opendc/api/v2/prefabs/prefabId/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/prefabId/__init__.py
diff --git a/web-server/opendc/api/v2/prefabs/prefabId/endpoint.py b/web-server/opendc/api/v2/prefabs/prefabId/endpoint.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/prefabId/endpoint.py
diff --git a/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py b/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py
diff --git a/web-server/opendc/api/v2/prefabs/test_endpoint.py b/web-server/opendc/api/v2/prefabs/test_endpoint.py
new file mode 100644
index 00000000..58735ac7
--- /dev/null
+++ b/web-server/opendc/api/v2/prefabs/test_endpoint.py
@@ -0,0 +1,21 @@
+from opendc.util.database import DB
+
+
+def test_add_simulation_missing_parameter(client):
+ assert '400' in client.post('/api/v2/prefabs').status
+
+
+def test_add_simulation(client, mocker):
+ mocker.patch.object(DB, 'fetch_one', return_value={'_id': '1', 'authorizations': []})
+ mocker.patch.object(DB,
+ 'insert',
+ return_value={
+ '_id': '1',
+ 'datetimeCreated': '000',
+ 'datetimeLastEdited': '000'
+ })
+ mocker.patch.object(DB, 'update', return_value={})
+ res = client.post('/api/v2/prefabs', json={'prefab': {'name': 'test prefab'}})
+ assert 'datetimeCreated' in res.json['content']
+ assert 'datetimeLastEdited' in res.json['content']
+ assert '200' in res.status
diff --git a/web-server/opendc/models/prefab.py b/web-server/opendc/models/prefab.py
index a3611a11..d3b1a5d5 100644
--- a/web-server/opendc/models/prefab.py
+++ b/web-server/opendc/models/prefab.py
@@ -6,7 +6,7 @@ from opendc.util.rest import Response
class Prefab(Model):
- """Model representing a Simulation."""
+ """Model representing a Prefab."""
collection_name = 'prefabs'
@@ -23,7 +23,7 @@ class Prefab(Model):
raise ClientError(Response(403, "Forbidden from retrieving prefab."))
def get_all_authorizations(self):
- """Get all user IDs having access to this simulation."""
+ """Get all user IDs having access to this prefab."""
return [
str(user['_id']) for user in DB.fetch_all({'authorizations': {
'prefabId': self.obj['_id']