feat(form-builder): add PurposeSubjectResolver per purpose (WS-6)
Parallel interface to PurposeGuardProvider for runtime subject resolution. Seven concrete resolvers, one per v1.0 purpose. Wired through purposes.php via subject_resolver_class key. EventRegistration uses PersonProvisioner (may create). Other purposes resolve from existing context (portal token, production request, auth). IncidentReport is the only purpose allowed to return null (anonymous- allowed configurations); the others return concrete model types (narrowed via PHP covariance) for caller convenience. Refs: RFC-WS-6.md §3 (Q9) Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -33,6 +33,7 @@ return [
|
||||
'allows_public_access' => true,
|
||||
'required_bindings' => ['person.email', 'person.first_name', 'person.last_name'],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\EventRegistrationGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\EventRegistrationSubjectResolver::class,
|
||||
],
|
||||
|
||||
'artist_advance' => [
|
||||
@@ -42,6 +43,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => [],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\ArtistAdvanceGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\ArtistAdvanceSubjectResolver::class,
|
||||
],
|
||||
|
||||
'supplier_intake' => [
|
||||
@@ -51,6 +53,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => ['company.name'],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\SupplierIntakeGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\SupplierIntakeSubjectResolver::class,
|
||||
],
|
||||
|
||||
'post_event_evaluation' => [
|
||||
@@ -60,6 +63,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => [],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\PostEventEvaluationGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\PostEventEvaluationSubjectResolver::class,
|
||||
],
|
||||
|
||||
'incident_report' => [
|
||||
@@ -69,6 +73,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => [],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\IncidentReportGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\IncidentReportSubjectResolver::class,
|
||||
],
|
||||
|
||||
'signature_contract' => [
|
||||
@@ -78,6 +83,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => [],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\SignatureContractGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\SignatureContractSubjectResolver::class,
|
||||
],
|
||||
|
||||
'user_profile' => [
|
||||
@@ -87,6 +93,7 @@ return [
|
||||
'allows_public_access' => false,
|
||||
'required_bindings' => [],
|
||||
'guards_class' => \App\FormBuilder\Purposes\Guards\UserProfileGuards::class,
|
||||
'subject_resolver_class' => \App\FormBuilder\Purposes\Resolvers\UserProfileSubjectResolver::class,
|
||||
],
|
||||
|
||||
];
|
||||
|
||||
Reference in New Issue
Block a user