Download the PHP package albertotain/acl-manager without Composer
On this page you can find all versions of the php package albertotain/acl-manager. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download albertotain/acl-manager
More information about albertotain/acl-manager
Files in albertotain/acl-manager
Package acl-manager
Short Description AclManager plugin for CakePHP 4
License MIT
Informations about the package acl-manager
CakePHP Acl Manager
Installation
Composer
You can install this plugin into your CakePHP application using composer.
The recommended way to install composer packages is:
Getting started
- Install the CakePHP ACL plugin by running composer require cakephp/acl. Read Acl plugin documentation.
- Set AclManager configuration. AclManager.aros. Must be specified before load plugin.
- Load the Acl and AclManager plugins in app/config/bootstrap.php.
Warning: It is not recommended to use Plugin::loadAll();. if you use Plugin::loadAll(); make sure it will not load any plugin several times with Plugin::load('PluginName').
Configuration parameters
Must be specified before load plugin.
-
AclManager.aros Required. Sets the AROs to be used. The value of this parameter must be an array with the names of the AROs to be used.
-
AclManager.admin Optional. Set 'admin' prefix. The value of this parameter must be boolean.
-
AclManager.hideDenied Hide plugins, controllers and actions denied in ACLs lists.
- AclManager.ignoreActions Ignore all plugins, controllers and actions you don't want to add to your ACLs. The value of this parameter must be an array.
Creating ACL tables
To create ACL related tables, run the following Migrations command.
bin/cake migrations migrate -p Acl
Example schema
An example schema based on Groups, Roles and Users.
Auth
Include and configure the AuthComponent and the AclComponent in the AppController.
Model Setup
Acting as a requester
Add $this->addBehavior('Acl.Acl', ['type' => 'requester']); to the initialize function in the files src/Model/Table/GroupsTable.php, src/Model/Table/RolesTable.php and src/Model/Table/UsersTable.php.
Implement parentNode function in Group entity
Add the following implementation of parentNode to the file src/Model/Entity/Group.php.
Implement parentNode function in Role entity
Add the following implementation of parentNode to the file src/Model/Entity/Role.php.
Implement parentNode function in User entity
Add the following implementation of parentNode to the file src/Model/Entity/User.php.
Create a group, role, and user.
Allow all. Add in AppController.php.
Now create a group, role, and user.
Access the plugin
Now navigate to http://www.domain.com/AclManager ( or http://www.domain.com/admin/AclManager If AclManager.admin is set to true ), just click "Update ACOs and AROs and set default values", after update ACOs and AROs, remove $this->Auth->allow() from AppController.php and enjoy!
Known issues
- Not known.
Changelog
v1.3
Added
- AclManager.hideDenied Hide plugins, controllers and actions denied in ACLs lists.
Changed
-
AclManager.ignoreActions Ignore all plugins, controllers and actions you don't want to add to your ACLs.
- Updated indexctp and permissioins.ctp: Show or hide ACLs that do not have permissions in the ACL list. Show flash messages below the actions panel.
- Fixed acoUpdate syncronization.
About CakePHP Acl Manager
CakePHP - AclManager is a single plugin for manage CakePHP ACLs, based on the original idea of Frédéric Massart (FMCorz) for CakePHP 2.x.
Licensed
All versions of acl-manager with dependencies
cakephp/cakephp Version ^4.0
composer/installers Version *
cakephp/plugin-installer Version ~1.2
cakephp/acl Version ^0.7.1