refactor(form-builder): drop custom purpose escape from schemas
Reduces the FormPurpose vocabulary from 22 variants + a `custom` escape to the seven v1.0 purposes registered in the new PurposeRegistry. - Purge migration deletes any form_schemas row whose `purpose` is not in the v1.0 set (cascades through form_fields, form_submissions, form_values, form_value_options, form_schema_sections, form_submission_section_statuses, form_submission_delegations, form_schema_webhooks, form_webhook_deliveries via existing FK). - Drop migration removes the `custom_purpose_slug` column + its index. - Both migrations declare their `down()` as a hard failure — we do not support reversing a purge (pre-launch, no production data). - `FormPurpose` enum slims to the seven cases; the legacy helpers (defaultSubmissionMode / defaultSubjectType / allowsPublicAccess) now delegate to PurposeRegistry so callers keep working. - FormSchema fillable / FormSchemaResource / StoreFormSchemaRequest / UpdateFormSchemaRequest / FormSchemaFactory drop every reference to `custom_purpose_slug` and the `custom` purpose. - VerifyFormsDataIntegrity drops the custom-slug mismatch check and sources the subject-type allow-list from PurposeRegistry. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -4,30 +4,25 @@ declare(strict_types=1);
|
||||
|
||||
namespace App\Enums\FormBuilder;
|
||||
|
||||
/**
|
||||
* v1.0 purpose vocabulary — the seven purposes registered in
|
||||
* `config/form_builder/purposes.php` (ARCH-CONSOLIDATION §3 besluit 4).
|
||||
*
|
||||
* Prefer `App\FormBuilder\Purposes\PurposeRegistry` for lookups: label,
|
||||
* subject_type, default submission mode, public-access flag and
|
||||
* required bindings all live there. This enum is kept for type-safety
|
||||
* on the `form_schemas.purpose` column and for code paths that match
|
||||
* a purpose by identity.
|
||||
*/
|
||||
enum FormPurpose: string
|
||||
{
|
||||
case EVENT_REGISTRATION = 'event_registration';
|
||||
case USER_PROFILE = 'user_profile';
|
||||
case ARTIST_PROFILE = 'artist_profile';
|
||||
case COMPANY_PROFILE = 'company_profile';
|
||||
case ARTIST_ADVANCE = 'artist_advance';
|
||||
case SUPPLIER_INTAKE = 'supplier_intake';
|
||||
case INCIDENT_REPORT = 'incident_report';
|
||||
case FEEDBACK = 'feedback';
|
||||
case POST_EVENT_EVALUATION = 'post_event_evaluation';
|
||||
case INCIDENT_REPORT = 'incident_report';
|
||||
case SIGNATURE_CONTRACT = 'signature_contract';
|
||||
case SIGNATURE_CODE_OF_CONDUCT = 'signature_code_of_conduct';
|
||||
case SIGNATURE_RECEIPT = 'signature_receipt';
|
||||
case ABSENCE_REPORT = 'absence_report';
|
||||
case CHECK_OUT_INVENTORY = 'check_out_inventory';
|
||||
case PUBLIC_COMPLAINT = 'public_complaint';
|
||||
case PUBLIC_PRESS_REQUEST = 'public_press_request';
|
||||
case PUBLIC_RSVP = 'public_rsvp';
|
||||
case ONBOARDING_WIZARD = 'onboarding_wizard';
|
||||
case EVENT_SETUP_WIZARD = 'event_setup_wizard';
|
||||
case COMPANY_CUSTOM = 'company_custom';
|
||||
case ARTIST_CUSTOM = 'artist_custom';
|
||||
case CUSTOM = 'custom';
|
||||
case USER_PROFILE = 'user_profile';
|
||||
|
||||
/**
|
||||
* @return array<int, string>
|
||||
@@ -37,83 +32,24 @@ enum FormPurpose: string
|
||||
return array_map(fn (self $case): string => $case->value, self::cases());
|
||||
}
|
||||
|
||||
/**
|
||||
* Default subject_type for each purpose per ARCH §3.1.
|
||||
* null = subject may be null (public or ambiguous).
|
||||
*/
|
||||
public function defaultSubjectType(): ?string
|
||||
{
|
||||
return match ($this) {
|
||||
self::EVENT_REGISTRATION,
|
||||
self::POST_EVENT_EVALUATION,
|
||||
self::SIGNATURE_RECEIPT,
|
||||
self::ABSENCE_REPORT,
|
||||
self::CHECK_OUT_INVENTORY => 'person',
|
||||
|
||||
self::USER_PROFILE,
|
||||
self::SIGNATURE_CODE_OF_CONDUCT => 'user',
|
||||
|
||||
self::ARTIST_PROFILE,
|
||||
self::ARTIST_ADVANCE,
|
||||
self::ARTIST_CUSTOM => 'artist',
|
||||
|
||||
self::COMPANY_PROFILE,
|
||||
self::SUPPLIER_INTAKE,
|
||||
self::COMPANY_CUSTOM => 'company',
|
||||
|
||||
self::ONBOARDING_WIZARD => 'organisation',
|
||||
self::EVENT_SETUP_WIZARD => 'event',
|
||||
|
||||
self::INCIDENT_REPORT,
|
||||
self::FEEDBACK,
|
||||
self::SIGNATURE_CONTRACT => 'user',
|
||||
|
||||
self::PUBLIC_COMPLAINT,
|
||||
self::PUBLIC_PRESS_REQUEST,
|
||||
self::PUBLIC_RSVP,
|
||||
self::CUSTOM => null,
|
||||
};
|
||||
}
|
||||
|
||||
public function defaultSubmissionMode(): FormSubmissionMode
|
||||
{
|
||||
return match ($this) {
|
||||
self::EVENT_REGISTRATION,
|
||||
self::ARTIST_ADVANCE,
|
||||
self::SUPPLIER_INTAKE => FormSubmissionMode::DRAFT_SINGLE,
|
||||
return app(\App\FormBuilder\Purposes\PurposeRegistry::class)
|
||||
->get($this->value)
|
||||
->defaultSubmissionMode;
|
||||
}
|
||||
|
||||
self::INCIDENT_REPORT,
|
||||
self::FEEDBACK,
|
||||
self::SIGNATURE_RECEIPT,
|
||||
self::ABSENCE_REPORT,
|
||||
self::CHECK_OUT_INVENTORY,
|
||||
self::PUBLIC_COMPLAINT,
|
||||
self::PUBLIC_PRESS_REQUEST => FormSubmissionMode::MULTIPLE,
|
||||
|
||||
self::USER_PROFILE,
|
||||
self::ARTIST_PROFILE,
|
||||
self::COMPANY_PROFILE,
|
||||
self::POST_EVENT_EVALUATION,
|
||||
self::SIGNATURE_CONTRACT,
|
||||
self::SIGNATURE_CODE_OF_CONDUCT,
|
||||
self::PUBLIC_RSVP,
|
||||
self::ONBOARDING_WIZARD,
|
||||
self::EVENT_SETUP_WIZARD,
|
||||
self::COMPANY_CUSTOM,
|
||||
self::ARTIST_CUSTOM,
|
||||
self::CUSTOM => FormSubmissionMode::SINGLE,
|
||||
};
|
||||
public function defaultSubjectType(): string
|
||||
{
|
||||
return app(\App\FormBuilder\Purposes\PurposeRegistry::class)
|
||||
->get($this->value)
|
||||
->subjectType;
|
||||
}
|
||||
|
||||
public function allowsPublicAccess(): bool
|
||||
{
|
||||
return match ($this) {
|
||||
self::PUBLIC_COMPLAINT,
|
||||
self::PUBLIC_PRESS_REQUEST,
|
||||
self::PUBLIC_RSVP,
|
||||
self::ARTIST_ADVANCE,
|
||||
self::SUPPLIER_INTAKE => true,
|
||||
default => false,
|
||||
};
|
||||
return app(\App\FormBuilder\Purposes\PurposeRegistry::class)
|
||||
->get($this->value)
|
||||
->allowsPublicAccess;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user