TenantAtlas/tests/Feature
ahmido 6a86c5901a 066-rbac-ui-enforcement-helper (#81)
Kontext / Ziel
Diese PR standardisiert Tenant‑RBAC Enforcement in der Filament‑UI: statt ad-hoc Gate::*, abort_if/abort_unless und kopierten ->visible()/->disabled()‑Closures gibt es jetzt eine zentrale, wiederverwendbare Implementierung für Actions (Header/Table/Bulk).

Links zur Spec:

spec.md
plan.md
quickstart.md
Was ist drin
Neue zentrale Helper-API: UiEnforcement (Tenant-plane RBAC‑UX “source of truth” für Filament Actions)
Standardisierte Tooltip-Texte und Context-DTO (UiTooltips, TenantAccessContext)
Migration vieler tenant‑scoped Filament Action-Surfaces auf das Standardpattern (ohne ad-hoc Auth-Patterns)
CI‑Guard (Test) gegen neue ad-hoc Patterns in app/Filament/**:
verbietet Gate::allows/denies/check/authorize, use Illuminate\Support\Facades\Gate, abort_if/abort_unless
Legacy-Allowlist ist aktuell leer (neue Verstöße failen sofort)
RBAC-UX Semantik (konsequent & testbar)
Non-member: UI Actions hidden (kein Tenant‑Leak); Execution wird blockiert (Filament hidden→disabled chain), Defense‑in‑depth enthält zusätzlich serverseitige Guards.
Member ohne Capability: Action visible aber disabled + Standard-Tooltip; Execution wird blockiert (keine Side Effects).
Member mit Capability: Action enabled und ausführbar.
Destructive actions: über ->destructive() immer mit ->requiresConfirmation() + klare Warntexte (Execution bleibt über ->action(...)).
Wichtig: In Filament v5 sind hidden/disabled Actions typischerweise “silently blocked” (200, keine Ausführung). Die Tests prüfen daher UI‑State + “no side effects”, nicht nur HTTP‑Statuscodes.

Sicherheit / Scope
Keine neuen DB-Tabellen, keine Migrations, keine Microsoft Graph Calls (DB‑only bei Render; kein outbound HTTP).
Tenant Isolation bleibt Isolation‑Boundary (deny-as-not-found auf Tenant‑Ebene, Capability erst nach Membership).
Kein Asset-Setup erforderlich; keine neuen Filament Assets.
Compliance Notes (Repo-Regeln)
Filament v5 / Livewire v4.0+ kompatibel.
Keine Änderungen an Provider‑Registrierung (Laravel 11+/12: providers.php bleibt der Ort; hier unverändert).
Global Search: keine gezielte Änderung am Global‑Search-Verhalten in dieser PR.
Tests / Qualität
Pest Feature/Unit Tests für Member/Non-member/Tooltip/Destructive/Regression‑Guard.
Guard-Test: “No ad-hoc Filament auth patterns”.
Full suite laut Tasks: vendor/bin/sail artisan test --compact → 837 passed, 5 skipped.
Checklist: requirements.md vollständig (16/16).
Review-Fokus
API‑Usage in neuen/angepassten Filament Actions: UiEnforcement::forAction/forTableAction/forBulkAction(...)->requireCapability(...)->apply()
Guard-Test soll “red” werden, sobald jemand neue ad-hoc Auth‑Patterns einführt (by design).

Co-authored-by: Ahmed Darrazi <ahmeddarrazi@MacBookPro.fritz.box>
Reviewed-on: #81
2026-01-30 16:58:02 +00:00
..
Audit 065-tenant-rbac-v1 (#79) 2026-01-28 21:09:47 +00:00
Auth feat: implement auth structure system panel (#77) 2026-01-27 21:49:18 +00:00
BackupScheduling 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BackupSets 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
Console 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
Database fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
DirectoryGroups 065-tenant-rbac-v1 (#79) 2026-01-28 21:09:47 +00:00
Drift 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Filament 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Guards 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Inventory 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Jobs feat/012-windows-update-rings (#18) 2026-01-01 10:44:17 +00:00
Monitoring 058-tenant-ui-polish (#70) 2026-01-22 00:17:23 +00:00
Notifications 055-ops-ux-rollout (#64) 2026-01-18 14:50:15 +00:00
OpsUx feat: implement auth structure system panel (#77) 2026-01-27 21:49:18 +00:00
ProviderConnections 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Rbac 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
Scheduling 054-unify-runs-suitewide (#63) 2026-01-17 22:25:00 +00:00
TenantRBAC 065-tenant-rbac-v1 (#79) 2026-01-28 21:09:47 +00:00
AdminConsentCallbackTest.php feat: TenantPilot v1 - Complete implementation (Phases 1-12) 2025-12-12 02:27:54 +01:00
BackupItemReaddTest.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
BackupServiceVersionReuseTest.php feat: always capture policy when adding to backup (#22) 2026-01-02 14:33:29 +00:00
BackupWithAssignmentsConsistencyTest.php feat/004-assignments-scope-tags (#4) 2025-12-23 21:49:58 +00:00
BulkDeleteBackupSetsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkDeleteMixedStatusTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkDeletePoliciesAsyncTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkDeletePoliciesTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkDeleteRestoreRunsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkExportFailuresTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkExportToBackupTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkForceDeleteBackupSetsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkForceDeletePolicyVersionsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkForceDeleteRestoreRunsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkProgressNotificationTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkPruneSkipReasonsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkPruneVersionsTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
BulkRestoreBackupSetsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkRestorePolicyVersionsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkRestoreRestoreRunsTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkSyncPoliciesTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
BulkTypeToConfirmTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
BulkUnignorePoliciesTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
DatabaseSeederTest.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
DependencyExtractionFeatureTest.php feat/042-inventory-dependencies-graph (#50) 2026-01-10 12:50:08 +00:00
DependencyQueryServiceTest.php feat/042-inventory-dependencies-graph (#49) 2026-01-10 00:20:14 +00:00
DependencyTenantIsolationTest.php feat/042-inventory-dependencies-graph (#49) 2026-01-10 00:20:14 +00:00
DeviceComplianceScriptPolicyTypeTest.php feat/026-custom-compliance-scripts (#29) 2026-01-04 02:28:29 +00:00
EndpointSecurityIntentRestoreSanitizationTest.php feat: endpoint security restore execution (023) (#25) 2026-01-03 22:44:08 +00:00
EndpointSecurityPolicyRestore023Test.php feat: endpoint security restore execution (023) (#25) 2026-01-03 22:44:08 +00:00
ExampleTest.php Initial commit from Specify template 2025-12-10 22:27:21 +01:00
ExecuteRestoreRunJobTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
FoundationBackupTest.php feat(006): foundations + assignment mapping and preview-only restore guard (#7) 2025-12-26 23:44:31 +00:00
InventoryItemDependenciesTest.php feat/047-inventory-foundations-nodes (#51) 2026-01-10 20:47:29 +00:00
MonitoringOperationsTest.php feat: implement auth structure system panel (#77) 2026-01-27 21:49:18 +00:00
OperationRunServiceStaleQueuedRunTest.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
OperationRunServiceTest.php 065-tenant-rbac-v1 (#79) 2026-01-28 21:09:47 +00:00
PolicyCaptureSnapshotIdempotencyTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
PolicyCaptureSnapshotQueuedTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
PolicyGeneralViewTest.php feat/017-policy-types-mam-endpoint-security-baselines (#23) 2026-01-03 02:06:35 +00:00
PolicySettingsStandardViewTest.php feat/017-policy-types-mam-endpoint-security-baselines (#23) 2026-01-03 02:06:35 +00:00
PolicySyncEnrollmentConfigurationTypeCollisionTest.php feat/027-enrollment-config-subtypes (#31) 2026-01-04 13:25:15 +00:00
PolicySyncServiceReportTest.php feat/017-policy-types-mam-endpoint-security-baselines (#23) 2026-01-03 02:06:35 +00:00
PolicySyncServiceTest.php feat/018-driver-updates-wufb (#27) 2026-01-04 00:38:54 +00:00
PolicySyncStartSurfaceTest.php 065-tenant-rbac-v1 (#79) 2026-01-28 21:09:47 +00:00
PolicyTypes017Test.php feat: endpoint security restore execution (023) (#25) 2026-01-03 22:44:08 +00:00
PolicyVersionViewAssignmentsTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
ReclassifyEnrollmentConfigurationsCommandTest.php 014-enrollment-autopilot (#20) 2026-01-02 11:59:21 +00:00
RestoreAdapterTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
RestoreAssignmentApplicationTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RestoreAuditLoggingTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
RestoreGraphErrorMetadataTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RestoreGroupMappingTest.php 051-entra-group-directory-cache (#57) 2026-01-11 23:24:12 +00:00
RestorePreviewDiffWizardTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RestoreRiskChecksWizardTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RestoreRunArchiveGuardTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
RestoreRunIdempotencyTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RestoreRunRerunTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
RestoreRunWizardExecuteTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
RestoreRunWizardMetadataTest.php feat/031-tenant-portfolio-context-switch (#32) 2026-01-04 21:28:08 +00:00
RestoreScopeTagMappingTest.php feat(006): foundations + assignment mapping and preview-only restore guard (#7) 2025-12-26 23:44:31 +00:00
RestoreUnknownPolicyTypeSafetyTest.php feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
RunAuthorizationTenantIsolationTest.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
RunStartAuthorizationTest.php 066-rbac-ui-enforcement-helper (#81) 2026-01-30 16:58:02 +00:00
SettingsCatalogDefinitionResolverTest.php dev-merges/c709b36 (#3) 2025-12-21 23:15:12 +00:00
SyncPoliciesJobDispatchTest.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
SyncPoliciesJobGraphDisabledTest.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
SyncPoliciesJobSupportedTypesTest.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00
TermsAndConditionsPolicyTypeTest.php feat/024-terms-and-conditions (#30) 2026-01-04 03:01:11 +00:00
TrackOperationRunMiddlewareTest.php 054-unify-runs-suitewide (#63) 2026-01-17 22:25:00 +00:00
VersionCaptureMetadataOnlyTest.php feat/017-policy-types-mam-endpoint-security-baselines (#23) 2026-01-03 02:06:35 +00:00
VersionCaptureWithAssignmentsTest.php feat/027-enrollment-config-subtypes (#31) 2026-01-04 13:25:15 +00:00