nasustop / hapi-auth
3.0.0
2023-06-25 07:44 UTC
Requires
- php: >=8.0
- firebase/php-jwt: ^6.4
- hyperf/contract: ~3.0.0
- hyperf/http-server: ~3.0.0
- nasustop/hapi-helpers: ~3.0.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- mockery/mockery: ^1.0
- phpstan/phpstan: ^1.0
- phpunit/phpunit: >=7.0
- swoole/ide-helper: ^4.5
Suggests
- swow/swow: Required to create swow components.
This package is auto-updated.
Last update: 2024-10-25 10:44:45 UTC
README
hapi的auth组件
安装
composer require nasustop/hapi-auth
声称配置文件
php bin/hyperf.php vendor:publish nasustop/hapi-auth
示例
<?php
declare(strict_types=1);
/**
* This file is part of Hapi.
*
* @link https://www.nasus.top
* @document https://wiki.nasus.top
* @contact xupengfei@xupengfei.net
* @license https://github.com/nasustop/hapi/blob/master/LICENSE
*/
namespace SystemBundle\Auth;
use Hyperf\HttpMessage\Exception\BadRequestHttpException;
use Hyperf\HttpMessage\Exception\UnauthorizedHttpException;
use Hyperf\Snowflake\IdGeneratorInterface;
use Hyperf\Validation\Contract\ValidatorFactoryInterface;
use Nasustop\HapiAuth\UserProvider;
use Psr\Container\ContainerExceptionInterface;
use Psr\Container\NotFoundExceptionInterface;
use Psr\SimpleCache\InvalidArgumentException;
use SystemBundle\Service\SystemUserService;
class AuthUserProvider extends UserProvider
{
public function getInfo(array $payload): array
{
if (empty($payload['id'])) {
throw new UnauthorizedHttpException('登录失效,请重新登录');
}
$user = cache($this->getCacheDriver())->get((string) $payload['id']);
if (empty($user)) {
throw new UnauthorizedHttpException('登录失效,请重新登录');
}
$user['id'] = $payload['id'];
return $user;
}
/**
* @throws NotFoundExceptionInterface
* @throws ContainerExceptionInterface
* @throws InvalidArgumentException
*/
public function login(array $inputData): array
{
$validatorFactory = $this->container->get(ValidatorFactoryInterface::class);
$validator = $validatorFactory->make($inputData, [
'username' => 'required',
'password' => 'required',
], [
'username.*' => '请填写登录账号',
'password.*' => '请填写密码',
]);
if ($validator->fails()) {
throw new BadRequestHttpException($validator->errors()->first());
}
$service = $this->container->get(SystemUserService::class);
$userInfo = $service->getRepository()->getInfo([
[
['login_name' => $inputData['username']],
'or',
['mobile' => $inputData['username']],
],
]);
if (empty($userInfo)) {
throw new BadRequestHttpException('账号不存在');
}
// 验证密码
if (! $service->getRepository()->validatePassword($inputData['password'], $userInfo['password'])) {
throw new BadRequestHttpException('密码错误');
}
unset($userInfo['password']);
// 验证状态
$service->getRepository()->validateUserStatus(user_status: $userInfo['user_status']);
// support admin user
$support_admin_user = config(sprintf('auth.%s.support_admin_user', $this->guard), '');
$support_admin_user = explode(',', $support_admin_user);
$userInfo['is_support_user'] = ! empty($userInfo['user_id']) && in_array($userInfo['user_id'], $support_admin_user);
$cacheUserIdKey = $this->getCacheUserIdKey(user_id: $userInfo['user_id']);
$cacheSnowflakeId = cache($this->getCacheDriver())->get(key: $cacheUserIdKey);
if (empty($cacheSnowflakeId)) {
// generate snowflake id
$generator = $this->container->get(id: IdGeneratorInterface::class);
$cacheSnowflakeId = $generator->generate();
}
$exp = (int) config(sprintf('auth.%s.jwt.exp', $this->guard), 7200);
cache($this->getCacheDriver())->set(key: (string) $cacheSnowflakeId, value: $userInfo, ttl: $exp);
cache($this->getCacheDriver())->set(key: $cacheUserIdKey, value: $cacheSnowflakeId, ttl: $exp);
return ['id' => $cacheSnowflakeId];
}
/**
* @throws InvalidArgumentException
*/
public function logout(array $payload): bool
{
if (! empty($payload['id'])) {
$userInfo = cache($this->getCacheDriver())->get(key: (string) $payload['id']);
if (! empty($userInfo['user_id'])) {
$cacheUserIdKey = $this->getCacheUserIdKey(user_id: $userInfo['user_id']);
cache($this->getCacheDriver())->delete(key: $cacheUserIdKey);
}
cache($this->getCacheDriver())->delete(key: (string) $payload['id']);
}
return true;
}
public function validateToken(array $payload): array
{
if (empty($payload['id'])) {
return [];
}
$user = cache($this->getCacheDriver())->get(key: (string) $payload['id']);
if (empty($user)) {
return [];
}
$user['id'] = $payload['id'];
return $user;
}
protected function getCacheDriver()
{
return config(sprintf('auth.%s.cache', $this->guard), 'default');
}
protected function getCacheUserIdKey(int $user_id): string
{
return sprintf('auth:user_id:%s', $user_id);
}
}