## Summary
- implement Spec 179 to make tenant lifecycle, provider consent, and provider verification the primary truth axes on the targeted Filament surfaces
- demote legacy tenant app status and legacy provider status and health to diagnostic-only roles, add centralized badge mappings for provider consent and verification, and keep provider connections excluded from global search
- add the full Spec 179 artifact set under `specs/179-provider-truth-cleanup/` plus focused Pest coverage for tenant truth cleanup, provider truth cleanup, RBAC, discovery safety, and badge semantics
- fix the numeric out-of-scope tenant route regression so inaccessible `/admin/tenants/{id}` paths return `404 Not Found` instead of `500`
## Testing
- `vendor/bin/sail artisan test --compact tests/Feature/Filament/TenantLifecycleStatusDomainSeparationTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Filament/TenantTruthCleanupSpec179Test.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Filament/ProviderConnectionsDbOnlyTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/ProviderConnections/ProviderConnectionTruthCleanupSpec179Test.php`
- `vendor/bin/sail artisan test --compact tests/Feature/ProviderConnections/RequiredFiltersTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Tenants/TenantProviderConnectionsCtaTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Rbac/TenantResourceAuthorizationTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/ProviderConnections/ProviderConnectionListAuthorizationTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/ProviderConnections/ProviderConnectionAuthorizationTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Rbac/AdminGlobalSearchContextSafetyTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Filament/TenantGlobalSearchLifecycleScopeTest.php`
- `vendor/bin/sail artisan test --compact tests/Feature/Filament/TenantScopingTest.php`
- `vendor/bin/sail artisan test --compact tests/Unit/Badges/TenantBadgesTest.php`
- `vendor/bin/sail artisan test --compact tests/Unit/Badges/ProviderConnectionBadgesTest.php`
## Manual validation
- integrated-browser smoke on `/admin/tenants`, tenant detail, `/admin/provider-connections`, provider detail, and provider edit
- verified out-of-scope tenant and provider URLs return `404 Not Found` with the current session
## Notes
- branch: `179-provider-truth-cleanup`
- commit: `e54c6632`
- target: `dev`
Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #207
61 lines
3.2 KiB
PHP
61 lines
3.2 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 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 ProviderConnectionStatus = 'provider_connection.status';
|
|
case ProviderConnectionHealth = 'provider_connection.health';
|
|
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';
|
|
}
|