TenantAtlas/apps/platform/app/Support/ReasonTranslation/ReasonOwnershipDescriptor.php
ahmido ad16eee591 Spec 204: harden platform core vocabulary (#234)
## Summary
- add the Spec 204 platform vocabulary foundation, including canonical glossary terms, registry ownership descriptors, canonical operation type and alias resolution, and explicit reason ownership and platform reason-family metadata
- harden platform-facing compare, snapshot, evidence, monitoring, review, and reporting surfaces so they prefer governed-subject and canonical operation semantics while preserving intentional Intune-owned terminology
- extend Spec 204 unit, feature, Filament, and architecture coverage and add the full spec artifacts, checklist, and completed task ledger

## Verification
- ran the focused recent-change Sail verification pack for the new glossary and reason-semantics work
- ran the full Spec 204 quickstart verification pack under Sail
- ran `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent`
- ran an integrated-browser smoke pass covering tenant dashboard, operations, operation detail, baseline compare, evidence, reviews, review packs, provider connections, inventory items, backup schedules, onboarding, and the system dashboard/operations/failures/run-detail surfaces

## Notes
- provider registration is unchanged and remains in `bootstrap/providers.php`
- no new destructive actions or asset-registration changes are introduced by this branch

Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de>
Reviewed-on: #234
2026-04-14 06:09:42 +00:00

62 lines
1.8 KiB
PHP

<?php
declare(strict_types=1);
namespace App\Support\ReasonTranslation;
final readonly class ReasonOwnershipDescriptor
{
public function __construct(
public string $ownerLayer,
public string $ownerNamespace,
public string $reasonCode,
public PlatformReasonFamily $platformReasonFamily,
) {}
/**
* @param array<string, mixed> $data
*/
public static function fromArray(array $data): ?self
{
$family = is_string($data['platform_reason_family'] ?? null)
? PlatformReasonFamily::tryFrom((string) $data['platform_reason_family'])
: null;
if (! $family instanceof PlatformReasonFamily) {
return null;
}
$ownerLayer = is_string($data['owner_layer'] ?? null) ? trim((string) $data['owner_layer']) : '';
$ownerNamespace = is_string($data['owner_namespace'] ?? null) ? trim((string) $data['owner_namespace']) : '';
$reasonCode = is_string($data['reason_code'] ?? null) ? trim((string) $data['reason_code']) : '';
if ($ownerLayer === '' || $ownerNamespace === '' || $reasonCode === '') {
return null;
}
return new self(
ownerLayer: $ownerLayer,
ownerNamespace: $ownerNamespace,
reasonCode: $reasonCode,
platformReasonFamily: $family,
);
}
/**
* @return array{
* owner_layer: string,
* owner_namespace: string,
* reason_code: string,
* platform_reason_family: string
* }
*/
public function toArray(): array
{
return [
'owner_layer' => $this->ownerLayer,
'owner_namespace' => $this->ownerNamespace,
'reason_code' => $this->reasonCode,
'platform_reason_family' => $this->platformReasonFamily->value,
];
}
}