single workspace role for task order officers
This commit is contained in:
parent
d41f233f5a
commit
95e7adfcf3
@ -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"
|
||||
|
@ -48,3 +48,15 @@ def test_add_officer_with_nonexistent_role():
|
||||
owner = task_order.workspace.owner
|
||||
with pytest.raises(TaskOrderError):
|
||||
TaskOrders.add_officer(owner, task_order, "pilot", ko.to_dictionary())
|
||||
|
||||
|
||||
def test_add_officer_who_is_already_workspace_member():
|
||||
task_order = TaskOrderFactory.create()
|
||||
owner = task_order.workspace.owner
|
||||
TaskOrders.add_officer(
|
||||
owner, task_order, "contracting_officer", owner.to_dictionary()
|
||||
)
|
||||
|
||||
assert task_order.contracting_officer == owner
|
||||
member = task_order.workspace.members[0]
|
||||
assert member.user == owner and member.role_name == "owner"
|
||||
|
@ -150,9 +150,7 @@ def test_invite_officers_to_task_order(queue):
|
||||
assert len(workspace.members) == 4
|
||||
roles = [member.role.name for member in workspace.members]
|
||||
# officers exist in roles
|
||||
assert "contracting_officer" in roles
|
||||
assert "contracting_officer_representative" in roles
|
||||
assert "security_officer" in roles
|
||||
assert roles.count("officer") == 3
|
||||
# email invitations are enqueued
|
||||
assert len(queue.get_queue()) == 3
|
||||
# task order has relationship to user for each officer role
|
||||
|
Loading…
x
Reference in New Issue
Block a user