2019-12-18 19:02:17 +00:00
|
|
|
import enum
|
|
|
|
|
2019-12-19 16:58:51 +00:00
|
|
|
from SpiffWorkflow import Task
|
2019-12-18 19:02:17 +00:00
|
|
|
from flask_marshmallow.sqla import ModelSchema
|
2019-12-19 16:58:51 +00:00
|
|
|
from marshmallow import post_load, fields, Schema
|
2019-12-18 19:02:17 +00:00
|
|
|
from marshmallow_enum import EnumField
|
|
|
|
from sqlalchemy import func
|
|
|
|
|
2019-12-19 16:58:51 +00:00
|
|
|
from crc import db, ma
|
2019-12-18 19:02:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ProtocolBuilderStatus(enum.Enum):
|
|
|
|
out_of_date = "out_of_date"
|
|
|
|
in_process = "in_process"
|
|
|
|
complete = "complete"
|
|
|
|
updating = "updating"
|
|
|
|
|
|
|
|
|
|
|
|
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)
|
|
|
|
|
|
|
|
|
|
|
|
class StudySchema(ModelSchema):
|
|
|
|
class Meta:
|
|
|
|
model = StudyModel
|
|
|
|
protocol_builder_status = EnumField(ProtocolBuilderStatus)
|
|
|
|
|
|
|
|
|
|
|
|
class WorkflowSpecModel(db.Model):
|
|
|
|
__tablename__ = 'workflow_spec'
|
|
|
|
id = db.Column(db.String, primary_key=True)
|
|
|
|
display_name = db.Column(db.String)
|
|
|
|
description = db.Column(db.Text)
|
|
|
|
|
|
|
|
class WorkflowSpecSchema(ModelSchema):
|
|
|
|
class Meta:
|
|
|
|
model = WorkflowSpecModel
|
|
|
|
|
|
|
|
class WorkflowStatus(enum.Enum):
|
|
|
|
new = "new"
|
|
|
|
user_input_required = "user_input_required"
|
|
|
|
waiting = "waiting"
|
|
|
|
complete = "complete"
|
|
|
|
|
|
|
|
|
|
|
|
class WorkflowModel(db.Model):
|
|
|
|
__tablename__ = 'workflow'
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
|
|
bpmn_workflow_json = db.Column(db.TEXT)
|
|
|
|
status = db.Column(db.Enum(WorkflowStatus))
|
|
|
|
study_id = db.Column(db.Integer, db.ForeignKey('study.id'))
|
|
|
|
workflow_spec_id = db.Column(db.Integer, db.ForeignKey('workflow_spec.id'))
|
|
|
|
|
2019-12-19 16:58:51 +00:00
|
|
|
|
2019-12-18 19:02:17 +00:00
|
|
|
class WorkflowSchema(ModelSchema):
|
|
|
|
class Meta:
|
|
|
|
model = WorkflowModel
|
|
|
|
status = EnumField(WorkflowStatus)
|
|
|
|
|
|
|
|
|
2019-12-19 16:58:51 +00:00
|
|
|
class Task:
|
|
|
|
def __init__(self, id, name, type, state, form):
|
|
|
|
self.id = id
|
|
|
|
self.name = name
|
|
|
|
self.type = type
|
|
|
|
self.state = state
|
|
|
|
self.form = form
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def from_spiff(cls, spiff_task):
|
|
|
|
instance = cls(spiff_task.id,
|
|
|
|
spiff_task.task_spec.name,
|
|
|
|
spiff_task.get_state_name(),
|
|
|
|
"task",
|
|
|
|
{})
|
|
|
|
if hasattr(spiff_task.task_spec, "form"):
|
|
|
|
instance.type = "form"
|
|
|
|
instance.form = spiff_task.task_spec.form
|
|
|
|
return instance
|
|
|
|
|
|
|
|
|
|
|
|
class OptionSchema(ma.Schema):
|
|
|
|
class Meta:
|
|
|
|
fields = ["id", "name"]
|
|
|
|
|
|
|
|
|
|
|
|
class FieldSchema(ma.Schema):
|
|
|
|
class Meta:
|
|
|
|
fields = ["id", "type", "label", "defaultValue", "options"]
|
|
|
|
options = fields.List(fields.Nested(OptionSchema))
|
|
|
|
|
|
|
|
|
|
|
|
class FormSchema(ma.Schema):
|
|
|
|
class Meta:
|
|
|
|
fields = ["key", "fields"]
|
|
|
|
fields = fields.List(fields.Nested(FieldSchema))
|
|
|
|
|
|
|
|
|
|
|
|
class TaskSchema(ma.Schema):
|
|
|
|
class Meta:
|
|
|
|
fields = ["id", "name", "type", "state", "form"]
|
|
|
|
|
|
|
|
form = fields.Nested(FormSchema)
|
|
|
|
@post_load
|
|
|
|
def make_task(self, data, **kwargs):
|
|
|
|
return Task(**data)
|
|
|
|
|
2019-12-18 19:02:17 +00:00
|
|
|
|