summaryrefslogtreecommitdiff
path: root/web-server/opendc/models_old/simulation.py
diff options
context:
space:
mode:
Diffstat (limited to 'web-server/opendc/models_old/simulation.py')
-rw-r--r--web-server/opendc/models_old/simulation.py39
1 files changed, 39 insertions, 0 deletions
diff --git a/web-server/opendc/models_old/simulation.py b/web-server/opendc/models_old/simulation.py
new file mode 100644
index 00000000..9c1820a3
--- /dev/null
+++ b/web-server/opendc/models_old/simulation.py
@@ -0,0 +1,39 @@
+from opendc.models_old.authorization import Authorization
+from opendc.models_old.model import Model
+from opendc.models_old.user import User
+from opendc.util import exceptions
+
+
+class Simulation(Model):
+ JSON_TO_PYTHON_DICT = {
+ 'Simulation': {
+ 'id': 'id',
+ 'name': 'name',
+ 'datetimeCreated': 'datetime_created',
+ 'datetimeLastEdited': 'datetime_last_edited'
+ }
+ }
+
+ COLLECTION_NAME = 'simulations'
+ COLUMNS = ['id', 'datetime_created', 'datetime_last_edited', 'name']
+ COLUMNS_PRIMARY_KEY = ['id']
+
+ def google_id_has_at_least(self, google_id, authorization_level):
+ """Return True if the user has at least the given auth level over this Simulation."""
+
+ # Get the User id
+
+ try:
+ user_id = User.from_google_id(google_id).read().id
+ except exceptions.RowNotFoundError:
+ return False
+
+ # Get the Simulation id
+
+ simulation_id = self.id
+
+ # Check the Authorization
+
+ authorization = Authorization.from_primary_key((user_id, simulation_id))
+
+ return authorization.has_at_least(authorization_level)