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