DSL syntax: system authentication store
The scripts that you can use with the SystemAuthenticationControl feature to update the system authentication store are formatted according to a domain-specific language (DSL). You can use the script builders provided in the APIs to create a script to update the system authentication store. However, if you want to create the script by some other method, ensure that it conforms to the DSL.
The following sections each describe the syntax for a single line of the file.
Adding a principal
data:image/s3,"s3://crabby-images/a94af/a94af66d69fd9f6197b23ca2abcfc4aa86289c64" alt="A railroad diagram that describes the syntax used to add a principal to the system authentication store: ADD PRINCIPAL principal password. This can, optionally, be followed by a comma-separated list of roles inside square brackets."
add principal "user6" "passw0rd" add principal "user13" "passw0rd" ["CLIENT", "TOPIC_CONTROL"]
The password is passed in as plain text, but is stored in the system authentication store as a secure hash.
Removing a principal
data:image/s3,"s3://crabby-images/02525/0252546e3a17205f18862181e8519e2c7549d321" alt="A railroad diagram that describes the syntax used to remove a principal from the system authentication store: REMOVE PRINCIPAL principal."
remove principal "user25"
Assigning roles to a principal
data:image/s3,"s3://crabby-images/e71c0/e71c097260922588003cdd15469a5da5e4c0105c" alt="A railroad diagram that describes the syntax used to assign roles to a principal in the system authentication store: ASSIGN ROLES principal, followed by a comma-separated list of roles inside square brackets."
assign roles "agent77" ["CLIENT", "CLIENT_CONTROL"]
When you use this command to assign roles to a principal, it overwrites any existing roles assigned to that principal. Ensure that all the roles you want the principal to have are listed in the command.
Setting the password for a principal
data:image/s3,"s3://crabby-images/ed40b/ed40bace00eb7197740d727101558b3d78ce4306" alt="A railroad diagram that describes the syntax used to set the password of a principal in the system authentication store: SET PASSWORD principal password."
set password "user1" "passw0rd"
The password is passed in as plain text, but is stored in the system authentication store as a secure hash.
Verifying the password for a principal
data:image/s3,"s3://crabby-images/12246/12246d57cdfb03452767a0da548b577ff6d774ed" alt="A railroad diagram that describes the syntax used to verify the password of a principal in the system authentication store: VERIFY PASSWORD principal password."
verify password "user1" "passw0rd"
The password is passed in as plain text, but is stored in the system authentication store as a secure hash.
Allowing anonymous connections
data:image/s3,"s3://crabby-images/4d34d/4d34dcb9c781f1b0c32fbac5dab8e90360fdc63e" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to allow anonymous connections: ALLOW ANONYMOUS CONNECTIONS. This can, optionally, be followed by a comma-separated list of roles inside square brackets."
allow anonymous connections [ "CLIENT" ]
Denying anonymous connections
data:image/s3,"s3://crabby-images/5fc5a/5fc5a9cefd04f87d8ded394c6124a4111661dbd0" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to deny anonymous connections: DENY ANONYMOUS CONNECTIONS."
deny anonymous connections
Abstaining from providing a decision about anonymous connections
data:image/s3,"s3://crabby-images/8cd0f/8cd0f2131d601175862ff983e1b8ddb2e6ad7cbf" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to abstain from decisions about anonymous connections: ABSTAIN ANONYMOUS CONNECTIONS."
abstain anonymous connections
Accepting client-proposed session properties with approved values
data:image/s3,"s3://crabby-images/f3523/f35238dfd0575f38d3ac0525dbf0bea6e522c243" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to accept client-proposed properties from a list."
trust client proposed property "Foo" if value in ["x", "y", "z"]
Accepting client-proposed session properties matching a regex
data:image/s3,"s3://crabby-images/8f82a/8f82a08bff3d0c2bc5130c7bb8c0205580e42ec4" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to accept client-proposed properties matching a regex."
trust client proposed property "Foo" if value matches "^\d{3}-?\d{2}-?\d{4}$"
Use Java-style regular expressions. Evaluation uses java.util.regex.Pattern.
Removing a previously-declared trusted client-proposed session property
data:image/s3,"s3://crabby-images/35b05/35b05282421a4e1265bfb1dacb7c248f0104f6d4" alt="A railroad diagram that describes the syntax used to tell the system authentication handler to ignore a previously trusted client-proposed property."
ignore client proposed property "Foo"
Isolating a path from permissions inheritance
data:image/s3,"s3://crabby-images/906b5/906b5c91b49fee095bed5b5953882bb6b166ca43" alt="A railroad diagram that describes the syntax used to isolate a path.."
isolate path "foo/bar/baz"