TenantAtlas/app/Services
ahmido c5fbcaa692 063-entra-signin (#76)
Key changes

Adds Entra OIDC redirect + callback endpoints under /auth/entra/* (token exchange only there).
Upserts tenant users keyed by (entra_tenant_id = tid, entra_object_id = oid); regenerates session; never stores tokens.
Blocks disabled / soft-deleted users with a generic error and safe logging.
Membership-based post-login routing:
0 memberships → /admin/no-access
1 membership → tenant dashboard (via Filament URL helpers)
>1 memberships → /admin/choose-tenant
Adds Filament pages:
/admin/choose-tenant (tenant selection + redirect)
/admin/no-access (tenantless-safe)
Both use simple layout to avoid tenant-required UI.
Guards / tests

Adds DbOnlyPagesDoNotMakeHttpRequestsTest to enforce DB-only render/hydration for:
/admin/login, /admin/no-access, /admin/choose-tenant
with Http::preventStrayRequests()
Adds session separation smoke coverage to ensure tenant session doesn’t access system and vice versa.
Runs: vendor/bin/sail artisan test --compact tests/Feature/Auth

Co-authored-by: Ahmed Darrazi <ahmeddarrazi@MacBookPro.fritz.box>
Reviewed-on: #76
2026-01-27 16:38:53 +00:00
..
Auth 063-entra-signin (#76) 2026-01-27 16:38:53 +00:00
BackupScheduling feat/032-backup-scheduling-mvp (#36) 2026-01-07 01:12:12 +00:00
Directory 051-entra-group-directory-cache (#57) 2026-01-11 23:24:12 +00:00
Drift feat/044-drift-mvp (#58) 2026-01-14 23:16:10 +00:00
Graph 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
Intune feat/049-backup-restore-job-orchestration (#56) 2026-01-11 15:59:06 +00:00
Inventory feat/047-inventory-foundations-nodes (#51) 2026-01-10 20:47:29 +00:00
Operations 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
Providers feat: unify provider connection actions and notifications (#73) 2026-01-25 01:01:37 +00:00
AdapterRunReconciler.php 056-remove-legacy-bulkops (#65) 2026-01-19 23:27:52 +00:00
AssignmentBackupService.php feat/009-app-protection-policy (#11) 2025-12-29 16:11:50 +00:00
AssignmentRestoreService.php feat/009-app-protection-policy (#11) 2025-12-29 16:11:50 +00:00
OperationRunService.php fix: Harden SyncPoliciesJob supported types handling (#75) 2026-01-26 19:23:40 +00:00