single workspace role for task order officers

This commit is contained in:
dandds
2019-01-08 14:36:32 -05:00
parent d41f233f5a
commit 95e7adfcf3
6 changed files with 41 additions and 36 deletions

View File

@@ -102,18 +102,34 @@ class TaskOrders(object):
]
@classmethod
def add_officer(cls, user, task_order, role, officer_data):
if role in TaskOrders.OFFICERS:
member = Workspaces.create_member(
user, task_order.workspace, {**officer_data, "workspace_role": role}
def add_officer(cls, user, task_order, officer_type, officer_data):
if officer_type in TaskOrders.OFFICERS:
workspace = task_order.workspace
existing_member = next(
(
member
for member in workspace.members
if member.user.dod_id is officer_data["dod_id"]
),
None,
)
setattr(task_order, role, member.user)
if existing_member:
user = existing_member.user
else:
member = Workspaces.create_member(
user, workspace, {**officer_data, "workspace_role": "officer"}
)
user = member.user
setattr(task_order, officer_type, user)
db.session.add(task_order)
db.session.commit()
return member.user
return user
else:
raise TaskOrderError(
"{} is not an officer role on task orders".format(role)
"{} is not an officer role on task orders".format(officer_type)
)