user(); $allUserCredentials = $user->webAuthnCredentials() ->enabled() ->get() ->all(); return response()->json($allUserCredentials, 200); } /** * Rename a WebAuthn device * * @param \App\Http\Requests\WebauthnRenameRequest $request * @return \Illuminate\Http\JsonResponse */ public function rename(WebauthnRenameRequest $request, string $credential) { $validated = $request->validated(); $webAuthnCredential = WebAuthnCredential::where('id', $credential)->firstOrFail(); $webAuthnCredential->name = $validated['name']; // @phpstan-ignore-line $webAuthnCredential->save(); return response()->json([ 'name' => $webAuthnCredential->name, ], 200); } /** * Remove the specified credential from storage. * * @param \Illuminate\Http\Request $request * @param string|array $credential * * @return \Illuminate\Http\JsonResponse */ public function delete(Request $request, $credential) { Log::info('Deletion of security device requested'); $user = $request->user(); $user->removeCredential($credential); // Webauthn user options should be reset to prevent impossible login // See #110 if (blank($user->allCredentialDescriptors())) { Settings::delete('useWebauthnAsDefault'); Settings::delete('useWebauthnOnly'); } Log::info('Security device deleted'); return response()->json(null, 204); } }