Cedarling Properties#
These Bootstrap Properties control default application level behavior.
CEDARLING_APPLICATION_NAME: Human friendly identifier for this applicationCEDARLING_POLICY_STORE_URI: Location of policy store JSON, used if policy store is not local, or retreived from Lock Master.CEDARLING_POLICY_STORE_ID: The identifier of the policy store in case there is more then one policy_store_id in the policy store.CEDARLING_USER_AUTHZ: Whenenabled, Cedar engine authorization is queried for a User principal.CEDARLING_WORKLOAD_AUTHZ: Whenenabled, Cedar engine authorization is queried for a Workload principal.CEDARLING_USER_WORKLOAD_BOOLEAN_OPERATION:AND,ORCEDARLING_MAPPING_USER: Name of Cedar User schema entity if we don't want to use default. When specified cedarling try build defined entity (from schema) as user instead of defaultUserentity defined incedarschema. Works in namespace defined in the policy store.CEDARLING_MAPPING_WORKLOAD: Name of Cedar Workload schema entityCEDARLING_MAPPING_ID_TOKEN: Name of Cedar id_token schema entityCEDARLING_MAPPING_ACCESS_TOKEN: Name of Cedar access_token schema entityCEDARLING_MAPPING_USERINFO_TOKEN: Name of Cedar userinfo schema entity
The following bootstrap properties are needed to configure log behavior:
CEDARLING_LOG_STORAGE:off,memory,std_outCEDARLING_LOG_LEVEL: System Log Level See here. Default toWARNCEDARLING_LOG_STDOUT_TYPE: EitherSystem,Metric, orDecision. Default to System.CEDARLING_LOG_LEVEL: Log level filter for logging. Log level has onlySystemlog type entries.TRACEis lowest.FATALis highest. Possible variants:- FATAL
- ERROR
- WARN
- INFO
- DEBUG
- TRACE
CEDARLING_DECISION_LOG_USER_CLAIMS: List of claims to map from user entity, such as ["sub", "email", "username", ...]CEDARLING_DECISION_LOG_WORKLOAD_CLAIMS: List of claims to map from user entity, such as ["client_id", "rp_id", ...]CEDARLING_DECISION_LOG_DEFAULT_JWT_ID: Token claims that will be used for decision logging. Default is "jti", but perhaps some other claim is needed.CEDARLING_LOG_TTL: in case ofmemorystore, TTL (time to live) of log entities in seconds.
The following bootstrap properties are needed to configure JWT and cryptographic behavior:
CEDARLING_LOCAL_JWKS: JWKS file with public keysCEDARLING_LOCAL_POLICY_STORE: JSON object with policy storeCEDARLING_POLICY_STORE_LOCAL_FN: Local file with JSON object with policy storeCEDARLING_JWT_SIG_VALIDATION:Enabled|Disabled-- Whether to check the signature of all JWT tokens. This requires anissis present.CEDARLING_JWT_STATUS_VALIDATION:Enabled|Disabled-- Whether to check the status of the JWT. On startup, the Cedarling should fetch and retreive the latest Status List JWT from the.well-known/openid-configurationvia thestatus_list_endpointclaim and cache it. See the IETF Draft for more info.CEDARLING_JWT_SIGNATURE_ALGORITHMS_SUPPORTED: Only tokens signed with these algorithms are acceptable to the Cedarling.CEDARLING_AT_ISS_VALIDATION: When enabled, theissclaim must be present in access token and the scheme must behttps.CEDARLING_AT_JTI_VALIDATION: When enabled, thejticlaim must be present in access token.CEDARLING_AT_NBF_VALIDATION: When enabled, thenbfclaim must be present in access token and the Cedarling should verify that the current date is after thenbf.CEDARLING_AT_EXP_VALIDATION: When enabled, theexpclaim must be present and not past the date specified.CEDARLING_IDT_ISS_VALIDATION: When enabled, theissclaim must be present in id_token and the scheme must behttps.CEDARLING_IDT_SUB_VALIDATION: When enabled, thesubclaim must be present in id_token.CEDARLING_IDT_EXP_VALIDATION: When enabled, theexpclaim must be present and not past the date specified.CEDARLING_IDT_IAT_VALIDATION: When enabled, theiatclaim must be present in id_token.CEDARLING_IDT_AUD_VALIDATION: When enabled, theaudclaim must be present in id_token.CEDARLING_USERINFO_ISS_VALIDATION: When enabled, theissclaim must be present and the scheme must behttps.CEDARLING_USERINFO_SUB_VALIDATION: When enabled, thesubclaim must be present in Userinfo JWT.CEDARLING_USERINFO_AUD_VALIDATION: When enabled, theaudclaim must be present in Userinfo JWT.CEDARLING_USERINFO_EXP_VALIDATION: When enabled, theexpclaim must be present and not past the date specified.CEDARLING_ID_TOKEN_TRUST_MODE:Strict|None. Varying levels of validations based on the preference of the developer.Strictmode requires (1) id_tokenaudmatches the access_tokenclient_id; (2) if a Userinfo token is present, thesubmatches the id_token, and that theaudmatches the access token client_id.
The following bootstrap properties are only needed for enterprise deployments.
CEDARLING_LOCK: Enabled | Disabled. If Enabled, the Cedarling will connect to the Lock Master for policies, and subscribe for SSE events.CEDARLING_LOCK_MASTER_CONFIGURATION_URI: Required ifLOCK==Enabled. URI where Cedarling can get JSON file with all required metadata about Lock Master, i.e..well-known/lock-master-configuration.CEDARLING_LOCK_DYNAMIC_CONFIGURATION: Enabled | Disabled, controls whether Cedarling should listen for SSE config updates.CEDARLING_LOCK_SSA_JWT: SSA for DCR in a Lock Master deployment. The Cedarling will validate this SSA JWT prior to DCR.CEDARLING_LOCK_LOG_INTERVAL: How often to send log messages to Lock Master (0 to turn off trasmission).CEDARLING_LOCK_HEALTH_INTERVAL: How often to send health messages to Lock Master (0 to turn off transmission).CEDARLING_LOCK_TELEMETRY_INTERVAL: How often to send telemetry messages to Lock Master (0 to turn off transmission).CEDARLING_LOCK_LISTEN_SSE: Enabled | Disabled: controls whether Cedarling should listen for updates from the Lock Server.
User-Workload Boolean Operation#
The CEDARLING_USER_WORKLOAD_BOOLEAN_OPERATION property specifies what boolean operation to use for the USER and WORKLOAD when making authz (authorization) decisions.
Available Operations#
- AND: authz will be successful if
USERANDWORKLOADis valid. - OR: authz will be successful if
USERORWORKLOADis valid.
ID Token Trust Mode#
The level of validation for the ID Token JWT can be set to either None or Strict.
None Mode#
Setting the validation level to None will not check for the conditions outlined in Strict Mode.
Strict Mode#
Strict mode requires:
- The
id_token'saudmatches theaccess_token'sclient_id; - if a Userinfo token is present, the
submatches theid_token, and that theaudmatches the access token'sclient_id.
Local JWKS#
A local JWKS can be used by setting the CEDARLING_LOCAL_JWKS bootstrap property to a path to a local JSON file. When providing a local Json Web Key Store (JWKS), the file must follow the following schema:
{
"trusted_issuer_id": [ ... ]
"another_trusted_issuer_id": [ ... ]
}
- Where keys are
Trusted Issuer IDsassigned to each key store - and the values contains the JSON Web Keys as defined in RFC 7517.
- The
trusted_issuers_idis used to tag a JWKS with a unique identifier and enables using multiple key stores.
Loading the bootstrap config#
There are multiple ways to load your bootstrap config:
You can load from both file types using the following code snippet:
use cedarling::BootstrapConfig;
let config =
BootstrapConfig::load_from_file("./path/to/your/config.json").unwrap();
Loading From JSON#
Below is an example of a bootstrap config in JSON format. Not all fields should be specified, almost all have default value.
{
"CEDARLING_APPLICATION_NAME": "My App",
"CEDARLING_POLICY_STORE_URI": "",
"CEDARLING_POLICY_STORE_ID": "840da5d85403f35ea76519ed1a18a33989f855bf1cf8",
"CEDARLING_LOG_TYPE": "memory",
"CEDARLING_LOG_LEVEL": "INFO",
"CEDARLING_DECISION_LOG_USER_CLAIMS": ["sub", "email", "username"],
"CEDARLING_DECISION_LOG_WORKLOAD_CLAIMS": ["client_id", "rp_id"],
"CEDARLING_DECISION_LOG_DEFAULT_JWT_ID": "jti",
"CEDARLING_LOG_TTL": 60,
"CEDARLING_USER_AUTHZ": "enabled",
"CEDARLING_WORKLOAD_AUTHZ": "enabled",
"CEDARLING_USER_WORKLOAD_BOOLEAN_OPERATION": "AND",
"CEDARLING_MAPPING_USER": "CustomUser",
"CEDARLING_MAPPING_WORKLOAD": "CustomWorkload",
"CEDARLING_MAPPING_ID_TOKEN": "CustomIdToken",
"CEDARLING_MAPPING_ACCESS_TOKEN": "CustomAccessToken",
"CEDARLING_MAPPING_USERINFO_TOKEN": "CustomUserinfoToken",
"CEDARLING_LOCAL_JWKS": "../test_files/local_jwks.json",
"CEDARLING_LOCAL_POLICY_STORE": null,
"CEDARLING_POLICY_STORE_LOCAL_FN": "../test_files/policy-store_blobby.json",
"CEDARLING_JWT_SIG_VALIDATION": "enabled",
"CEDARLING_JWT_STATUS_VALIDATION": "disabled",
"CEDARLING_JWT_SIGNATURE_ALGORITHMS_SUPPORTED": [
"HS256",
"RS256"
],
"CEDARLING_AT_ISS_VALIDATION": "disabled",
"CEDARLING_AT_JTI_VALIDATION": "disabled",
"CEDARLING_AT_NBF_VALIDATION": "disabled",
"CEDARLING_AT_EXP_VALIDATION": "enabled",
"CEDARLING_IDT_ISS_VALIDATION": "enabled",
"CEDARLING_IDT_SUB_VALIDATION": "enabled",
"CEDARLING_IDT_EXP_VALIDATION": "enabled",
"CEDARLING_IDT_IAT_VALIDATION": "enabled",
"CEDARLING_IDT_AUD_VALIDATION": "enabled",
"CEDARLING_USERINFO_ISS_VALIDATION": "enabled",
"CEDARLING_USERINFO_SUB_VALIDATION": "enabled",
"CEDARLING_USERINFO_AUD_VALIDATION": "enabled",
"CEDARLING_USERINFO_EXP_VALIDATION": "enabled",
"CEDARLING_ID_TOKEN_TRUST_MODE": "Strict",
"CEDARLING_LOCK": "disabled",
"CEDARLING_LOCK_MASTER_CONFIGURATION_URI": null,
"CEDARLING_DYNAMIC_CONFIGURATION": "disabled",
"CEDARLING_LOCK_SSA_JWT": null,
"CEDARLING_AUDIT_HEALTH_INTERVAL": 0,
"CEDARLING_AUDIT_TELEMETRY_INTERVAL": 0,
"CEDARLING_LISTEN_SSE": "disabled"
}
- Note that properties set to
"disabled", an empty string"", zero0, andnullcan be ommited since they are the defaults.
Local JWKS#
A local JWKS can be used by setting the CEDARLING_LOCAL_JWKS bootstrap property to a path to a local JSON file. When providing a local Json Web Key Store (JWKS), the file must follow the following schema:
{
"trusted_issuer_id": [ ... ]
"another_trusted_issuer_id": [ ... ]
}
- Where keys are
Trusted Issuer IDsassigned to each key store - and the values contains the JSON Web Keys as defined in RFC 7517.
-
The
trusted_issuers_idis used to tag a JWKS with a unique identifier and enables using multiple key stores. -
Note that properties set to
"disabled", an empty string"", zero0, andnullcan be ommited since they are the defaults.
Loading From YAML#
Below is an example of a bootstrap config in YAML format. Not all fields should be specified, almost all have default value.
CEDARLING_APPLICATION_NAME: My App
CEDARLING_POLICY_STORE_URI: ''
CEDARLING_POLICY_STORE_ID: '840da5d85403f35ea76519ed1a18a33989f855bf1cf8'
CEDARLING_LOG_TYPE: 'memory'
CEDARLING_LOG_LEVEL: 'INFO'
CEDARLING_DECISION_LOG_USER_CLAIMS: ["sub","email"]
CEDARLING_DECISION_LOG_WORKLOAD_CLAIMS: ["client_id", "rp_id"]
CEDARLING_LOG_TTL: 60
CEDARLING_USER_AUTHZ: 'enabled'
CEDARLING_WORKLOAD_AUTHZ: 'enabled'
CEDARLING_USER_WORKLOAD_BOOLEAN_OPERATION: 'AND'
CEDARLING_MAPPING_USER: 'CustomUser'
CEDARLING_MAPPING_WORKLOAD: 'CustomWorkload'
CEDARLING_MAPPING_ID_TOKEN: 'CustomIdToken'
CEDARLING_MAPPING_ACCESS_TOKEN: 'CustomAccessToken'
CEDARLING_MAPPING_USERINFO_TOKEN: 'CustomUserinfoToken'
CEDARLING_LOCAL_JWKS: '../test_files/local_jwks.json'
CEDARLING_LOCAL_POLICY_STORE: null
CEDARLING_POLICY_STORE_LOCAL_FN: '../test_files/policy-store_blobby.json'
CEDARLING_JWT_SIG_VALIDATION: 'enabled'
CEDARLING_JWT_STATUS_VALIDATION: 'disabled'
CEDARLING_JWT_SIGNATURE_ALGORITHMS_SUPPORTED:
- 'HS256'
- 'RS256'
CEDARLING_AT_ISS_VALIDATION: 'disabled'
CEDARLING_AT_JTI_VALIDATION: 'disabled'
CEDARLING_AT_NBF_VALIDATION: 'disabled'
CEDARLING_AT_EXP_VALIDATION: 'enabled'
CEDARLING_IDT_ISS_VALIDATION: 'enabled'
CEDARLING_IDT_SUB_VALIDATION: 'enabled'
CEDARLING_IDT_EXP_VALIDATION: 'enabled'
CEDARLING_IDT_IAT_VALIDATION: 'enabled'
CEDARLING_IDT_AUD_VALIDATION: 'enabled'
CEDARLING_USERINFO_ISS_VALIDATION: 'enabled'
CEDARLING_USERINFO_SUB_VALIDATION: 'enabled'
CEDARLING_USERINFO_AUD_VALIDATION: 'enabled'
CEDARLING_USERINFO_EXP_VALIDATION: 'enabled'
CEDARLING_ID_TOKEN_TRUST_MODE: 'Strict'
CEDARLING_LOCK: 'disabled'
CEDARLING_LOCK_MASTER_CONFIGURATION_URI: null
CEDARLING_DYNAMIC_CONFIGURATION: 'disabled'
CEDARLING_LOCK_SSA_JWT: 0
CEDARLING_AUDIT_HEALTH_INTERVAL: 0
CEDARLING_AUDIT_TELEMETRY_INTERVAL: 0
CEDARLING_LISTEN_SSE: 'disabled'
- Note that properties set to
'disabled', an empty string'', zero0, andnullcan be ommited since they are the defaults.
Created: 2024-10-08