Laravel validate is a package for validate faster & easier.
You can validate data easier, Laravel validate have lots of rule class for validation.
This package support localization and you can use for most of the language.
(If some language didn't support, you can PR for new language)
PHP >= 8.0
Laravel >= 9.0
Morilog-Jalali >= 3.x
GitHub | L6 | L7 | L8 | L9 | L10 |
---|---|---|---|---|---|
1.5 | ✅ | ✅ | ✅ | ✅ | ❌ |
1.6 | ❌ | ❌ | ❌ | ✅ | ✅ |
composer require milwad/laravel-validate
use Milwad\LaravelValidate\Rules\ValidPhoneNumber;
return [
'phone' => ['required', new ValidPhoneNumber()],
];
If you want to publish lang file for custom validation message you can run this command in terminal:
php artisan vendor:publish --tag="validate-lang-{$lang}"
You can replace $lang
to your lang name, for ex:
php artisan vendor:publish --tag="validate-lang-en"
If you don't know about langs name you can go Support Languages
# | Rule name | Usage |
---|---|---|
1 | ValidBitcoinAddress | Validate bitcoin address for ex (1KFHE7w8BhaENAswwryaoccDb6qcT6DbYY) |
2 | ValidCapitalCharWithNumber | Validate String for ex (MILWAD-84) |
3 | ValidDiscordUsername | Validate username discord for ex (Milwad#2134) |
4 | ValidHashtag | Validate hashtag for ex (#milwad) |
5 | ValidIpAddressIPV4 | Validate ip address IPV4 for ex (129.144.50.56) |
6 | ValidIpAddressIPV6 | Validate ip address IPV6 for ex (2001:db8:3333:4444:5555:6666:7777:8888) |
7 | ValidPhoneNumber | Validate phone number for ex (09366000000) |
8 | ValidPort | Validate port value for ex (8080) |
9 | ValidSlug | Validate slug for ex (milwad-dev) |
10 | ValidImei | Validate imei phone for ex (354809104295874) |
11 | ValidStrongPassword | Validate password for ex (Milwad123!) |
12 | ValidUrl | Validate url for ex (https://www.google.com) |
13 | ValidUsername | Validate username for ex (milwad) |
14 | ValidUuid | Validate uuid for ex (123e4567-e89b-12d3-a456-426655440000) |
15 | ValidHexColor | Validate hex color for ex (#fcba03) |
16 | ValidHtmlTag | Validate html tags for ex (<h1></h1> ) |
17 | ValidNationalCard | Validate national card for ex (015016437) |
18 | ValidCarNumber | Validate car number for ex (KA01AB1234) |
19 | ValidNameDaysWeek | Validate day week for ex (monday) |
20 | ValidEvenNumber | Validate number is even for ex (1024) |
21 | ValidOddNumber | Validate number is odd for ex (4321) |
22 | ValidSlashEndOfString | Validate write slash at the string for ex (milwad/) |
23 | ValidCartNumberIran | Validate cart number for ex (1234123412341234) |
24 | ValidBase64 | Validate base64 for ex (bWlsd2Fk) |
25 | ValidJwt | Validate jwt |
26 | ValidJalaliDate | Validate jajali date for ex (1384/8/25) |
27 | ValidDuplicateCharacter | Validate duplicate characters for ex (1,2,3,4,5,6,7,8,9) |
28 | ValidPattern | Validate texts with specific pattern 🔥 for ex (4444-4444-4444) |
29 | ValidDuplicate | Validate duplicate string, numbers for ex (1123456) |
30 | ValidUlid | Validate ulid for ex (01ARZ3NDEKTSV4RRFFQ69G5FAV) |
Sometimes you need to validate text with pattern, For example you want to validate a text like (4444-4444-4444).
If you want to check the length of text is seperator after -
is 4, You can use this Rule:
use Milwad\LaravelValidate\Rules\ValidPattern;
return [
'numbers' => ['required', new ValidPattern(4, '-')],
];
If a language is not supported, you can make issue to add it.
Also, you can make PR to add it.
- English (en)
- Persian (fa)
- Arabic (ar)
- Chinese (zh_CN)
- French (fr)
- Hindi (hi)
- Italian (It)
- Japanese (ja)
- Korean (Ko)
- Russian (ru)
- This package is created and modified by Milwad Khosravi for Laravel upper more than 9 and is released under the MIT License.
This project exists thanks to all the people who contribute. CONTRIBUTING
If you've found a bug regarding security please mail milwad.dev@gmail.com instead of using the issue tracker.