marvinlabs / laravel-luhn
Luhn algorithm for Laravel
                                    Fund package maintenance!
                                                                            
                                                                                                                                        vpratfr
                                                                                    
                                                                
Installs: 351 010
Dependents: 0
Suggesters: 0
Security: 0
Stars: 108
Watchers: 3
Forks: 11
pkg:composer/marvinlabs/laravel-luhn
Requires
- php: >=7.1
- illuminate/support: ^5.5|^6.0|^7.0|^8.0|^9.0|^10.0|^11.0|^12.0
Requires (Dev)
- mockery/mockery: >=0.9
- orchestra/testbench: ^3.6|^4.0|^5.0|^6.0|^7.0|^8.0|^9.0|^10.0
- phpunit/phpunit: ^7.0|^8.0|^9.0|^10.5|^11.5.3
README
marvinlabs/laravel-luhn is a laravel package providing various Laravel utilities to work with the
Luhn algorithm such as:
- a few validation rules
- dependency injection
- facade
The Luhn algorithm is used widely to verify that numbers are valid: credit card numbers, SIREN company codes, etc.
Installation
You can install the package via composer:
composer require marvinlabs/laravel-luhn
If you are using Laravel 5.5, the service provider and facade will automatically be discovered.
On earlier versions, you need to do that manually. You must install the service provider:
// config/app.php 'providers' => [ ... MarvinLabs\Luhn\LuhnServiceProvider::class ];
And optionally register an alias for the facade.
// config/app.php 'aliases' => [ ... 'Luhn' => MarvinLabs\Luhn\Facades\Luhn::class, ];
Usage
Algorithm implementation
The package provides an implementation to the algorithm interface defined in \MarvinLabs\Luhn\Contracts\LuhnAlgorithm.
The contract provides 3 public methods to:
- Check if an input string is valid according to the Luhn algorithm
- Compute the check digit to append to a string in order to make it valid
- Compute the checksum according to the Luhn algorithm
Facade
A facade is provided to access the Luhn algorithm implementation.
Luhn::isValid('1234'); Luhn::computeCheckDigit('1234'); Luhn::computeCheckSum('1234');
Dependency injection
You can get an implementation of the Luhn algorithm at any time using the Laravel container.
$luhn = app(\MarvinLabs\Luhn\Contracts\LuhnAlgorithm::class); // Using the interface $luhn = app('luhn'); // This shortcut works too, up to you ;)
Validation
The package provides custom rules to validate a string.
$validator = Validator::make($data, [ 'number1' => 'luhn', // Using shorthand notation 'number2' => new LuhnRule(), // Using custom rule class ]);
Version history
See the dedicated change log
Credits
- Got some ideas from nekman/luhn-algorithm
License
The MIT License (MIT). Please see License File for more information.