diff options
Diffstat (limited to 'animism-align/cli/app/sql/models/project.py')
| -rw-r--r-- | animism-align/cli/app/sql/models/project.py | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/animism-align/cli/app/sql/models/project.py b/animism-align/cli/app/sql/models/project.py new file mode 100644 index 0000000..eb94fd6 --- /dev/null +++ b/animism-align/cli/app/sql/models/project.py @@ -0,0 +1,32 @@ +from sqlalchemy import create_engine, Table, Column, Text, String, Integer, Boolean, Float, DateTime, JSON, ForeignKey +from sqlalchemy.orm import relationship +import sqlalchemy.sql.functions as func +from sqlalchemy_utc import UtcDateTime, utcnow +from wtforms_alchemy import ModelForm + +from app.sql.common import db, Base, Session + +from app.settings import app_cfg + +class Project(Base): + """Table for storing projects and their metadata""" + __tablename__ = 'project' + id = Column(Integer, primary_key=True) + title = Column(String(256, convert_unicode=True), nullable=False) + is_live = Column(Boolean, default=False) + settings = Column(JSON, default={}, nullable=True) + + def toJSON(self): + return { + 'id': self.id, + 'title': self.title, + 'is_live': self.is_live, + 'settings': self.settings, + } + +class ProjectForm(ModelForm): + class Meta: + model = Episode + exclude = ['settings'] + def get_session(): + return Session() |
