122 lines
4.2 KiB
Python
Raw Normal View History

import enum
2022-02-09 08:50:00 -05:00
import marshmallow
2022-02-09 11:37:54 -05:00
from marshmallow import EXCLUDE, post_load, fields, INCLUDE
from sqlalchemy import func
from sqlalchemy.orm import deferred
from crc import db, ma
2020-03-18 16:58:50 -04:00
class WorkflowSpecCategory(object):
2022-02-09 11:24:41 -05:00
def __init__(self, id, display_name, display_order=0, admin=False):
2022-02-09 10:55:02 -05:00
self.id = id # A unique string name, lower case, under scores (ie, 'my_category')
self.display_name = display_name
self.display_order = display_order
self.admin = admin
2022-02-09 08:50:00 -05:00
self.workflows = [] # For storing Workflow Metadata
2022-02-09 10:55:02 -05:00
self.specs = [] # For the list of specifications associated with a category
2022-03-16 12:49:35 -04:00
self.meta = None # For storing category metadata
2022-02-09 10:55:02 -05:00
def __eq__(self, other):
if not isinstance(other, WorkflowSpecCategory):
return False
if other.id == self.id:
return True
return False
class WorkflowSpecCategorySchema(ma.Schema):
2020-03-13 14:56:46 -04:00
class Meta:
model = WorkflowSpecCategory
2022-03-16 12:49:35 -04:00
fields = ["id", "display_name", "display_order", "admin"]
@post_load
def make_cat(self, data, **kwargs):
return WorkflowSpecCategory(**data)
class WorkflowSpecInfo(object):
2022-02-08 14:40:33 -05:00
def __init__(self, id, display_name, description, is_master_spec=False,
standalone=False, library=False, primary_file_name='', primary_process_id='',
2022-02-09 11:37:54 -05:00
libraries=[], category_id="", display_order=0, is_review=False):
self.id = id # Sting unique id
self.display_name = display_name
self.description = description
2022-02-07 09:12:11 -05:00
self.display_order = display_order
self.is_master_spec = is_master_spec
self.standalone = standalone
self.library = library
self.primary_file_name = primary_file_name
self.primary_process_id = primary_process_id
self.is_review = is_review
self.libraries = libraries
2022-02-08 11:30:13 -05:00
self.category_id = category_id
def __eq__(self, other):
if not isinstance(other, WorkflowSpecInfo):
return False
if other.id == self.id:
return True
return False
class WorkflowSpecInfoSchema(ma.Schema):
class Meta:
model = WorkflowSpecInfo
id = marshmallow.fields.String(required=True)
display_name = marshmallow.fields.String(required=True)
description = marshmallow.fields.String()
is_master_spec = marshmallow.fields.Boolean(required=True)
standalone = marshmallow.fields.Boolean(required=True)
library = marshmallow.fields.Boolean(required=True)
display_order = marshmallow.fields.Integer(allow_none=True)
primary_file_name = marshmallow.fields.String(allow_none=True)
primary_process_id = marshmallow.fields.String(allow_none=True)
is_review = marshmallow.fields.Boolean(allow_none=True)
category_id = marshmallow.fields.String(allow_none=True)
libraries = marshmallow.fields.List(marshmallow.fields.String(), allow_none=True)
2022-02-07 16:27:45 -05:00
@post_load
def make_spec(self, data, **kwargs):
return WorkflowSpecInfo(**data)
class WorkflowState(enum.Enum):
hidden = "hidden"
disabled = "disabled"
required = "required"
optional = "optional"
locked = "locked"
@classmethod
def has_value(cls, value):
return value in cls._value2member_map_
@staticmethod
def list():
return list(map(lambda c: c.value, WorkflowState))
class WorkflowStatus(enum.Enum):
not_started = "not_started"
user_input_required = "user_input_required"
waiting = "waiting"
complete = "complete"
erroring = "erroring"
class WorkflowModel(db.Model):
__tablename__ = 'workflow'
id = db.Column(db.Integer, primary_key=True)
bpmn_workflow_json = deferred(db.Column(db.JSON))
status = db.Column(db.Enum(WorkflowStatus))
study_id = db.Column(db.Integer, db.ForeignKey('study.id'))
study = db.relationship("StudyModel", backref='workflow', lazy='select')
2022-02-07 12:18:32 -05:00
workflow_spec_id = db.Column(db.String)
total_tasks = db.Column(db.Integer, default=0)
completed_tasks = db.Column(db.Integer, default=0)
last_updated = db.Column(db.DateTime(timezone=True), server_default=func.now())
user_id = db.Column(db.String, default=None)
2022-05-06 14:02:11 -04:00
state = db.Column(db.String, nullable=True)