mangement add oauth

This commit is contained in:
xiaomlove
2024-03-11 02:12:17 +08:00
parent a2b8ef3c50
commit 8903f10286
19 changed files with 455 additions and 7 deletions

View File

@@ -74,11 +74,17 @@ class NexusWebGuard implements StatefulGuard
return false;
}
$user = $this->provider->retrieveById($id);
if ($user) {
if (!$user) {
return false;
}
try {
$user->checkIsNormal();
$this->user = $user;
return true;
} catch (\Throwable $e) {
do_log($e->getMessage());
return false;
}
return false;
}
public function logout()

View File

@@ -16,10 +16,8 @@ class PageListSingle extends ManageRecords
return Layout::AboveContent;
}
protected function getTableRecordUrlUsing(): ?Closure
protected function getTableRecordActionUsing(): ?Closure
{
return function (Model $record): ?string {
return null;
};
return null;
}
}

View File

@@ -0,0 +1,76 @@
<?php
namespace App\Filament\Resources\Oauth;
use App\Filament\Resources\Oauth\AccessTokenResource\Pages;
use App\Filament\Resources\Oauth\AccessTokenResource\RelationManagers;
use Laravel\Passport\Token;
use Filament\Forms;
use Filament\Resources\Form;
use Filament\Resources\Resource;
use Filament\Resources\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class AccessTokenResource extends Resource
{
protected static ?string $model = Token::class;
protected static ?string $navigationIcon = 'heroicon-o-collection';
protected static ?string $navigationGroup = 'Oauth';
protected static ?int $navigationSort = 3;
protected static function getNavigationLabel(): string
{
return __('admin.sidebar.oauth_access_token');
}
public static function getBreadcrumb(): string
{
return self::getNavigationLabel();
}
public static function form(Form $form): Form
{
return $form
->schema([
//
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id')->searchable(),
Tables\Columns\TextColumn::make('user.username')
->label(__('label.username'))
->formatStateUsing(fn ($record) => username_for_admin($record->user_id)),
Tables\Columns\TextColumn::make('client.name')
->label(__('oauth.client')),
Tables\Columns\TextColumn::make('expires_at')
->label(__('label.expire_at'))
])
->filters([
//
])
->actions([
// Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
])
->bulkActions([
Tables\Actions\DeleteBulkAction::make(),
]);
}
public static function getPages(): array
{
return [
'index' => Pages\ManageAccessTokens::route('/'),
];
}
}

View File

@@ -0,0 +1,20 @@
<?php
namespace App\Filament\Resources\Oauth\AccessTokenResource\Pages;
use App\Filament\PageListSingle;
use App\Filament\Resources\Oauth\AccessTokenResource;
use Filament\Pages\Actions;
use Filament\Resources\Pages\ManageRecords;
class ManageAccessTokens extends PageListSingle
{
protected static string $resource = AccessTokenResource::class;
protected function getActions(): array
{
return [
// Actions\CreateAction::make(),
];
}
}

View File

@@ -0,0 +1,75 @@
<?php
namespace App\Filament\Resources\Oauth;
use App\Filament\Resources\Oauth\AuthCodeResource\Pages;
use App\Filament\Resources\Oauth\AuthCodeResource\RelationManagers;
use Laravel\Passport\AuthCode;
use Filament\Forms;
use Filament\Resources\Form;
use Filament\Resources\Resource;
use Filament\Resources\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class AuthCodeResource extends Resource
{
protected static ?string $model = AuthCode::class;
protected static ?string $navigationIcon = 'heroicon-o-collection';
protected static ?string $navigationGroup = 'Oauth';
protected static ?int $navigationSort = 2;
protected static function getNavigationLabel(): string
{
return __('admin.sidebar.oauth_auth_code');
}
public static function getBreadcrumb(): string
{
return self::getNavigationLabel();
}
public static function form(Form $form): Form
{
return $form
->schema([
//
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id'),
Tables\Columns\TextColumn::make('user.username')
->label(__('label.username'))
->formatStateUsing(fn ($record) => username_for_admin($record->user_id)),
Tables\Columns\TextColumn::make('client.name')
->label(__('oauth.client')),
Tables\Columns\TextColumn::make('expires_at')
->label(__('label.expire_at'))
])
->filters([
//
])
->actions([
// Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
])
->bulkActions([
Tables\Actions\DeleteBulkAction::make(),
]);
}
public static function getPages(): array
{
return [
'index' => Pages\ManageAuthCodes::route('/'),
];
}
}

View File

