death_satan / hyperf-auth
The Hyperf Auth package.
Fund package maintenance!
Open Collective
hyperf.wiki/#/zh-cn/donate
Requires
- php: >=8.1
- death_satan/hyperf-hashing: ^3.1
- hyperf/command: ^3.1
- hyperf/database: ^3.1
- hyperf/db-connection: ^3.1
- hyperf/di: ^3.1
- hyperf/framework: ^3.1
Requires (Dev)
- friendsofhyperf/rector: ^0.1.5
- friendsofphp/php-cs-fixer: ^3.0
- hyperf/testing: ^3.1
- mockery/mockery: ^1.0
- phpstan/phpstan: ^1.0
- swoole/ide-helper: dev-master
Suggests
- ext-swoole: >=5 Required use Hyperf
- hyperf-ext/cookie: Required to use session guard.
- hyperf-ext/jwt: Required to use JWT guard.
- hyperf/session: Required to use session guard.
This package is auto-updated.
Last update: 2024-11-07 16:52:15 UTC
README
该组件移植了 Laravel Auth 组件(illuminate/auth)相对完整的功能特性,除了中间件传参和邮件通知。
- Hyperf 的中间件遵循 PSR-15 的规范,无法使用 Laravel 的方式通过路由向中间件传递值,故在实现上与 Laravel 不同,仅实现了一个基础的身份认证中间件抽象类
HyperfExt\Auth\Middlewares\AbstractAuthenticateMiddleware
。 - 邮件(illuminate/mail)和通知(illuminate/notifications)尚未移植完成。
该组件实现了两个自定义注解。
-
Hyperf\Di\Annotations\AbstractAnnotation\Auth
可用于类和方法,语法Auth({"GUARD_CONF_NAME"[, ...]}[, passable=bool])
:- 第一个参数为 Guard 名列表
- 第二个
passable
可选参数默认值为false
,设置为true
时未认证的用户也可以通过 Guard,不会抛出为认证的异常,在某些特殊情况下将会比较有用。例如,同一个 API 需要对认证用户和非认证用户展示不同的数据。
-
Hyperf\Di\Annotations\AbstractAnnotation\Policy
可用于类,语法Policy({"MODEL_FQCN"\[, ...\]})
:- 参数为模型 FQCN 列表
另外,Gate 和策略的注册方法与 Laravel 不同。
Gate 可以通过注入 HyperfExt\Auth\Contracts\Access\GateManagerInterface
来调用实例的 define
方法注册。或者监听 HyperfExt\Auth\Events\GateManagerResolved
事件来在监听器中访问事件的 gate
属性(GateManagerInterface)来注册。
策略可以通过 gen:policy
命令来创建,例如 gen:policy PostPolicy --model=App\\Model\\Post
。也可以在配置文件的 policies
中定义模型类和策略类的映射。
如需使用 JWT,请额外安装 hyperf-ext/jwt
组件。
安装
composer require hyperf-ext/auth
发布配置
php bin/hyperf.php vendor:publish hyperf-ext/auth
文件位于
config/autoload/auth.php
。
配置
详细说明见配置文件。
使用
身份认证
文档待完成。
授权
文档待完成。