## 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
126 lines
4.7 KiB
PHP
126 lines
4.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Support\Ui\GovernanceArtifactTruth;
|
|
|
|
use App\Support\ReasonTranslation\NextStepOption;
|
|
use App\Support\ReasonTranslation\PlatformReasonFamily;
|
|
use App\Support\ReasonTranslation\ReasonOwnershipDescriptor;
|
|
use App\Support\ReasonTranslation\ReasonResolutionEnvelope;
|
|
use App\Support\Ui\OperatorExplanation\TrustworthinessLevel;
|
|
|
|
final readonly class ArtifactTruthCause
|
|
{
|
|
/**
|
|
* @param array<int, string> $nextSteps
|
|
*/
|
|
public function __construct(
|
|
public ?string $reasonCode,
|
|
public ?string $translationArtifact,
|
|
public ?string $operatorLabel,
|
|
public ?string $shortExplanation,
|
|
public ?string $diagnosticCode,
|
|
public string $trustImpact,
|
|
public ?string $absencePattern,
|
|
public array $nextSteps = [],
|
|
public ?string $ownerLayer = null,
|
|
public ?string $ownerNamespace = null,
|
|
public ?string $platformReasonFamily = null,
|
|
) {}
|
|
|
|
public static function fromReasonResolutionEnvelope(
|
|
?ReasonResolutionEnvelope $reason,
|
|
?string $translationArtifact = null,
|
|
): ?self {
|
|
if (! $reason instanceof ReasonResolutionEnvelope) {
|
|
return null;
|
|
}
|
|
|
|
return new self(
|
|
reasonCode: $reason->internalCode,
|
|
translationArtifact: $translationArtifact,
|
|
operatorLabel: $reason->operatorLabel,
|
|
shortExplanation: $reason->shortExplanation,
|
|
diagnosticCode: $reason->diagnosticCode(),
|
|
trustImpact: $reason->trustImpact,
|
|
absencePattern: $reason->absencePattern,
|
|
nextSteps: array_values(array_map(
|
|
static fn (NextStepOption $nextStep): string => $nextStep->label,
|
|
$reason->nextSteps,
|
|
)),
|
|
ownerLayer: $reason->ownerLayer(),
|
|
ownerNamespace: $reason->ownerNamespace(),
|
|
platformReasonFamily: $reason->platformReasonFamily(),
|
|
);
|
|
}
|
|
|
|
public function toReasonResolutionEnvelope(): ReasonResolutionEnvelope
|
|
{
|
|
$reasonOwnership = null;
|
|
$family = is_string($this->platformReasonFamily)
|
|
? PlatformReasonFamily::tryFrom($this->platformReasonFamily)
|
|
: null;
|
|
|
|
if (is_string($this->ownerLayer)
|
|
&& trim($this->ownerLayer) !== ''
|
|
&& is_string($this->ownerNamespace)
|
|
&& trim($this->ownerNamespace) !== ''
|
|
&& $family instanceof PlatformReasonFamily) {
|
|
$reasonOwnership = new ReasonOwnershipDescriptor(
|
|
ownerLayer: trim($this->ownerLayer),
|
|
ownerNamespace: trim($this->ownerNamespace),
|
|
reasonCode: $this->reasonCode ?? 'artifact_truth_reason',
|
|
platformReasonFamily: $family,
|
|
);
|
|
}
|
|
|
|
return new ReasonResolutionEnvelope(
|
|
internalCode: $this->reasonCode ?? 'artifact_truth_reason',
|
|
operatorLabel: $this->operatorLabel ?? 'Operator attention required',
|
|
shortExplanation: $this->shortExplanation ?? 'Technical diagnostics are available for this result.',
|
|
actionability: $this->absencePattern === 'true_no_result' ? 'non_actionable' : 'prerequisite_missing',
|
|
nextSteps: array_map(
|
|
static fn (string $label): NextStepOption => NextStepOption::instruction($label),
|
|
$this->nextSteps,
|
|
),
|
|
diagnosticCodeLabel: $this->diagnosticCode,
|
|
trustImpact: $this->trustImpact !== '' ? $this->trustImpact : TrustworthinessLevel::LimitedConfidence->value,
|
|
absencePattern: $this->absencePattern,
|
|
reasonOwnership: $reasonOwnership,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return array{
|
|
* reasonCode: ?string,
|
|
* translationArtifact: ?string,
|
|
* operatorLabel: ?string,
|
|
* shortExplanation: ?string,
|
|
* diagnosticCode: ?string,
|
|
* trustImpact: string,
|
|
* absencePattern: ?string,
|
|
* nextSteps: array<int, string>,
|
|
* ownerLayer: ?string,
|
|
* ownerNamespace: ?string,
|
|
* platformReasonFamily: ?string
|
|
* }
|
|
*/
|
|
public function toArray(): array
|
|
{
|
|
return [
|
|
'reasonCode' => $this->reasonCode,
|
|
'translationArtifact' => $this->translationArtifact,
|
|
'operatorLabel' => $this->operatorLabel,
|
|
'shortExplanation' => $this->shortExplanation,
|
|
'diagnosticCode' => $this->diagnosticCode,
|
|
'trustImpact' => $this->trustImpact,
|
|
'absencePattern' => $this->absencePattern,
|
|
'nextSteps' => $this->nextSteps,
|
|
'ownerLayer' => $this->ownerLayer,
|
|
'ownerNamespace' => $this->ownerNamespace,
|
|
'platformReasonFamily' => $this->platformReasonFamily,
|
|
];
|
|
}
|
|
}
|