isApiEnabled = InstanceSettings::get()->is_api_enabled; $this->canUseRootPermissions = auth()->user()->can('useRootPermissions', PersonalAccessToken::class); $this->canUseWritePermissions = auth()->user()->can('useWritePermissions', PersonalAccessToken::class); $this->getTokens(); } private function getTokens() { $this->tokens = auth()->user()->tokens->sortByDesc('created_at'); } public function updatedPermissions($permissionToUpdate) { // Check if user is trying to use restricted permissions if ($permissionToUpdate == 'root' && ! $this->canUseRootPermissions) { $this->dispatch('error', 'You do not have permission to use root permissions.'); // Remove root from permissions if it was somehow added $this->permissions = array_diff($this->permissions, ['root']); return; } if (in_array($permissionToUpdate, ['write', 'write:sensitive']) && ! $this->canUseWritePermissions) { $this->dispatch('error', 'You do not have permission to use write permissions.'); // Remove write permissions if they were somehow added $this->permissions = array_diff($this->permissions, ['write', 'write:sensitive']); return; } if ($permissionToUpdate == 'root') { $this->permissions = ['root']; } elseif ($permissionToUpdate == 'read:sensitive' && ! in_array('read', $this->permissions)) { $this->permissions[] = 'read'; } elseif ($permissionToUpdate == 'deploy') { $this->permissions = ['deploy']; } else { if (count($this->permissions) == 0) { $this->permissions = ['read']; } } sort($this->permissions); } public function addNewToken() { try { $this->authorize('create', PersonalAccessToken::class); // Validate permissions based on user role if (in_array('root', $this->permissions) && ! $this->canUseRootPermissions) { throw new \Exception('You do not have permission to create tokens with root permissions.'); } if (array_intersect(['write', 'write:sensitive'], $this->permissions) && ! $this->canUseWritePermissions) { throw new \Exception('You do not have permission to create tokens with write permissions.'); } $this->validate([ 'description' => 'required|min:3|max:255', ]); $token = auth()->user()->createToken($this->description, array_values($this->permissions)); $this->getTokens(); session()->flash('token', $token->plainTextToken); } catch (\Exception $e) { return handleError($e, $this); } } public function revoke(int $id) { try { $token = auth()->user()->tokens()->where('id', $id)->firstOrFail(); $this->authorize('delete', $token); $token->delete(); $this->getTokens(); } catch (\Exception $e) { return handleError($e, $this); } } }