114 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Livewire\Security;
 | 
						|
 | 
						|
use App\Models\InstanceSettings;
 | 
						|
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
 | 
						|
use Laravel\Sanctum\PersonalAccessToken;
 | 
						|
use Livewire\Component;
 | 
						|
 | 
						|
class ApiTokens extends Component
 | 
						|
{
 | 
						|
    use AuthorizesRequests;
 | 
						|
 | 
						|
    public ?string $description = null;
 | 
						|
 | 
						|
    public $tokens = [];
 | 
						|
 | 
						|
    public array $permissions = ['read'];
 | 
						|
 | 
						|
    public $isApiEnabled;
 | 
						|
 | 
						|
    public bool $canUseRootPermissions = false;
 | 
						|
 | 
						|
    public bool $canUseWritePermissions = false;
 | 
						|
 | 
						|
    public function render()
 | 
						|
    {
 | 
						|
        return view('livewire.security.api-tokens');
 | 
						|
    }
 | 
						|
 | 
						|
    public function mount()
 | 
						|
    {
 | 
						|
        $this->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);
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |