Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork1
Laravel advanced validation rules for real-life scenarios.
License
arifszn/laravel-advanced-validation
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Laravel advanced validation rules for real-life scenarios.
Install viacomposer
composer require arifszn/laravel-advanced-validation
Laravel uses Package Auto-Discovery, so doesn't require you to manually add the ServiceProvider.
If you wish to edit the package translations, you can run the following command to publish them into yourresources/lang
folder
php artisan vendor:publish --provider="Arifszn\AdvancedValidation\ServiceProvider"
You can specify the error message on the fly when declaring the rules. Simple pass the error message parameter.
useArifszn\AdvancedValidation\Rules\Username;publicfunctionrules(){return ['foo' => [newUsername('Your custom error message')], ];}
Ascii
Base64 Image
Base64 String
BIC
Btc Address
Credit Card
Data URI
Divisible By
Ethereum Address
Float Number
Hash
Image URL
JWT
Name
Phone
Username
Without Spaces
The field under validation must contain ASCII chars only.
public Arifszn\AdvancedValidation\Rules\Ascii::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Ascii;publicfunctionrules(){return ['foo' => [newAscii()], ];}
The field under validation must be a Base64 encoded image.
public Arifszn\AdvancedValidation\Rules\Base64Image::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Base64Image;publicfunctionrules(){return ['avatar' => [newBase64Image()], ];}
The field under validation must be a Base64 encoded string.
public Arifszn\AdvancedValidation\Rules\Base64String::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Base64String;publicfunctionrules(){return ['foo' => [newBase64String()], ];}
The field under validation must be a BIC(Business Identifier Code) or SWIFT code.
public Arifszn\AdvancedValidation\Rules\BIC::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\BIC;publicfunctionrules(){return ['foo' => [newBIC()], ];}
The field under validation must be a valid BTC address.
public Arifszn\AdvancedValidation\Rules\BtcAddress::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\BtcAddress;publicfunctionrules(){return ['foo' => [newBtcAddress()], ];}
The field under validation must be a valid credit card number.
public Arifszn\AdvancedValidation\Rules\CreditCard::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\CreditCard;publicfunctionrules(){return ['foo' => [newCreditCard()], ];}
The field under validation must havedata uri format.
public Arifszn\AdvancedValidation\Rules\DataURI::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\DataURI;publicfunctionrules(){return ['foo' => [newDataURI()], ];}
The field under validation must be divisible by the given number.
public Arifszn\AdvancedValidation\Rules\DivisibleBy::__construct(int $number, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\DivisibleBy;publicfunctionrules(){return ['foo' => [newDivisibleBy(2)], ];}
The field under validation must be anEthereum address. Does not validate address checksums.
public Arifszn\AdvancedValidation\Rules\EthereumAddress::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\EthereumAddress;publicfunctionrules(){return ['foo' => [newEthereumAddress()], ];}
The field under validation must be a float number.
public Arifszn\AdvancedValidation\Rules\FloatNumber::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\FloatNumber;publicfunctionrules(){return ['foo' => [newFloatNumber()], ];}
The field under validation must be a hash of type algorithm.
Algorithm is one of'md4', 'md5', 'sha1', 'sha256', 'sha384', 'sha512', 'ripemd128', 'ripemd160', 'tiger128', 'tiger160', 'tiger192', 'crc32', 'crc32b'
.
public Arifszn\AdvancedValidation\Rules\Hash::__construct(string $algorithm, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Hash;publicfunctionrules(){return ['foo' => [newHash('md4')], ];}
The field under validation must be a valid image URL.
✓https://www.php.net/images/logos/php-logo.png
✕https://imaginarysite123.com/invalid.png
public Arifszn\AdvancedValidation\Rules\ImageURL::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\ImageURL;publicfunctionrules(){return ['avatar' => [newImageURL()], ];}
The field under validation must have a valid format of JWT (JSON Web Token).
public Arifszn\AdvancedValidation\Rules\Jwt::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Jwt;publicfunctionrules(){return ['foo' => [newJwt()], ];}
The field under validation must be a valid name.
- no emoji
- no number (if
$allowNumber
flag is true, it will accept numbers, default is false) - special characters are allowed (restricting special characters will cause false-negative for names like
Martin Luther King, Jr.
or李小龍
)
public Arifszn\AdvancedValidation\Rules\Name::__construct(bool $allowNumber = false, string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Name;publicfunctionrules(){return ['name' => [newName()], ];}
The field under validation must be a valid phone number.
✓ +x-xxx-xxx-xxxx
✓ +xxxxxxxxxxx
✓ (xxx) xxx-xxxx
✓ xxxxxxxxxx
public Arifszn\AdvancedValidation\Rules\Phone::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Phone;publicfunctionrules(){return ['foo' => [newPhone()], ];}
The field under validation must be a valid username.
- starts with a letter (alpha)
- only alpha-numeric (a-z, A-Z, 0-9), underscore, minus and dot
- multiple underscores, minus and are not allowed (-- or __ or ..)
- underscores, minus and dot are not allowed at the beginning or end
public Arifszn\AdvancedValidation\Rules\Username::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\Username;publicfunctionrules(){return ['username' => [newUsername()], ];}
The field under validation must not contain spaces.
public Arifszn\AdvancedValidation\Rules\WithoutSpaces::__construct(string $errorMessage = null)
useArifszn\AdvancedValidation\Rules\WithoutSpaces;publicfunctionrules(){return ['foo' => [newWithoutSpaces()], ];}
If you want to use the rules as strings and use them globally e.g.'foo' => ['phone']
, you can do so by adding them to the boot method of your project'sAppServiceProvider.
<?phpnamespaceApp\Providers;useIlluminate\Support\ServiceProvider;useIlluminate\Support\Facades\Validator;useArifszn\AdvancedValidation\Rules\Phone;class AppServiceProviderextends ServiceProvider{publicfunctionboot() { Validator::extend('phone','Arifszn\AdvancedValidation\Rules\Phone@passes', (newPhone())->message() ); }}
composertest
Any contributors who want to make this project better can make contributions, which will be greatly appreciated. To contribute, clone this repo locally and commit your code to a new branch. Feel free to create an issue or make a pull request.

This package is licensed under theMIT License.
About
Laravel advanced validation rules for real-life scenarios.
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.
Uh oh!
There was an error while loading.Please reload this page.