## Summary - migrate provider connections to the canonical three-dimension state model: lifecycle via `is_enabled`, consent via `consent_status`, and verification via `verification_status` - remove legacy provider status and health badge paths, update admin and system directory surfaces, and align onboarding, consent callback, verification, resolver, and mutation flows with the new model - add the Spec 188 artifact set, schema migrations, guard coverage, and expanded provider-state tests across admin, system, onboarding, verification, and rendering paths ## Verification - `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent` - `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Auth/SystemPanelAuthTest.php tests/Feature/Filament/TenantGlobalSearchLifecycleScopeTest.php tests/Feature/ProviderConnections/ProviderConnectionEnableDisableTest.php tests/Feature/ProviderConnections/ProviderConnectionTruthCleanupSpec179Test.php` - integrated browser smoke: validated admin provider list/detail/edit, tenant provider summary, system directory tenant detail, provider-connection search exclusion, and cleaned up the temporary smoke record afterward ## Filament / implementation notes - Livewire v4.0+ compliance: preserved; this change targets Filament v5 on Livewire v4 and does not introduce older APIs - Provider registration location: unchanged; Laravel 11+ panel providers remain registered in `bootstrap/providers.php` - Globally searchable resources: `ProviderConnectionResource` remains intentionally excluded from global search; tenant global search remains enabled and continues to resolve to view pages - Destructive actions: no new destructive action surface was introduced without confirmation or authorization; existing capability checks continue to gate provider mutations - Asset strategy: unchanged; no new Filament assets were added, so deploy behavior for `php artisan filament:assets` remains unchanged - Testing plan covered: system auth, tenant global search, provider lifecycle enable/disable behavior, and provider truth cleanup cutover behavior Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #219
60 lines
3.1 KiB
PHP
60 lines
3.1 KiB
PHP
<?php
|
|
|
|
namespace App\Support\Badges;
|
|
|
|
enum BadgeDomain: string
|
|
{
|
|
case AuditOutcome = 'audit_outcome';
|
|
case AuditActorType = 'audit_actor_type';
|
|
case GovernanceArtifactExistence = 'governance_artifact_existence';
|
|
case GovernanceArtifactContent = 'governance_artifact_content';
|
|
case GovernanceArtifactFreshness = 'governance_artifact_freshness';
|
|
case GovernanceArtifactPublicationReadiness = 'governance_artifact_publication_readiness';
|
|
case GovernanceArtifactActionability = 'governance_artifact_actionability';
|
|
case OperatorExplanationEvaluationResult = 'operator_explanation_evaluation_result';
|
|
case OperatorExplanationTrustworthiness = 'operator_explanation_trustworthiness';
|
|
case BaselineSnapshotLifecycle = 'baseline_snapshot_lifecycle';
|
|
case BaselineSnapshotFidelity = 'baseline_snapshot_fidelity';
|
|
case BaselineSnapshotGapStatus = 'baseline_snapshot_gap_status';
|
|
case OperationRunStatus = 'operation_run_status';
|
|
case OperationRunOutcome = 'operation_run_outcome';
|
|
case InventoryCoverageState = 'inventory_coverage_state';
|
|
case BackupSetStatus = 'backup_set_status';
|
|
case RestoreRunStatus = 'restore_run_status';
|
|
case RestoreCheckSeverity = 'restore_check_severity';
|
|
case FindingStatus = 'finding_status';
|
|
case FindingSeverity = 'finding_severity';
|
|
case FindingExceptionStatus = 'finding_exception_status';
|
|
case FindingRiskGovernanceValidity = 'finding_risk_governance_validity';
|
|
case BooleanEnabled = 'boolean_enabled';
|
|
case BooleanHasErrors = 'boolean_has_errors';
|
|
case TenantStatus = 'tenant_status';
|
|
case TenantAppStatus = 'tenant_app_status';
|
|
case TenantRbacStatus = 'tenant_rbac_status';
|
|
case TenantPermissionStatus = 'tenant_permission_status';
|
|
case PolicySnapshotMode = 'policy_snapshot_mode';
|
|
case PolicyRestoreMode = 'policy_restore_mode';
|
|
case PolicyRisk = 'policy_risk';
|
|
case IgnoredAt = 'ignored_at';
|
|
case RestorePreviewDecision = 'restore_preview_decision';
|
|
case RestoreResultStatus = 'restore_result_status';
|
|
case ProviderConsentStatus = 'provider_connection.consent_status';
|
|
case ProviderVerificationStatus = 'provider_connection.verification_status';
|
|
case ManagedTenantOnboardingVerificationStatus = 'managed_tenant_onboarding.verification_status';
|
|
case VerificationCheckStatus = 'verification_check_status';
|
|
case VerificationCheckSeverity = 'verification_check_severity';
|
|
case VerificationReportOverall = 'verification_report_overall';
|
|
case AlertDeliveryStatus = 'alert_delivery_status';
|
|
case AlertDestinationLastTestStatus = 'alert_destination_last_test_status';
|
|
case BaselineProfileStatus = 'baseline_profile_status';
|
|
case FindingType = 'finding_type';
|
|
case ReviewPackStatus = 'review_pack_status';
|
|
case EvidenceSnapshotStatus = 'evidence_snapshot_status';
|
|
case EvidenceCompleteness = 'evidence_completeness';
|
|
case TenantReviewStatus = 'tenant_review_status';
|
|
case TenantReviewCompleteness = 'tenant_review_completeness';
|
|
case SystemHealth = 'system_health';
|
|
case ReferenceResolutionState = 'reference_resolution_state';
|
|
case DiffRowStatus = 'diff_row_status';
|
|
}
|