TenantAtlas/apps/platform/app/Support/References/Resolvers/EntraRoleDefinitionReferenceResolver.php
ahmido e64bae9cfc feat: cut over tenant core to managed environments (#335)
## Summary
- replace the legacy Tenant and TenantMembership core models with ManagedEnvironment and ManagedEnvironmentMembership
- propagate the managed environment naming and key changes across Filament resources, pages, controllers, jobs, models, and supporting runtime paths
- add feature 279 spec artifacts and focused managed-environment test coverage for model behavior, route binding, panel context, authorization, and legacy guardrails

## Validation
- `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/ManagedEnvironment/LegacyTenantCoreGuardTest.php tests/Feature/ManagedEnvironment/ManagedEnvironmentAuthorizationTest.php tests/Feature/ManagedEnvironment/ManagedEnvironmentPanelContextTest.php tests/Feature/ManagedEnvironment/ManagedEnvironmentRouteBindingTest.php tests/Unit/ManagedEnvironment/ManagedEnvironmentContextResolverTest.php tests/Unit/ManagedEnvironment/ManagedEnvironmentModelTest.php`
- `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent`

## Notes
- branch pushed from commit `1123b122`
- browser smoke test file was added but not run in this pass

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #335
2026-05-07 06:38:14 +00:00

55 lines
1.7 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Support\References\Resolvers;
use App\Models\EntraRoleDefinition;
use App\Support\References\ReferenceClass;
use App\Support\References\ReferenceDescriptor;
use App\Support\References\ResolvedReference;
final class EntraRoleDefinitionReferenceResolver extends BaseReferenceResolver
{
public function __construct(
\App\Support\References\ReferenceTypeLabelCatalog $typeLabels,
) {
parent::__construct($typeLabels);
}
public function referenceClass(): ReferenceClass
{
return ReferenceClass::RoleDefinition;
}
public function resolve(ReferenceDescriptor $descriptor): ResolvedReference
{
$tenantId = $descriptor->tenantId;
if ($tenantId === null || $tenantId <= 0) {
return $this->unresolved($descriptor, primaryLabel: 'Role definition');
}
$roleDefinition = EntraRoleDefinition::query()
->where('managed_environment_id', $tenantId)
->where('entra_id', $descriptor->rawIdentifier)
->first();
if ($roleDefinition instanceof EntraRoleDefinition) {
return $this->resolved(
descriptor: $descriptor,
primaryLabel: (string) $roleDefinition->display_name,
secondaryLabel: $roleDefinition->is_built_in ? 'Built-in role definition' : 'Custom role definition',
);
}
$fallback = $descriptor->fallbackLabel;
if (is_string($fallback) && trim($fallback) !== '') {
return $this->externalLimited($descriptor, primaryLabel: $fallback, secondaryLabel: 'Captured role definition');
}
return $this->unresolved($descriptor, primaryLabel: 'Role definition');
}
}