aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala
diff options
context:
space:
mode:
authorKseniya Tomskikh <ktomskih@datamonsters.co>2017-08-02 15:25:17 +0600
committerKseniya Tomskikh <ktomskih@datamonsters.co>2017-08-02 16:54:04 +0600
commit98cecaebc650584f66d8c28c8424e8481c4814cc (patch)
tree01e7b230c5ce8599b4f726a5abc7664d8e08bb07 /src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala
parent31d5b35549fa49413692ecb3ecba7ee4c0b9cb4d (diff)
downloadrest-query-98cecaebc650584f66d8c28c8424e8481c4814cc.tar.gz
rest-query-98cecaebc650584f66d8c28c8424e8481c4814cc.tar.bz2
rest-query-98cecaebc650584f66d8c28c8424e8481c4814cc.zip
PDSUI-2181 Created entities for patient history
Diffstat (limited to 'src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala')
-rw-r--r--src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala36
1 files changed, 28 insertions, 8 deletions
diff --git a/src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala b/src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala
index 07d5014..f21c165 100644
--- a/src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala
+++ b/src/main/scala/xyz/driver/pdsuicommon/acl/ACL.scala
@@ -85,7 +85,11 @@ object ACL extends PhiLogging {
extends BaseACL(
label = "extracted data",
create = Set(DocumentExtractor, RecordAdmin),
- read = Set(DocumentExtractor, RecordAdmin, RoutesCurator, TreatmentMatchingAdmin, ResearchOncologist),
+ read = Set(DocumentExtractor,
+ RecordAdmin,
+ RoutesCurator,
+ TreatmentMatchingAdmin,
+ ResearchOncologist),
update = Set(DocumentExtractor, RecordAdmin),
delete = Set(DocumentExtractor, RecordAdmin)
)
@@ -151,7 +155,11 @@ object ACL extends PhiLogging {
extends BaseACL(
label = "criterion",
create = Set(CriteriaCurator, TrialAdmin),
- read = Set(CriteriaCurator, TrialAdmin, RoutesCurator, TreatmentMatchingAdmin, ResearchOncologist),
+ read = Set(CriteriaCurator,
+ TrialAdmin,
+ RoutesCurator,
+ TreatmentMatchingAdmin,
+ ResearchOncologist),
update = Set(CriteriaCurator, TrialAdmin),
delete = Set(CriteriaCurator, TrialAdmin)
)
@@ -187,6 +195,12 @@ object ACL extends PhiLogging {
update = TreatmentMatchingRoles
)
+ object PatientHistory
+ extends BaseACL(
+ label = "patient history",
+ read = Set(TreatmentMatchingAdmin)
+ )
+
object PatientIssue
extends BaseACL(
label = "patient issue",
@@ -238,26 +252,32 @@ object ACL extends PhiLogging {
update: AclCheck = Forbid,
delete: AclCheck = Forbid) {
- def isCreateAllow()(implicit requestContext: AuthenticatedRequestContext): Boolean = {
+ def isCreateAllow()(
+ implicit requestContext: AuthenticatedRequestContext): Boolean = {
check("create", create)(requestContext.executor.roles)
}
- def isReadAllow()(implicit requestContext: AuthenticatedRequestContext): Boolean = {
+ def isReadAllow()(
+ implicit requestContext: AuthenticatedRequestContext): Boolean = {
check("read", read)(requestContext.executor.roles)
}
- def isUpdateAllow()(implicit requestContext: AuthenticatedRequestContext): Boolean = {
+ def isUpdateAllow()(
+ implicit requestContext: AuthenticatedRequestContext): Boolean = {
check("update", update)(requestContext.executor.roles)
}
- def isDeleteAllow()(implicit requestContext: AuthenticatedRequestContext): Boolean = {
+ def isDeleteAllow()(
+ implicit requestContext: AuthenticatedRequestContext): Boolean = {
check("delete", delete)(requestContext.executor.roles)
}
- private def check(action: String, isAllowed: AclCheck)(executorRoles: Set[Role]): Boolean = {
+ private def check(action: String, isAllowed: AclCheck)(
+ executorRoles: Set[Role]): Boolean = {
loggedError(
executorRoles.exists(isAllowed),
- phi"${Unsafe(executorRoles.mkString(", "))} has no access to ${Unsafe(action)} a ${Unsafe(label)}"
+ phi"${Unsafe(executorRoles.mkString(", "))} has no access to ${Unsafe(
+ action)} a ${Unsafe(label)}"
)
}
}