定制 vortexpanel/policy-permission-sync 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

vortexpanel/policy-permission-sync

最新稳定版本:v1.0.0

Composer 安装命令:

composer require vortexpanel/policy-permission-sync

包简介

Sync Laravel Policies to Spatie permissions using dot-style naming.

README 文档

README

Sync Laravel Policies into Spatie permissions using deterministic names (configurable):

  • posts.view_any
  • posts.view
  • posts.create
  • posts.update
  • posts.delete

This is a tiny, UI-agnostic package intended to be reused by admin panels (VortexPanel, Filament, Nova, ...).

Requirements

  • PHP 8.1+
  • Laravel 10+
  • spatie/laravel-permission

Installation

composer require vortexpanel/policy-permission-sync

Publish config:

php artisan vendor:publish --tag=policy-permission-sync-config

Configuration

Edit config/policy-permission-sync.php.

The most reliable setup is to explicitly scan your policies directory:

'policy_paths' => [
    app_path('Policies'),
],

Customize permission naming

By default, permissions are created using a dot-style pattern:

'naming' => [
    'prefix' => '',
    'pattern' => '{resource}.{ability}',
],

You can change it to any pattern containing {resource} and {ability}:

// posts:view_any
'pattern' => '{resource}:{ability}',

// view_any:posts
'pattern' => '{ability}:{resource}',

// admin.posts.view_any
'prefix' => 'admin.',
'pattern' => '{resource}.{ability}',

Notes:

  • If you use --prune, the package scopes pruning by extracting {resource} back from permission names using this same pattern. If your pattern doesn't include {resource}, pruning can't be scoped.

If your policies live in a custom directory/namespace, set the mapping:

'policy_paths' => [
    app_path('Domain/Blog/Policies'),
],

'policy_path_namespace_map' => [
    app_path('Domain/Blog/Policies') => 'App\\Domain\\Blog\\Policies',
],

Usage

Preview changes (no DB writes):

php artisan permissions:sync-policies --dry-run

Apply changes:

php artisan permissions:sync-policies

Prune stale permissions (opt-in):

php artisan permissions:sync-policies --prune

Target specific guards:

php artisan permissions:sync-policies --guards=web,api

Filter resources:

php artisan permissions:sync-policies --only=posts,users
php artisan permissions:sync-policies --except=audits

Show per-permission actions:

php artisan permissions:sync-policies --details
# or use artisan verbosity:
php artisan permissions:sync-policies -v

Development & Tests (inside this package repo)

If you see PDOException: could not find driver, your PHP CLI is missing the SQLite extension.

Ubuntu/WSL:

sudo apt-get update
sudo apt-get install -y php-sqlite3
php -m | grep -i sqlite

Then:

composer install
composer test
composer analyse

Testing in a real Laravel app (manual)

  1. Install spatie/laravel-permission and run its migrations.

  2. Create a policy, e.g. app/Policies/PostPolicy.php with methods like viewAny, view, create, update, delete.

  3. Ensure your config scans the right directory:

'policy_paths' => [app_path('Policies')],
  1. Run:
php artisan permissions:sync-policies

Then check the permissions table.

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-19

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固