drago-ex / authorization
A simple dynamic access control list (ACL) management system for Nette Framework, with support for roles, permissions, and resources
Installs: 1 084
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: >=8.1 <8.4
- drago-ex/application: ^1.0
- drago-ex/database: ^1.0
- drago-ex/utils: ^1.0
- latte/latte: ^3.0
- nette/application: ^3.1
- nette/caching: ^3.2
- nette/di: ^3.1
- nette/security: ^3.1
- ublaboo/datagrid: dev-next
Requires (Dev)
- nette/bootstrap: ^3.2
- nette/tester: ^2.5
- phpstan/phpstan-nette: 1.2.9
- tracy/tracy: ^2.10
README
Drago Authorization is a simple and dynamic access control list (ACL) management system built on top of the Nette Framework. It provides an easy-to-use solution for managing roles, resources, and permissions, with built-in support for PHP 8.3 or higher.
Technology
- PHP 8.3 or higher
- Bootstrap
- composer
Installation
composer require drago-ex/authorization
Extension Registration
To use Drago Authorization in your Nette application, register the extension in your config.neon
file:
extensions: - Drago\Authorization\DI\AuthorizationExtension
Usage
Use Trait in Base Presenter for Access Control
You can use the Authorization
trait in your base presenter to manage access control and redirect users to the login page if needed.
use Drago\Authorization\Authorization // Redirect to a specific login presenter or module private string $loginLink = ':Module:Presenter:';
UUse Trait in Presenter for Access Control Settings
In each presenter, use the AuthorizationControl
trait to manage authorization control.
use Drago\Authorization\Control\AuthorizationControl
Component Creation and Configuration
Here’s how to create and configure the main components for managing roles, permissions, and resources:
// Minimum configuration to create components. protected function createComponentPermissionsControl(): PermissionsControl { return $this->permissionsControl; } protected function createComponentRolesControl(): RolesControl { return $this->rolesControl; } protected function createComponentResourcesControl(): ResourcesControl { return $this->resourcesControl; } protected function createComponentPrivilegesControl(): PrivilegesControl { return $this->privilegesControl; } protected function createComponentAccessControl(): AccessControl { return $this->accessControl; }
You can also configure custom templates for the components:
// Set custom templates for controls $control->templateControl = __DIR__ . '/path/to/file.latte'; $control->templateGrid = __DIR__ . '/path/to/file.latte'; // Insert a translator for multi-language support $control->translator = $this->getTranslator();
Use Components in Latte
Once the components are configured, you can render them in your Latte templates:
{control permissionsControl} {control rolesControl} {control resourcesControl} {control privilegesControl} {control accessControl}