Lae/app/Http/Controllers/Public/AuthRequestController.php

66 lines
1.6 KiB
PHP
Raw Normal View History

2023-02-02 05:51:32 +00:00
<?php
2023-02-07 09:20:54 +00:00
namespace App\Http\Controllers\Public;
2023-02-02 05:51:32 +00:00
use App\Http\Controllers\Controller;
2023-02-07 09:02:08 +00:00
use Illuminate\Http\JsonResponse;
2023-02-02 05:51:32 +00:00
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Str;
class AuthRequestController extends Controller
{
2023-02-07 09:02:08 +00:00
public function store(Request $request): JsonResponse
2023-02-02 05:51:32 +00:00
{
$request->validate([
'description' => 'required|string|max:255',
2023-02-07 09:45:31 +00:00
'require_token' => 'nullable|boolean'
2023-02-02 05:51:32 +00:00
]);
$token = Str::random(128);
$data = [
2023-02-07 09:45:31 +00:00
'meta' => [
'description' => $request->input('description'),
'token' => $token,
'require_token' => $request->input('require_token', false),
]
2023-02-02 05:51:32 +00:00
];
2023-02-07 09:20:54 +00:00
if ($request->user('module')) {
$data['module'] = $request->user('module')->toArray();
}
if ($request->user('application')) {
$data['application'] = $request->user('application')->toArray();
}
if ($request->user('sanctum')) {
$data['from_user'] = $request->user('sanctum')->getOnlyPublic([
'balance',
]);
}
2023-02-07 09:45:31 +00:00
Cache::put('auth_request:' . $token, $data, 120);
2023-02-02 05:51:32 +00:00
$data['url'] = route('auth_request.show', $token);
return $this->success($data);
}
2023-02-07 09:02:08 +00:00
public function show($token): JsonResponse
2023-02-02 05:51:32 +00:00
{
2023-02-07 09:45:31 +00:00
$data = Cache::get('auth_request:' . $token);
2023-02-02 05:51:32 +00:00
if (empty($data)) {
return $this->error('Token 不存在或已过期。');
}
2023-02-07 09:45:31 +00:00
if (!isset($data['user'])) {
2023-02-03 06:06:45 +00:00
$data['user'] = null;
2023-02-02 05:51:32 +00:00
}
return $this->success($data);
}
}