drago-ex/authorization 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

drago-ex/authorization

最新稳定版本:v1.0.28

Composer 安装命令:

composer require drago-ex/authorization

包简介

A simple dynamic access control list (ACL) management system for Nette Framework, with support for roles, permissions, and resources

README 文档

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.

License: MIT PHP version Tests Coding Style

Requirements

  • PHP >= 8.3
  • Nette Framework
  • Composer
  • Bootstrap

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

Examples

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:';

Use 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}

统计信息

  • 总下载量: 1.17k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-08-25

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固