From 541e23df31ed3e9f1d1c5fe02962efbb3d6c2c8f Mon Sep 17 00:00:00 2001 From: Jules Laplace Date: Tue, 29 Sep 2020 19:14:53 +0200 Subject: add table for episodes --- animism-align/cli/app/sql/models/episode.py | 34 +++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) create mode 100644 animism-align/cli/app/sql/models/episode.py (limited to 'animism-align/cli/app/sql/models/episode.py') diff --git a/animism-align/cli/app/sql/models/episode.py b/animism-align/cli/app/sql/models/episode.py new file mode 100644 index 0000000..a13c674 --- /dev/null +++ b/animism-align/cli/app/sql/models/episode.py @@ -0,0 +1,34 @@ +from sqlalchemy import create_engine, Table, Column, Text, String, Integer, 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 Episode(Base): + """Table for storing episodes and their metadata""" + __tablename__ = 'episode' + id = Column(Integer, primary_key=True) + episode_number = Column(Integer, primary_key=True) + title = Column(String(256, convert_unicode=True), nullable=False) + release_date = Column(String(256, convert_unicode=True), primary_key=True) + settings = Column(JSON, default={}, nullable=True) + + def toJSON(self): + return { + 'id': self.id, + 'episode_number': self.episode_number, + 'title': self.type, + 'release_date': self.release_date, + 'settings': self.settings, + } + +class EpisodeForm(ModelForm): + class Meta: + model = Episode + exclude = ['settings'] + def get_session(): + return Session() -- cgit v1.2.3-70-g09d2