## Summary - add the shared resolved-reference foundation with registry, resolvers, presenters, and badge semantics - refactor related context, assignment evidence, and policy-version assignment rendering toward label-first reference presentation - add Spec 132 artifacts and focused Pest coverage for reference resolution, degraded states, canonical linking, and tenant-context carryover ## Verification - `vendor/bin/sail bin pint --dirty --format agent` - focused Pest verification was marked complete in the task artifact ## Notes - this PR is opened from the current session branch - `specs/132-guid-context-resolver/tasks.md` reflects in-progress completion state for the implemented tasks Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #161
55 lines
1.7 KiB
PHP
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('tenant_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');
|
|
}
|
|
}
|