codekanzlei / cake-auth-actions
Simple ACL alternative for CakePHP 4
Installs: 65 078
Dependents: 2
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 2
Open Issues: 0
Type:cakephp-plugin
pkg:composer/codekanzlei/cake-auth-actions
Requires
- php: >=7.2.0
- cakephp/cakephp: ^4.0.0-RC1
Requires (Dev)
- phpstan/phpstan: ^0.11
- scherersoftware/coding-standard: ^4.0-dev
This package is auto-updated.
Last update: 2025-09-29 01:46:44 UTC
README
A simple, configuration based ACL alternative for CakePHP 4. Allows you to define specific access rights to controller actions for different kinds of users.
Installation
1. Install the plugin via composer
composer require codekanzlei/auth-actions
2. Load the plugin in your src/Application.php
$this->addPlugin('AuthActions');
Usage & Configuration
1. Configure AppController.php
In your src/Controller/AppController.php, insert the following pieces of code in the matching sections:
Traits:
use \AuthActions\Lib\AuthActionsTrait;
...
use AuthActionsTrait;
$components:
public $components = [
    'Auth' => [
        'authenticate' => [
            'Form' => [
                'repository' => 'Users',
                'scope' => [
                    'status' => Status::ACTIVE,
                ]
            ]
        ],
        'authorize' => ['Controller'],
        'loginAction' => [], // prefered login view
        'loginRedirect' => [], // redirect after successful login
        'logoutRedirect' => [], // redirect after logout
        'authError' => 'PERMISSION_DENIED',
        
        // namespace declaration of AuthUtilsComponent
        'AuthActions.AuthUtils'
    ]
];
beforeFilter():
public function beforeFilter(\Cake\Event\Event $event)
{
    $this->initAuthActions();
}
2. Configure AppView.php
initialize():
public function initialize()
{
    $this->loadHelper('Auth', [
        'className' => 'AuthActions.Auth'
    ]);
}
3. Create additional files
In your project's config folder, create the required config files.
Note: For reference, see these files:
- 
auth_actions.php-defaulthere you can grant or restrict access to Controller functions to certain user roles. 
- 
user_rights.php-defaulthere you can define further custom access rights, allowing easy control over which buttons will be rendered in view files, depending on the role of the user that's viewing them. 
See [4. Grant/Restrict group rights](#### 4. Grant/Restrict group rights) for further information and example code snippets.
auth_actions.php
touch config/auth_actions.php
user_rights.php
touch config/user_rights.php
3. Define custom user roles
Add a new column namend role to your database users table.
In your User.php, you can define custom user roles as constants.
A commonly used, basic set of user roles ADMIN and USER can be defined as follows:
const ROLE_ADMIN = 'admin';
const ROLE_USER = 'user';
4. Grant/Restrict group rights
Following the example of a simple USER and ADMIN setup above, consider the following commonly needed use-cases.
- 
restricting access for non-admin users: Consider a basic "Users" MVC setup. Assuming you wish to only grant ADMINS access to every controller-action, including edit() as well as any functions added later on, while restricting USERS from all functions except for index() and view(). In auth_actions.php:$config = [ 'auth_actions' => [ // Controller name: 'Users' 'Users' => [ // wildcard * includes every action in this controller '*' => [ User::ROLE_ADMIN ], // here we explicitly list actions that // USERS shall be able to access 'index' => [ User::ROLE_USER ], 'view' => [ User::ROLE_USER ] ] ] ];
- 
preventing buttons from being rendered in a view: The above code will prevent USERS from calling any action in UsersController except for index() and view() but - for example - edit buttons next to User entities in your index-view will still be rendered. Here's how you can prevent them from being rendered if the view file is being viewes by a non-ADMIN user: In user_rights.php:$config = [ 'user_rights' => [ // granting a custom right only for Users of type ADMIN 'viewEditButton' => [ User::ROLE_ADMIN ] ] ];In your index view: <?php if ($this->Auth->hasRight('viewEditButton')): ?> <?= $this->Html->link(__('Edit'), ['action' => 'edit', $user->id]) ?> <?php endif; ?>