mirror of
https://github.com/pelican-dev/panel.git
synced 2025-05-19 21:04:44 +02:00

* use RESOURCE_NAME for requests * use RESOURCE_NAME for transformers * add permissions field to api key * add migration for new permissions field * update tests * remove debug log * set column type to "json" * remove default attribute to fix tests * fix default value for permissions * fix after merge * fix after merge * allow to "register" custom permissions * add "role" to default resource names * fix after merge * fix phpstan * fix migrations
108 lines
4.0 KiB
PHP
108 lines
4.0 KiB
PHP
<?php
|
|
|
|
namespace App\Filament\Resources\ApiKeyResource\Pages;
|
|
|
|
use App\Filament\Resources\ApiKeyResource;
|
|
use App\Models\ApiKey;
|
|
use Filament\Forms\Components\Fieldset;
|
|
use Filament\Forms\Components\Hidden;
|
|
use Filament\Forms\Components\TagsInput;
|
|
use Filament\Forms\Components\Textarea;
|
|
use Filament\Forms\Components\ToggleButtons;
|
|
use Filament\Forms\Form;
|
|
use Filament\Resources\Pages\CreateRecord;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
class CreateApiKey extends CreateRecord
|
|
{
|
|
protected static string $resource = ApiKeyResource::class;
|
|
|
|
protected ?string $heading = 'Create Application API Key';
|
|
|
|
public function form(Form $form): Form
|
|
{
|
|
return $form
|
|
->schema([
|
|
Hidden::make('identifier')->default(ApiKey::generateTokenIdentifier(ApiKey::TYPE_APPLICATION)),
|
|
Hidden::make('token')->default(str_random(ApiKey::KEY_LENGTH)),
|
|
|
|
Hidden::make('user_id')
|
|
->default(auth()->user()->id)
|
|
->required(),
|
|
|
|
Hidden::make('key_type')
|
|
->inlineLabel()
|
|
->default(ApiKey::TYPE_APPLICATION)
|
|
->required(),
|
|
|
|
Fieldset::make('Permissions')
|
|
->columns([
|
|
'default' => 1,
|
|
'sm' => 1,
|
|
'md' => 2,
|
|
])
|
|
->schema(
|
|
collect(ApiKey::getPermissionList())->map(fn ($resource) => ToggleButtons::make('permissions_' . $resource)
|
|
->label(str($resource)->replace('_', ' ')->title())->inline()
|
|
->options([
|
|
0 => 'None',
|
|
1 => 'Read',
|
|
// 2 => 'Write',
|
|
3 => 'Read & Write',
|
|
])
|
|
->icons([
|
|
0 => 'tabler-book-off',
|
|
1 => 'tabler-book',
|
|
2 => 'tabler-writing',
|
|
3 => 'tabler-writing',
|
|
])
|
|
->colors([
|
|
0 => 'success',
|
|
1 => 'warning',
|
|
2 => 'danger',
|
|
3 => 'danger',
|
|
])
|
|
->required()
|
|
->columnSpan([
|
|
'default' => 1,
|
|
'sm' => 1,
|
|
'md' => 1,
|
|
])
|
|
->default(0),
|
|
)->all(),
|
|
),
|
|
|
|
TagsInput::make('allowed_ips')
|
|
->placeholder('Example: 127.0.0.1 or 192.168.1.1')
|
|
->label('Whitelisted IPv4 Addresses')
|
|
->helperText('Press enter to add a new IP address or leave blank to allow any IP address')
|
|
->columnSpanFull(),
|
|
|
|
Textarea::make('memo')
|
|
->required()
|
|
->label('Description')
|
|
->helperText('
|
|
Once you have assigned permissions and created this set of credentials you will be unable to come back and edit it.
|
|
If you need to make changes down the road you will need to create a new set of credentials.
|
|
')
|
|
->columnSpanFull(),
|
|
]);
|
|
}
|
|
|
|
protected function handleRecordCreation(array $data): Model
|
|
{
|
|
$permissions = [];
|
|
|
|
foreach (ApiKey::getPermissionList() as $permission) {
|
|
if (isset($data['permissions_' . $permission])) {
|
|
$permissions[$permission] = intval($data['permissions_' . $permission]);
|
|
unset($data['permissions_' . $permission]);
|
|
}
|
|
}
|
|
|
|
$data['permissions'] = $permissions;
|
|
|
|
return parent::handleRecordCreation($data);
|
|
}
|
|
}
|