## Summary <!-- Kurz: Was ändert sich und warum? --> ## Spec-Driven Development (SDD) - [ ] Es gibt eine Spec unter `specs/<NNN>-<feature>/` - [ ] Enthaltene Dateien: `plan.md`, `tasks.md`, `spec.md` - [ ] Spec beschreibt Verhalten/Acceptance Criteria (nicht nur Implementation) - [ ] Wenn sich Anforderungen während der Umsetzung geändert haben: Spec/Plan/Tasks wurden aktualisiert ## Implementation - [ ] Implementierung entspricht der Spec - [ ] Edge cases / Fehlerfälle berücksichtigt - [ ] Keine unbeabsichtigten Änderungen außerhalb des Scopes ## Tests - [ ] Tests ergänzt/aktualisiert (Pest/PHPUnit) - [ ] Relevante Tests lokal ausgeführt (`./vendor/bin/sail artisan test` oder `php artisan test`) ## Migration / Config / Ops (falls relevant) - [ ] Migration(en) enthalten und getestet - [ ] Rollback bedacht (rückwärts kompatibel, sichere Migration) - [ ] Neue Env Vars dokumentiert (`.env.example` / Doku) - [ ] Queue/cron/storage Auswirkungen geprüft ## UI (Filament/Livewire) (falls relevant) - [ ] UI-Flows geprüft - [ ] Screenshots/Notizen hinzugefügt ## Notes <!-- Links, Screenshots, Follow-ups, offene Punkte --> Co-authored-by: Ahmed Darrazi <ahmeddarrazi@adsmac.local> Reviewed-on: #4
88 lines
2.6 KiB
PHP
88 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace App\Jobs;
|
|
|
|
use App\Models\BackupItem;
|
|
use App\Services\AssignmentBackupService;
|
|
use Illuminate\Bus\Queueable;
|
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
|
use Illuminate\Foundation\Bus\Dispatchable;
|
|
use Illuminate\Queue\InteractsWithQueue;
|
|
use Illuminate\Queue\SerializesModels;
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
class FetchAssignmentsJob implements ShouldQueue
|
|
{
|
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
|
|
|
/**
|
|
* The number of times the job may be attempted.
|
|
*/
|
|
public int $tries = 1;
|
|
|
|
/**
|
|
* The number of seconds to wait before retrying the job.
|
|
*/
|
|
public int $backoff = 0;
|
|
|
|
/**
|
|
* Create a new job instance.
|
|
*/
|
|
public function __construct(
|
|
public int $backupItemId,
|
|
public string $tenantExternalId,
|
|
public string $policyExternalId,
|
|
public array $policyPayload
|
|
) {}
|
|
|
|
/**
|
|
* Execute the job.
|
|
*/
|
|
public function handle(AssignmentBackupService $assignmentBackupService): void
|
|
{
|
|
try {
|
|
$backupItem = BackupItem::find($this->backupItemId);
|
|
|
|
if ($backupItem === null) {
|
|
Log::warning('FetchAssignmentsJob: BackupItem not found', [
|
|
'backup_item_id' => $this->backupItemId,
|
|
]);
|
|
|
|
return;
|
|
}
|
|
|
|
// Only process Settings Catalog policies
|
|
if ($backupItem->policy_type !== 'settingsCatalogPolicy') {
|
|
Log::info('FetchAssignmentsJob: Skipping non-Settings Catalog policy', [
|
|
'backup_item_id' => $this->backupItemId,
|
|
'policy_type' => $backupItem->policy_type,
|
|
]);
|
|
|
|
return;
|
|
}
|
|
|
|
$assignmentBackupService->enrichWithAssignments(
|
|
backupItem: $backupItem,
|
|
tenantId: $this->tenantExternalId,
|
|
policyId: $this->policyExternalId,
|
|
policyPayload: $this->policyPayload,
|
|
includeAssignments: true
|
|
);
|
|
|
|
Log::info('FetchAssignmentsJob: Successfully enriched BackupItem', [
|
|
'backup_item_id' => $this->backupItemId,
|
|
'assignment_count' => $backupItem->getAssignmentCount(),
|
|
]);
|
|
} catch (\Throwable $e) {
|
|
Log::error('FetchAssignmentsJob: Failed to enrich BackupItem', [
|
|
'backup_item_id' => $this->backupItemId,
|
|
'error' => $e->getMessage(),
|
|
'trace' => $e->getTraceAsString(),
|
|
]);
|
|
|
|
// Don't retry - fail soft
|
|
$this->fail($e);
|
|
}
|
|
}
|
|
}
|