Authorize on Sessions¶
Preface¶
This guide will explain how to authorize a Subject's access request based on the Session which they intend to access.
This access rule is implemented as part of the Organisational Policy. As such, you should include this and the Diamond Data Bundle when you configure OPA or as described in the guide for your helm or local docker-compose deployment.
Delegate Policy Decisions¶
When loaded, you can delegate policy decisions of your system entrypoint to the Organisational Policy by calling the data.diamond.policy.session.access_session
function in your policy with the subject identifier, proposal number, and visit number.
The example below shows how you might write a system package which extracts the subject from the access token and checks they are allowed to view the requested session using data.diamond.policy.session.access_session
.
Example
package system
import data.diamond.policy.session
import rego.v1
# METADATA
# description: Allow if user is permitted to perform requested action
# entrypoint: true
main := {"allow": allow}
default allow := false
# Allow if action is view_session and subject is permitted
allow if {
subject := token.verify(input.token)
session.access_session(subject, input.proposal, input.visit)
}
The system policy decision can be queried at http://opa:8181
with use of the OPA REST Query API.
Example
POST
http://opa:8181
with:
{
"input": {
"token": "<YOUR_ACCESS_TOKEN>",
"proposal": 12345,
"visit": 42
}
}
Response:
{
"result": true
}