-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProcess.php
More file actions
72 lines (68 loc) · 1.9 KB
/
Process.php
File metadata and controls
72 lines (68 loc) · 1.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<?php
declare(strict_types=1);
namespace KaririCode\ProcessorPipeline\Attribute;
use Attribute;
/**
* Marks a class property for pipeline processing.
*
* Apply this attribute to properties that should be processed through a
* specific set of processors. The attribute is consumed by
* {@see \KaririCode\PropertyInspector\AttributeAnalyzer} at runtime.
*
* ARFA 1.3 Compliance
* ===================
*
* P2 (Reactive Flow Composition):
* Declarative processor composition via PHP 8.4+ attributes.
* The processor list defines the flow: f₁ ∘ f₂ ∘ ... ∘ fₙ.
*
* Usage
* =====
*
* ```php
* use KaririCode\ProcessorPipeline\Attribute\Process;
*
* class UserProfile
* {
* #[Process(
* processors: ['trim', 'lowercase', 'email'],
* messages: [
* 'email' => 'Invalid email format.',
* ],
* )]
* public private(set) string $email = '';
*
* #[Process(
* processors: [
* 'required',
* 'length' => ['minLength' => 3, 'maxLength' => 50],
* ],
* messages: [
* 'required' => 'Username is required.',
* 'length' => 'Username must be 3-50 characters.',
* ],
* )]
* public private(set) string $username = '';
* }
* ```
*
* @package KaririCode\ProcessorPipeline\Attribute
* @author Walmir Silva <walmir.silva@kariricode.org>
* @copyright 2025 KaririCode
* @license MIT
* @version 2.0.0
* @since 2.0.0
*/
#[Attribute(Attribute::TARGET_PROPERTY | Attribute::IS_REPEATABLE)]
final readonly class Process
{
/**
* @param array<int|string, string|array<string, mixed>> $processors Processor specification
* @param array<string, string> $messages Error key → message overrides
*/
public function __construct(
public array $processors = [],
public array $messages = [],
) {
}
}