Files
anonaddy/app/Http/Controllers/Auth/PersonalAccessTokenController.php
Will Browning 8d6ddb4434 Rebrand update
2023-10-04 11:32:39 +01:00

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);
}
}