single workspace role for task order officers
This commit is contained in:
@@ -141,22 +141,10 @@ WORKSPACE_ROLES = [
|
||||
],
|
||||
},
|
||||
{
|
||||
"name": "contracting_officer",
|
||||
"description": "Can approve funding for a task order. Has view and edit permissions for task orders in a workspace.",
|
||||
"display_name": "Contracting Officer",
|
||||
"permissions": [Permissions.VIEW_WORKSPACE, Permissions.KO_SIGN_TASK_ORDER],
|
||||
},
|
||||
{
|
||||
"name": "contracting_officer_representative",
|
||||
"description": "Assists in submitting task order documents. Can update Task Order.",
|
||||
"display_name": "Contracting Officer Representative",
|
||||
"permissions": [Permissions.VIEW_WORKSPACE],
|
||||
},
|
||||
{
|
||||
"name": "security_officer",
|
||||
"description": "Can edit security questions for a task order.",
|
||||
"display_name": "Security Officer",
|
||||
"permissions": [Permissions.VIEW_WORKSPACE, Permissions.SO_SIGN_TASK_ORDER],
|
||||
"name": "officer",
|
||||
"description": "Officer involved with setting up a Task Order",
|
||||
"display_name": "Task Order Officer",
|
||||
"permissions": [],
|
||||
},
|
||||
]
|
||||
|
||||
|
@@ -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)
|
||||
)
|
||||
|
@@ -105,16 +105,10 @@ COMPLETION_DATE_RANGES = [
|
||||
("Above 12 months", "Above 12 months"),
|
||||
]
|
||||
|
||||
NONDISPLAY_ROLES = [
|
||||
"contracting_officer",
|
||||
"contracting_officer_representative",
|
||||
"security_officer",
|
||||
]
|
||||
|
||||
WORKSPACE_ROLES = [
|
||||
(role["name"], {"name": role["display_name"], "description": role["description"]})
|
||||
for role in WORKSPACE_ROLE_DEFINITIONS
|
||||
if role["name"] not in NONDISPLAY_ROLES
|
||||
if role["name"] is not "officer"
|
||||
]
|
||||
|
||||
ENVIRONMENT_ROLES = [
|
||||
|
@@ -42,6 +42,3 @@ class Permissions(object):
|
||||
|
||||
ADD_TAG_TO_WORKSPACE = "add_tag_to_workspace"
|
||||
REMOVE_TAG_FROM_WORKSPACE = "remove_tag_from_workspace"
|
||||
|
||||
KO_SIGN_TASK_ORDER = "ko_sign_task_order"
|
||||
SO_SIGN_TASK_ORDER = "so_sign_task_order"
|
||||
|
Reference in New Issue
Block a user