Implement superadmin audit log for mutations
This commit is contained in:
@@ -6,6 +6,7 @@ use App\Filament\Blog\Resources\CategoryResource\Pages;
|
||||
use App\Filament\Blog\Traits\HasContentEditor;
|
||||
use App\Filament\Clusters\RareAdmin\RareAdminCluster;
|
||||
use App\Models\BlogCategory;
|
||||
use App\Services\Audit\SuperAdminAuditLogger;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use Filament\Actions\EditAction;
|
||||
@@ -24,6 +25,7 @@ use Filament\Tables\Columns\IconColumn;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Table;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Database\Eloquent\Collection;
|
||||
use Illuminate\Database\Eloquent\SoftDeletingScope;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
@@ -116,38 +118,25 @@ class CategoryResource extends Resource
|
||||
$data['description_de'] = $descArray['de'] ?? '';
|
||||
$data['description_en'] = $descArray['en'] ?? '';
|
||||
|
||||
\Illuminate\Support\Facades\Log::info('BeforeFill Description Extraction:', [
|
||||
'descJson' => $descJson,
|
||||
'descArray' => $descArray,
|
||||
'description_de' => $data['description_de'],
|
||||
'description_en' => $data['description_en'],
|
||||
]);
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
public static function mutateFormDataBeforeCreate(array $data): array
|
||||
{
|
||||
\Illuminate\Support\Facades\Log::info('mutateFormDataBeforeCreate Input Data:', ['data' => $data]);
|
||||
|
||||
$nameData = [
|
||||
'de' => $data['name_de'] ?? '',
|
||||
'en' => $data['name_en'] ?? '',
|
||||
];
|
||||
$data['name'] = json_encode($nameData);
|
||||
\Illuminate\Support\Facades\Log::info('mutateFormDataBeforeCreate Name JSON:', ['name' => $nameData]);
|
||||
|
||||
$descData = [
|
||||
'de' => $data['description_de'] ?? '',
|
||||
'en' => $data['description_en'] ?? '',
|
||||
];
|
||||
$data['description'] = json_encode($descData);
|
||||
\Illuminate\Support\Facades\Log::info('mutateFormDataBeforeCreate Description JSON:', ['description' => $descData]);
|
||||
|
||||
unset($data['name_de'], $data['name_en'], $data['description_de'], $data['description_en']);
|
||||
|
||||
\Illuminate\Support\Facades\Log::info('mutateFormDataBeforeCreate Final Data:', $data);
|
||||
|
||||
return $data;
|
||||
}
|
||||
|
||||
@@ -185,11 +174,28 @@ class CategoryResource extends Resource
|
||||
//
|
||||
])
|
||||
->actions([
|
||||
EditAction::make(),
|
||||
EditAction::make()
|
||||
->after(fn (array $data, BlogCategory $record) => app(SuperAdminAuditLogger::class)->recordModelMutation(
|
||||
'updated',
|
||||
$record,
|
||||
SuperAdminAuditLogger::fieldsMetadata($data),
|
||||
static::class
|
||||
)),
|
||||
])
|
||||
->bulkActions([
|
||||
BulkActionGroup::make([
|
||||
DeleteBulkAction::make(),
|
||||
DeleteBulkAction::make()
|
||||
->after(function (Collection $records): void {
|
||||
$logger = app(SuperAdminAuditLogger::class);
|
||||
|
||||
foreach ($records as $record) {
|
||||
$logger->recordModelMutation(
|
||||
'deleted',
|
||||
$record,
|
||||
source: static::class
|
||||
);
|
||||
}
|
||||
}),
|
||||
]),
|
||||
]);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user