API access rules
Ory Oathkeeper reaches decisions to allow or deny access by applying Access Rules. Access Rules can be stored on the file system,
set as an environment variable, or fetched from HTTP(s) remotes. These repositories can be configured in the configuration file
(oathkeeper -c ./path/to/config.yml ...
)
# Configures Access Rules
access_rules:
# Locations (list of URLs) where access rules should be fetched from on boot.
# It's expected that the documents at those locations return a JSON or YAML Array containing Ory Oathkeeper Access Rules.
repositories:
# If the URL Scheme is `file://`, the access rules (an array of access rules is expected) will be
# fetched from the local file system.
- file://path/to/rules.json
# If the URL Scheme is `inline://`, the access rules (an array of access rules is expected)
# are expected to be a base64 encoded (with padding!) JSON/YAML string (base64_encode(`[{"id":"foo-rule","authenticators":[....]}]`)):
- inline://W3siaWQiOiJmb28tcnVsZSIsImF1dGhlbnRpY2F0b3JzIjpbXX1d
# If the URL Scheme is `http://` or `https://`, the access rules (an array of access rules is expected) will be
# fetched from the provided HTTP(s) location.
- https://path-to-my-rules/rules.json
# If the URL Scheme is `s3://`, `gs://` or `azblob://`, the access rules (an array of access rules is expected)
# will be fetched by an object storage (AWS S3, Google Cloud Storage, Azure Blob Storage).
#
# S3 storage also supports S3-compatible endpoints served by Minio or Ceph.
# See aws.ConfigFromURLParams (https://godoc.org/gocloud.dev/aws#ConfigFromURLParams) for more details on supported URL options for S3.
- s3://my-bucket-name/rules.json
- s3://my-bucket-name/rules.json?endpoint=minio.my-server.net
- gs://gcp-bucket-name/rules.json
- azblob://my-blob-container/rules.json
# Determines a matching strategy for the access rules . Supported values are `glob` and `regexp`. Empty string defaults to regexp.
matching_strategy: glob
or by setting the equivalent environment variable:
export ACCESS_RULES_REPOSITORIES='file://path/to/rules.json,https://path-to-my-rules/rules.json,inline://W3siaWQiOiJmb28tcnVsZSIsImF1dGhlbnRpY2F0b3JzIjpbXX1d'
The repository (file, inline, remote) must be formatted either as a JSON or a YAML array containing the access rules:
cat ./rules.json
[{
"id": "my-first-rule"
},{
"id": "my-second-rule"
}]
cat ./rules.yaml
- id: my-first-rule
version: v0.36.0-beta.4
authenticators:
- handler: noop
- id: my-second-rule
version: v0.36.0-beta.4
authorizer:
handler: allow
Access rule format
Access Rules have four principal keys:
id
(string): The unique ID of the Access Rule.version
(string): The version of Ory Oathkeeper uses Semantic Versioning. Please usevMAJOR.MINOR.PATCH
notation format. Ory Oathkeeper can migrate access rules across versions. If left empty Ory Oathkeeper will assume that the rule uses the same tag as the running version. Examples:v0.1.3
orv1.2.3
upstream
(object): The location of the server where requests matching this rule should be forwarded to. This only needs to be set when using the Ory Oathkeeper Proxy as the Decision API doesn't forward the request to the upstream.url
(string): The URL the request will be forwarded to.preserve_host
(bool): If set tofalse
(default), the forwarded request will include the host and port of theurl
value. Iftrue
, the host and port of the Ory Oathkeeper Proxy will be used instead:false
: Incoming HTTP HeaderHost: mydomain.com
-> Forwarding HTTP HeaderHost: someservice.intranet.mydomain.com:1234
strip_path
(string): If set, replaces the provided path prefix when forwarding the requested URL to the upstream URL:- set to
/api/v1
: Incoming HTTP Request at/api/v1/users
-> Forwarding HTTP Request at/users
. - unset: Incoming HTTP Request at
/api/v1/users
-> Forwarding HTTP Request at/api/v1/users
.
- set to
match
(object): Defines the URL(s) this Access Rule should match.methods
(string[]): Array of HTTP methods (for example GET, POST, PUT, DELETE, ...).url
(string): The URL that should be matched. You can use regular expressions or glob patterns in this field to match more than one url. The matching strategy (glob or regexp) is defined in the global configuration file asaccess_rules.matching_strategy
. This matcher ignores query parameters. Regular expressions (or glob patterns) are encapsulated in brackets<
and>
.Regular expressions examples:
https://mydomain.com/
matcheshttps://mydomain.com/
and doesn't matchhttps://mydomain.com/foo
orhttps://mydomain.com
.<https|http>://mydomain.com/<.*>
matches:https://mydomain.com/
orhttp://mydomain.com/foo
. Doesn't match:https://other-domain.com/
orhttps://mydomain.com
.http://mydomain.com/<[[:digit:]]+>
matcheshttp://mydomain.com/123
and doesn't matchhttp://mydomain/abc
.http://mydomain.com/<(?!protected).*>
matcheshttp://mydomain.com/resource
and doesn't matchhttp://mydomain.com/protected
Glob patterns examples:
https://mydomain.com/<m?n>
matcheshttps://mydomain.com/man
and does not matchhttp://mydomain.com/foo
.https://mydomain.com/<{foo*,bar*}>
matcheshttps://mydomain.com/foo
orhttps://mydomain.com/bar
and doesn't matchhttps://mydomain.com/any
.
authenticators
: A list of authentication handlers that authenticate the provided credentials. Authenticators are checked iteratively from index0
ton
and the first authenticator to return a positive result will be the one used. If you want the rule to first check a specific authenticator before "falling back" to others, have that authenticator as the first item in the array. For the full list of available authenticators, click here.authorizer
: The authorization handler which will try to authorize the subject ("user") from the previously validated credentials making the request. For example, you could check if the subject ("user") is part of the "admin" group or if he/she has permission to perform that action. For the full list of available authorizers, click here.mutators
: A list of mutation handlers that transform the HTTP request before forwarding it. A common use case is generating a new set of credentials (for example JWT) which then will be forwarded to the upstream server. When using Ory Oathkeeper's Decision API, it's expected that the API Gateway forwards the mutated HTTP Headers to the upstream server. For the full list of available mutators, click here.errors
: A list of error handlers that are executed when any of the previous handlers (for example authentication) fail. Error handlers define what to do in case of an error, for example redirect the user to the login endpoint when a unauthorized (HTTP Status Code 401) error occurs. If left unspecified, errors will always be handled as JSON responses unless the global configuration keyerrors.fallback
was changed. For more information on error handlers, click here.
Examples
Rule in JSON format:
{
"id": "some-id",
"version": "v0.36.0-beta.4",
"upstream": {
"url": "http://my-backend-service",
"preserve_host": true,
"strip_path": "/api/v1"
},
"match": {
"url": "http://my-app/some-route/<.*>",
"methods": ["GET", "POST"]
},
"authenticators": [{ "handler": "noop" }],
"authorizer": { "handler": "allow" },
"mutators": [{ "handler": "noop" }],
"errors": [{ "handler": "json" }]
}
Rule in YAML format:
id: some-id
version: v0.36.0-beta.4
upstream:
url: http://my-backend-service
preserve_host: true
strip_path: /api/v1
match:
url: http://my-app/some-route/<.*>
methods:
- GET
- POST
authenticators:
- handler: noop
authorizer:
handler: allow
mutators:
- handler: noop
errors:
- handler: json
Handler configuration
Handlers (Authenticators, Mutators, Authorizers, Errors) sometimes require configuration. The configuration can be defined globally as well as per Access Rule. The configuration from the Access Rule is overrides values from the global configuration.
oathkeeper.yml
authenticators:
anonymous:
enabled: true
config:
subject: anon
rule.json
{
"id": "some-id",
"upstream": {
"url": "http://my-backend-service",
"preserve_host": true,
"strip_path": "/api/v1"
},
"match": {
"url": "http://my-app/some-route/<.*>",
"methods": ["GET", "POST"]
},
"authenticators": [{ "handler": "anonymous", "config": { "subject": "anon" } }],
"authorizer": { "handler": "allow" },
"mutators": [{ "handler": "noop" }]
}
Scoped credentials
Some credentials are scoped. For example, OAuth 2.0 Access Tokens usually are scoped ("OAuth 2.0 Scope"). Scope validation depends on the meaning of the scope. Therefore, wherever Ory Oathkeeper validates a scope, these scope strategies are supported:
hierarchic
: Scopefoo
matchesfoo
,foo.bar
,foo.baz
but notbar
wildcard
: Scopefoo.*
matchesfoo
,foo.bar
,foo.baz
but notbar
. Scopefoo
matchesfoo
but notfoo.bar
norbar
exact
: Scopefoo
matchesfoo
but notbar
norfoo.bar
none
: Scope validation is disabled. If however a scope is configured to be validated, the request will fail with an error message.
Match strategy behavior
With the Regular expression strategy, you can use the extracted groups in all handlers where the substitutions are supported
by using the Go text/template
package, receiving the
AuthenticationSession struct:
type AuthenticationSession struct {
Subject string
Extra map[string]interface{}
Header http.Header
MatchContext MatchContext
}
type MatchContext struct {
RegexpCaptureGroups []string
URL *url.URL
}
If the match URL is <https|http>://mydomain.com/<.*>
and the request is http://mydomain.com/foo
, the MatchContext
field will
contain
RegexpCaptureGroups
: ["http", "foo"]URL
: "http://mydomain.com/foo"