Implement superadmin audit log for mutations
This commit is contained in:
@@ -6,6 +6,7 @@ use App\Exports\EventPurchaseExporter;
|
||||
use App\Filament\Clusters\WeeklyOps\WeeklyOpsCluster;
|
||||
use App\Filament\Resources\EventPurchaseResource\Pages;
|
||||
use App\Models\EventPurchase;
|
||||
use App\Services\Audit\SuperAdminAuditLogger;
|
||||
use Filament\Actions\Action;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
@@ -23,6 +24,7 @@ use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Tables\Filters\TernaryFilter;
|
||||
use Filament\Tables\Table;
|
||||
use Illuminate\Database\Eloquent\Builder;
|
||||
use Illuminate\Database\Eloquent\Collection;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
class EventPurchaseResource extends Resource
|
||||
@@ -174,11 +176,29 @@ class EventPurchaseResource extends Resource
|
||||
->action(function (EventPurchase $record) {
|
||||
$record->update(['refunded_at' => now()]);
|
||||
Log::info('Refund processed for purchase ID: '.$record->id);
|
||||
|
||||
app(SuperAdminAuditLogger::class)->record(
|
||||
'event_purchase.refunded',
|
||||
$record,
|
||||
SuperAdminAuditLogger::fieldsMetadata(['refunded_at']),
|
||||
source: 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
|
||||
);
|
||||
}
|
||||
}),
|
||||
ExportBulkAction::make()
|
||||
->label('Export CSV')
|
||||
->exporter(EventPurchaseExporter::class),
|
||||
|
||||
Reference in New Issue
Block a user