mirror of
https://github.com/Respect/Validation.git
synced 2026-03-15 23:05:45 +01:00
- Remove redundant "valid" prefix: Date, DateTime, DateTimeDiff, Domain, Email, Iban, Imei, Ip, Isbn, Json, LanguageCode, LeapDate, LeapYear, Luhn, MacAddress, NfeAccessKey, Nif, Nip, Pesel, Phone, Pis, PolishIdCard, PostalCode, Roman, Slug, Tld, Url, Uuid, Version. - Remove redundant "value" suffix ArrayVal, BoolVal, Countable, FloatVal, IntVal, IterableVal, NumericVal, ScalarVal, StringVal. - Standardize "consist only of" phrasing Alnum, Alpha, Cntrl, Consonant, Digit, Graph, Lowercase, Printable, Punct, Space, Spaced, Uppercase, Vowel, Xdigit. - Improve file accessibility messages Directory, Executable, File, Image, Readable, SymbolicLink, Writable. - Improve grammar and article usage CreditCard, Extension, Mimetype, Regex, Size.
1.8 KiB
1.8 KiB
Masked
Masked(string $range, Validator $validator)Masked(string $range, Validator $validator, string $replacement)
Decorates a validator to mask input values in error messages while still validating the original unmasked input.
v::masked('1-@', v::email())->assert('foo@example.com');
// Validation passes successfully
v::masked('1-@', v::email())->assert('invalid username@domain.com');
// → "****************@domain.com" must be an email address
v::masked('1-', v::lengthGreaterThan(10))->assert('password');
// → The length of "********" must be greater than 10
v::masked('6-12', v::creditCard(), 'X')->assert('4111111111111211');
// → "41111XXXXXXX1211" must be a credit card number
This validator is useful for security-sensitive applications where error messages should not expose sensitive data like credit card numbers, passwords, or email addresses.
It uses respect/string-formatter as the underlying masking engine. See the section the documentation of MaskFormatter for more information.
Categorization
- Display
- Miscellaneous
Behavior
The validator first ensures the input is a valid string using StringVal. If the input passes string validation, it validates the original unmasked input using the inner validator. If validation fails, it applies masking to the input value shown in error messages.
Changelog
| Version | Description |
|---|---|
| 3.0.0 | Created |