SystemAuthentication.store
The SystemAuthentication.store file defines the roles that are assigned by the system authentication handler to client sessions that have authenticated with a specific security principal. It also defines whether anonymous connections are allowed or denied.
The following sections each describe the syntax for a single line of the file.
Adding a principal
data:image/s3,"s3://crabby-images/a310c/a310c7c7c9f4710e3ca2685709d17628f822ed7a" 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/dbd1f/dbd1fb14d33b8e5f16fa47d1c19427a844ccea28" 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/d1c3c/d1c3cff4da2c073a3c14070b6324c76d3af2041f" 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/65224/652240c6220648cde3b7c6d7e9fd676b171da127" 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/31434/31434d5118d4ea33e000021d8e0a4b309992a63b" 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/5bff5/5bff527034e05df2b40002489779cf42f9d8b6ca" 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/b258e/b258e5cf2e51cad3e147f4e4df8a0a3794ca1fab" 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/f2668/f2668a91a686ab454bbde0124f4912d8efb2e80c" 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/01049/010497a53fa02bde3c278fecda93ab848f4699ab" 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/85a85/85a85aca3759606fb0721e757e90167b994ca243" 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/fa125/fa125c09626d7fb8738df704bb0e0b87ba5b50d5" 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/4d6bc/4d6bc82f7440838da85b9a95d151bcd8de3da579" alt="A railroad diagram that describes the syntax used to isolate a path.."
isolate path "foo/bar/baz"