Configuration ENTERPRISE
For most System types, Styra DAS knows the format of the decisions, for example, whether the decision represents an allow or a deny. For most System types, Styra DAS has no knowledge of what a decision log entry means. However, you can configure Styra DAS so that it understands enough of the decision log format to display and search it properly.
There are two types of decision log mappings:
- Default decision log mapping is applied to all decision logs.
- Custom decision log mapping overrides default mappings for specific packages or rules.
The package or rule name is required, for example rules/allowed.
To configure the decision log, go to <das-id>.styra.com
and navigate to SYSTEM >> Settings >> Decision Mappings.
You can configure the following three top-level nodes.
-
allowed: Shows only
allowed
decisions. Most policy decisions can be categorized asallowed
ordenied
. To configureallowed
you must provide the following components:- path: A simple Rego reference to a field in the decision. For example:
path.to.allowed.field
orpath["to"]["allowed"].field
. - expect: (optional) If the
path
has this string value, the decision isallowed
. Default value is the booleantrue
. - negated: (optional) If true, the decision is allowed if
path
does not equalexpect
.
- path: A simple Rego reference to a field in the decision. For example:
-
reason: The human-readable reason to make a decision, which is often included in a policy decision so that the system can return an error message to the user. To configure the reason for a decision, you must provide the following field:
- path: (optional) A simple Rego reference to a field in the decision. For example:
path.to.reason
orpath["to"].reason
.
- path: (optional) A simple Rego reference to a field in the decision. For example:
-
columns: When displayed in log form, each decision is shown in a log format, where you control which columns appear. For each column, you must provide the following information:
- path: A simple Rego reference to a field in the decision. For example:
path.to.value
orpath["to"].value
. - key: An alphanumeric name you can use to filter the decision log entries.
- type: (inferred if omitted) The type of this field (to support filtering). Possible values are
string
(same as leavingtype
empty),boolean
,date
,integer
,float
.
- path: A simple Rego reference to a field in the decision. For example:
The decision log size limit is 1 MB per decision by default. This can be increased for a tenant by contacting customer support.
The Styra DAS UI gives you the ability to control only some of the above details. The /systems
API gives you complete control over the configuration.
The following shows an example of the information that you will provide to the /systems
API:
{
"allowed": {
"path": "path.to.allowed",
"expect": "nope", // Optional.
"negated": true // Optional.
},
"columns": [
{
"key": "email", // Required for queries.
"path": "path.to.value", // Required.
"type": "string" // Inferred if omitted.
},
...
],
"reason": { // Optional.
"path": "path.to.reason",
}
}
You can use any path that is exposed in the decision log and easily find the paths by inspecting the decision log entries. For more information on decision logs, see the OPA decision logs page.
-
For a Custom System, per package Decision Mapping is done at the system level.
-
The decision logs are searchable for three days and always retained in storage.
Use Copy JSON Path
In the Styra DAS UI, the Copy JSON path action is useful for configuring decision log mappings. This action copies the path of any attribute in a decision log to your clipboard which avoids the need to backtrack the full path.
- Go to
<das-id>.styra.com
. - In the left navigation panel, click on a System (Kubernetes/Envoy/Custom), or under WORKSPACE, click on your tenant name.
- Click on the Decisions tab to view the live decision log.
- Expand a decision and right-click an attribute.
- Click on the Copy JSON path to copy the path of the decision or message attribute in a decision.
- Click on the Settings tab >> Decision Mappings pane and paste the path into the corresponding Path to decision or Path to message field.
You can also use the Copy JSON path action to copy path references from data source files, or the custom library JSON files, and paste them into Rego rules when writing policies.