## 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
52 lines
1.8 KiB
PHP
52 lines
1.8 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Services\Evidence\Sources;
|
|
|
|
use App\Models\StoredReport;
|
|
use App\Models\ManagedEnvironment;
|
|
use App\Services\Evidence\Contracts\EvidenceSourceProvider;
|
|
use App\Support\Evidence\EvidenceCompletenessState;
|
|
|
|
final class EntraAdminRolesSource implements EvidenceSourceProvider
|
|
{
|
|
public function key(): string
|
|
{
|
|
return 'entra_admin_roles';
|
|
}
|
|
|
|
public function collect(ManagedEnvironment $tenant): array
|
|
{
|
|
$report = StoredReport::query()
|
|
->where('managed_environment_id', (int) $tenant->getKey())
|
|
->where('report_type', StoredReport::REPORT_TYPE_ENTRA_ADMIN_ROLES)
|
|
->latest('id')
|
|
->first();
|
|
|
|
$payload = is_array($report?->payload) ? $report->payload : [];
|
|
$roles = is_array($payload['roles'] ?? null) ? $payload['roles'] : [];
|
|
|
|
return [
|
|
'dimension_key' => $this->key(),
|
|
'state' => $report instanceof StoredReport ? EvidenceCompletenessState::Complete->value : EvidenceCompletenessState::Missing->value,
|
|
'required' => true,
|
|
'source_kind' => 'stored_report',
|
|
'source_record_type' => StoredReport::class,
|
|
'source_record_id' => $report instanceof StoredReport ? (string) $report->getKey() : null,
|
|
'source_fingerprint' => $report?->fingerprint,
|
|
'measured_at' => $report?->updated_at,
|
|
'freshness_at' => $report?->updated_at,
|
|
'summary_payload' => [
|
|
'role_count' => count($roles),
|
|
'roles' => $roles,
|
|
],
|
|
'fingerprint_payload' => [
|
|
'fingerprint' => $report?->fingerprint,
|
|
'role_count' => count($roles),
|
|
],
|
|
'sort_order' => 30,
|
|
];
|
|
}
|
|
}
|