Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fmcorz/aclmanager
Plugin to manage Acl for CakePHP 2.x
https://github.com/fmcorz/aclmanager
aclmanager cakephp cakephp-plugin php
Last synced: about 7 hours ago
JSON representation
Plugin to manage Acl for CakePHP 2.x
- Host: GitHub
- URL: https://github.com/fmcorz/aclmanager
- Owner: FMCorz
- Created: 2011-08-14T14:56:28.000Z (over 13 years ago)
- Default Branch: stable
- Last Pushed: 2016-03-19T06:50:52.000Z (over 8 years ago)
- Last Synced: 2024-09-15T07:49:50.753Z (2 months ago)
- Topics: aclmanager, cakephp, cakephp-plugin, php
- Language: PHP
- Homepage:
- Size: 205 KB
- Stars: 59
- Watchers: 18
- Forks: 33
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# AclManager for CakePHP 2.x
This plugins allows you to easily manage your permissions in CakePHP 2.x through the Acl module.
## Features
* Managing permissions for each node
* Updating Database with missing AROs (Users, Roles, ...)
* Updating Database with missing ACOs (Controller actions)
* Revoking all permissions## Requirements
* CakePHP 2.x
## How to install
### 1. Set up your Acl environment
* Install SQL tables through Cake Console
* parentNode() method on your requester modelsSee: [CakePHP: Simple ACL Controlled Application](http://book.cakephp.org/2.0/en/tutorials-and-examples/simple-acl-controlled-application/simple-acl-controlled-application.html)
### 2. Configure Auth in your AppController
It should look something like this:
```php
var $components = array('Auth', 'Acl', 'Session');function beforeFilter() {
//Configure AuthComponent
$this->Auth->authorize = array(
'Controller',
'Actions' => array('actionPath' => 'controllers')
);
$this->Auth->authenticate = array(
'Form' => array(
'fields' => array(
'username' => 'login',
'password' => 'password'
)
)
);
$this->Auth->loginAction = array(
'controller' => 'users',
'action' => 'login',
'admin' => false,
'plugin' => false
);
$this->Auth->logoutRedirect = array(
'controller' => 'users',
'action' => 'login',
'admin' => false,
'plugin' => false
);
$this->Auth->loginRedirect = array(
'controller' => 'products',
'action' => 'index',
'admin' => false,
'plugin' => false
);
}function isAuthorized($user) {
// return false;
return $this->Auth->loggedIn();
}
```### 3. Download AclManager
#### Manually
Download the stable branch (https://github.com/FMCorz/AclManager/archive/stable.zip) and paste the content in your `app/Plugin/` directory.
#### With Composer
1. [Install composer](http://getcomposer.org/doc/00-intro.md#locally) in the `app/` folder of your project.
2. Add `"fmcorz/acl-manager": "stable"` to your `require` key in your `composer.json` file. ([More about this](http://getcomposer.org/doc/01-basic-usage.md#the-require-key))
3. Run `php composer.phar install` to install the plugin.[Composer documentation](http://getcomposer.org/doc/)
### 4. Configure the plugin
See `AclManager/Config/bootstrap.php`
AclManager.aros : write in there your requester models aliases (the order is important)
### 5. Enable the plugin
In `app/Config/bootstrap.php`
CakePlugin::load('AclManager', array('bootstrap' => true));
### 6. Login with an existing user
The plugin conflicts with `$this->Auth->allow()`, do not use it. Just make sure that you are logged in.
### 7. Access the plugin at `/acl_manager/acl`
* Update your AROs and ACOs
* Set up your permissions (do not forget to enable your own public actions!)
### 8. Disable the authorizer ControllerOr uncomment `return false` in `AppController::isAuthorized()`
### 9. You're done!
Enjoy!
Licence
-------Licensed under the [MIT License](http://www.opensource.org/licenses/mit-license.php)