@@ -0,0 +1,20 @@
<?php
namespace App\Filament\Resources\Oauth\AuthCodeResource\Pages;
use App\Filament\PageListSingle;
use App\Filament\Resources\Oauth\AuthCodeResource;
use Filament\Pages\Actions;
use Filament\Resources\Pages\ManageRecords;
class ManageAuthCodes extends PageListSingle
{
protected static string $resource = AuthCodeResource::class;
protected function getActions(): array
{
return [
// Actions\CreateAction::make(),
];
}
}

View File

@@ -0,0 +1,75 @@
<?php
namespace App\Filament\Resources\Oauth;
use App\Filament\PageListSingle;
use App\Filament\Resources\Oauth\ClientResource\Pages;
use App\Filament\Resources\Oauth\ClientResource\RelationManagers;
use Laravel\Passport\Client;
use Filament\Forms;
use Filament\Resources\Form;
use Filament\Resources\Resource;
use Filament\Resources\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class ClientResource extends Resource
{
protected static ?string $model = Client::class;
protected static ?string $navigationIcon = 'heroicon-o-collection';
protected static ?string $navigationGroup = 'Oauth';
protected static ?int $navigationSort = 1;
protected static function getNavigationLabel(): string
{
return __('admin.sidebar.oauth_client');
}
public static function getBreadcrumb(): string
{
return self::getNavigationLabel();
}
public static function form(Form $form): Form
{
return $form
->schema([
Forms\Components\TextInput::make('name')->label(__('label.name')),
Forms\Components\TextInput::make('redirect')->label(__('oauth.redirect')),
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id'),
Tables\Columns\TextColumn::make('name')->label(__('label.name')),
Tables\Columns\TextColumn::make('secret')->label(__('oauth.secret')),
Tables\Columns\TextColumn::make('redirect')->label(__('oauth.redirect')),
])
->filters([
//
])
->actions([
Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
])
->bulkActions([
Tables\Actions\DeleteBulkAction::make(),
]);
}
public static function getPages(): array
{
return [
'index' => Pages\ManageClients::route('/'),
];
}
}

View File

@@ -0,0 +1,20 @@
<?php
namespace App\Filament\Resources\Oauth\ClientResource\Pages;
use App\Filament\PageListSingle;
use App\Filament\Resources\Oauth\ClientResource;
use Filament\Pages\Actions;
use Filament\Resources\Pages\ManageRecords;
class ManageClients extends PageListSingle
{
protected static string $resource = ClientResource::class;
protected function getActions(): array
{
return [
Actions\CreateAction::make(),
];
}
}

View File

@@ -0,0 +1,77 @@
<?php
namespace App\Filament\Resources\Oauth;
use App\Filament\Resources\Oauth\RefreshTokenResource\Pages;
use App\Filament\Resources\Oauth\RefreshTokenResource\RelationManagers;
use Laravel\Passport\RefreshToken;
use Filament\Forms;
use Filament\Resources\Form;
use Filament\Resources\Resource;
use Filament\Resources\Table;
use Filament\Tables;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\SoftDeletingScope;
class RefreshTokenResource extends Resource
{
protected static ?string $model = RefreshToken::class;
protected static ?string $navigationIcon = 'heroicon-o-collection';
protected static ?string $navigationGroup = 'Oauth';
protected static ?int $navigationSort = 4;
protected static function getNavigationLabel(): string
{
return __('admin.sidebar.oauth_refresh_token');
}
public static function getBreadcrumb(): string
{
return self::getNavigationLabel();
}
public static function form(Form $form): Form
{
return $form
->schema([
//
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
Tables\Columns\TextColumn::make('id')
->label(__('oauth.refresh_token'))
->searchable()
,
Tables\Columns\TextColumn::make('access_token_id')
->label(__('oauth.access_token'))
->searchable()
,
Tables\Columns\TextColumn::make('expires_at')
->label(__('label.expire_at'))
])
->filters([
//
])
->actions([
// Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
])
->bulkActions([
Tables\Actions\DeleteBulkAction::make(),
]);
}
public static function getPages(): array
{
return [
'index' => Pages\ManageRefreshTokens::route('/'),
];
}
}

View File

@@ -0,0 +1,20 @@
<?php
namespace App\Filament\Resources\Oauth\RefreshTokenResource\Pages;
use App\Filament\PageListSingle;
use App\Filament\Resources\Oauth\RefreshTokenResource;
use Filament\Pages\Actions;
use Filament\Resources\Pages\ManageRecords;
class ManageRefreshTokens extends PageListSingle
{
protected static string $resource = RefreshTokenResource::class;
protected function getActions(): array
{
return [
// Actions\CreateAction::make(),
];
}
}

View File

@@ -42,6 +42,7 @@ class AppServiceProvider extends ServiceProvider
'Role & Permission',
'Other',
'Section',
'Oauth',
'System',
]);
});