mirror of
https://github.com/anonaddy/anonaddy
synced 2026-04-26 01:25:06 +02:00
52 lines
1.6 KiB
PHP
52 lines
1.6 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Auth;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\StorePersonalAccessTokenRequest;
|
|
use App\Http\Resources\PersonalAccessTokenResource;
|
|
use chillerlan\QRCode\QRCode;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
class PersonalAccessTokenController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
return PersonalAccessTokenResource::collection(user()->tokens()->select(['id', 'tokenable_id', 'name', 'created_at', 'last_used_at', 'expires_at', 'updated_at', 'created_at'])->get());
|
|
}
|
|
|
|
public function store(StorePersonalAccessTokenRequest $request)
|
|
{
|
|
if (! Hash::check($request->password, user()->password)) {
|
|
throw ValidationException::withMessages(['password' => 'Incorrect password entered']);
|
|
}
|
|
|
|
// day, week, month, year or null
|
|
if ($request->expiration) {
|
|
$method = 'add'.ucfirst($request->expiration);
|
|
$expiration = now()->{$method}();
|
|
} else {
|
|
$expiration = null;
|
|
}
|
|
|
|
$token = user()->createToken($request->name, ['*'], $expiration);
|
|
$accessToken = explode('|', $token->plainTextToken, 2)[1];
|
|
|
|
return [
|
|
'token' => new PersonalAccessTokenResource($token->accessToken),
|
|
'accessToken' => $accessToken,
|
|
'qrCode' => (new QRCode())->render(config('app.url').'|'.$accessToken),
|
|
];
|
|
}
|
|
|
|
public function destroy($id)
|
|
{
|
|
$token = user()->tokens()->findOrFail($id);
|
|
|
|
$token->delete();
|
|
|
|
return response('', 204);
|
|
}
|
|
}
|