from marshmallow_enum import EnumField from marshmallow_sqlalchemy import ModelSchema from sqlalchemy import func from crc import db from crc.models.protocol_builder import ProtocolBuilderStatus class StudyModel(db.Model): __tablename__ = 'study' id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String) last_updated = db.Column(db.DateTime(timezone=True), default=func.now()) protocol_builder_status = db.Column(db.Enum(ProtocolBuilderStatus)) primary_investigator_id = db.Column(db.String) sponsor = db.Column(db.String) ind_number = db.Column(db.String) user_uid = db.Column(db.String, db.ForeignKey('user.uid'), nullable=True) investigator_uids = db.Column(db.ARRAY(db.String)) inactive = db.Column(db.Boolean, default=False) class StudyModelSchema(ModelSchema): class Meta: model = StudyModel include_fk = True # Includes foreign keys protocol_builder_status = EnumField(ProtocolBuilderStatus)