rsthn / rose-ext-sentinel
Sentinel Authentication Extension
Installs: 657
Dependents: 3
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Type:rose-extension
Requires
- dev-master
- v3.0.3
- v3.0.2
- v3.0.1
- v3.0.0
- v2.0.6
- v2.0.5
- v2.0.4
- v2.0.3
- v2.0.2
- v2.0.1
- v2.0.0
- v1.1.2
- v1.1.1
- v1.1.0
- 1.0.38
- 1.0.37
- 1.0.36
- 1.0.35
- 1.0.34
- 1.0.33
- 1.0.32
- 1.0.31
- 1.0.30
- 1.0.29
- 1.0.28
- 1.0.27
- 1.0.26
- 1.0.25
- 1.0.24
- 1.0.23
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.0
This package is auto-updated.
Last update: 2024-12-27 08:27:08 UTC
README
This extension adds user authentication features to Rose.
composer require rsthn/rose-ext-sentinel
Database Structure
The following tables are required by Sentinel. Note that any of the tables below can be extended if desired, the columns shown are the required minimum.
CREATE TABLE users ( user_id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, created_at DATETIME NOT NULL, deleted_at DATETIME DEFAULT NULL, blocked_at DATETIME DEFAULT NULL, username VARCHAR(256) NOT NULL, password VARCHAR(96) NOT NULL ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci AUTO_INCREMENT=1; CREATE INDEX users_created_at ON users (created_at); CREATE INDEX users_deleted_at ON users (deleted_at); CREATE INDEX users_blocked_at ON users (blocked_at); CREATE INDEX users_username ON users (username, deleted_at);
CREATE TABLE permissions ( permission_id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, name VARCHAR(128) NOT NULL UNIQUE ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
CREATE TABLE user_permissions ( user_id INT NOT NULL, permission_id INT NOT NULL, flag INT DEFAULT 0, PRIMARY KEY (user_id, permission_id), FOREIGN KEY (user_id) REFERENCES users (user_id), FOREIGN KEY (permission_id) REFERENCES permissions (permission_id) ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci; CREATE INDEX user_permissions_flag ON user_permissions (user_id, flag);
Token Authorization
Whenever authorization via access tokens is desired (by setting auth_bearer
to true in the Sentinel configuration section), then add the following tables to your database as well:
CREATE TABLE tokens ( token_id INT PRIMARY KEY AUTO_INCREMENT, created_at DATETIME NOT NULL, deleted_at DATETIME DEFAULT NULL, blocked_at DATETIME DEFAULT NULL, user_id INT NOT NULL, token VARCHAR(128) NOT NULL UNIQUE, name VARCHAR(128) NOT NULL, FOREIGN KEY (user_id) REFERENCES users (user_id) ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci AUTO_INCREMENT=1; CREATE INDEX tokens_user_id ON tokens (user_id, deleted_at); CREATE INDEX tokens_token ON tokens (token, deleted_at);
CREATE TABLE token_permissions ( token_id INT NOT NULL, permission_id INT NOT NULL, flag INT DEFAULT 0, PRIMARY KEY (token_id, permission_id), FOREIGN KEY (token_id) REFERENCES tokens (token_id), FOREIGN KEY (permission_id) REFERENCES permissions (permission_id) ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci; CREATE INDEX token_permissions_flag ON token_permissions (token_id, flag);
Identifier Banning
Sentinel include support to blacklist identifiers that are trying to brute force the system. To use this feature check the sentinel:access-required
,sentinel:access-denied
and sentinel:access-granted
functions.
The following table is required for this feature:
CREATE TABLE suspicious_identifiers ( identifier VARCHAR(512) NOT NULL, PRIMARY KEY (identifier), next_attempt_at DATETIME DEFAULT NULL, last_attempt_at DATETIME NOT NULL, count_failed INT DEFAULT 1, count_blocked INT DEFAULT 0, is_banned INT DEFAULT 0 ) ENGINE=InnoDB CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci AUTO_INCREMENT=1;
Configuration Section: "Sentinel"
Functions
(sentinel:password
<password>)
Calculates the hash of the given password and returns it. The plain password gets the suffix
and prefix
configuration fields
appended and prepended respectively before calculating its hash. The hash algorithm is set by the hash
configuration field.
(sentinel:status
)
Returns the authentication status (boolean) of the active session.
(sentinel:auth-required
)
Fails with error code 401
if the active session is not authenticated.
(sentinel:permission-required
<permissions>)
Verifies if the active session has the specified permissions. Fails with 401
if the session has not been authenticated, or with
403
if the permission requirements are not met. The permissions string contains the permission names OR-sets separated by pipe (|),
and the AND-sets separated by ampersand (&).
(sentinel:permission-required "admin | provider & enabled | customer") ; false
(sentinel:has-permission
<permissions>)
Verifies if the active session has the specified permissions. Returns boolean. The permissions string contains the permission
name sets (see sentinel:permission-required
).
(sentinel:case
<case1> <result1> ... [default <default>])
Checks the permissions of the active user against one of the case values. Returns the respective result or the default result if
none matches. If no default result is specified an empty string will be returned. Note that each case result should be a value
not a block. Each case string is a permission name set (see sentinel:permission-required
).
(sentinel:case "admin" "Has permission admin" "client" "Has permission client" "x | y" "Has permission x or y" "a & b & c" "Has permission a, b and c" )
(sentinel:level-required
<level>)
Verifies if the active user meets the specified minimum permission level. The level is the permission_id divided by 100. Fails with 401
if the user has not been authenticated, or with 403
if the permission level requirements are not met.
(sentinel:has-level
<level>)
Verifies if the active user meets the specified minimum permission level. The level is the permission_id divided by 100. Returns boolean.
(sentinel:has-level 7) ; true
(sentinel:get-level
[username])
Returns the permission level of the active session user, or of the given user if username
is provided.
(sentinel:get-level "admin") ; 7
(sentinel:validate
<username> <password>)
Verifies if the given credentials are valid, returns boolean.
(sentinel:validate "admin" "admin") ; true
(sentinel:login
<username> <password>)
Verifies if the given credentials are valid, fails with 422
and sets the error
field accordingly. When successful, opens a session
and loads the user
field with the data of the user that has been authenticated.
Note that Sentinel will automatically run the login process (without creating a session) if the Authorization: BASIC data
header is detected
and the auth_basic
flag is enabled in the configuration.
When using Apache, the HTTP_AUTHORIZATION
header is not sent to the application, however by setting the following in your .htaccess
it
will be available for Sentinel to use it.
SetEnvIf Authorization "(.*)" HTTP_AUTHORIZATION=$1
(sentinel:authorize
<token> [persistent=false])
Checks if the auth_bearer
flag is set to true
in the Sentinel configuration and then verifies the validity of the token
and authorizes access. On errors return status code 422
and sets the error
field accordingly.
When successful, opens a session only if the persistent
flag is set to true
, and loads the user
field of the session
with the data of the user related to the token that was just authorized.
Note that Sentinel will automatically run the authorization process (without creating a session) if the Authorization: BEARER token
header is detected while auth_bearer
is enabled in the configuration.
(sentinel:token-id
)
Returns the token_id
of the active session or null
if the user is either not authenticated yet or the user
authenticated by other means without a token (i.e. regular login).
(sentinel:token-id) ; 13
(sentinel:login-manual
<data>)
Starts a session and loads the specified data object into the user
session field, effectively creating (manually) an
authenticated session. If the data being placed in the session does not actually exist in the database, ensure to use only
the sentinel:auth-required
and sentinel:logout
functions in your API, all others that query the database will fail.
(sentinel:login-manual { user_id 1 permissions ["admin"] })
(sentinel:login-user
<user_id>)
Verifies if the user exist and forces a login without any password. Fails with 422
and sets the error
field
accordingly. When successful, opens a session and loads the user
field of the session with the data of the user
that was just authenticated.
(sentinel:login-user 1)
(sentinel:logout
)
Removes authentication status from the active session. Note that this function does not remove the session itself, only
the authentication data related to the user. Use session:destroy
afterwards to fully remove the session completely.
(sentinel:reload
)
Reloads the active user's session data and permissions from the database. Do not call this function if you logged in in a
manual way using sentinel:login-manual
because the user's data you placed will be overwritten.
(sentinel:access-required
<identifier> [message])
Ensures the provided identifier is not either banned or blocked. Fails with status code 409
and with the default
error message if the message
parameter is not provided.
(sentinel:access-required "127.0.0.1" "Your IP has been blocked.") ; If identifier `127.0.0.1` is blocked: ; {"response":409, "error":"@messages.retry_later (60s)", "retry_at":"2024-11-21 11:20:00", "wait":60} (sentinel:access-required "127.0.0.1" "Your IP has been blocked.") ; If identifier `127.0.0.1` is banned: ; {"response":409, "error":"Your IP has been blocked."}
(sentinel:access-denied
<identifier> [action='auto'] [wait-timeout=2] [block-timeout=30])
Registers an access-denied attempt for the specified identifier. Returns a string indicating the action taken for
the identifier, valid values are auto
, wait
, block
, or ban
.
(sentinel:access-denied "127.0.0.1") ; "wait"
(sentinel:access-granted
<identifier> [unban=false])
Grants access to an identifier, calling this will reset the failed and blocked counters. A ban will continue
to be in effect unless the unban
parameter is set to true
.
(sentinel:access-granted "127.0.0.1" true) ; null