aliarefavin / avinauthpackage
Custom authentication system for Laravel
Requires
- php: ^8.0|^8.1|^8.2|^8.3
- illuminate/container: ~8.0|~9.0|~10.0|~11.0|~12.0
- illuminate/database: ~8.0|~9.0|~10.0|~11.0|~12.0
- illuminate/pagination: ~8.0|~9.0|~10.0|~11.0|~12.0
- illuminate/support: ~10.0|~11.0|~12.0
Requires (Dev)
- mockery/mockery: 1.4.x-dev|1.4.2|1.5.1|^1.6
- orchestra/testbench: 5.*|^6.0|^6.6.0|^7.0.0|^8.0.0|v9.0.0
- phpstan/phpstan: ^1.8
- phpunit/phpunit: 8.3|8.5|9.3|^9.5|10.5.5
README
A lightweight and customizable Laravel package for verifying mobile/email using one-time passwords (OTP) on Redis.
🔐 Secure & Simple • 📦 Easily Integrates with Laravel • ✉️ SMS/Email ReadyVerify your user mobile/email with a one-time password using both Redis
and Mysql Database
.
Installation
You can install the package via composer:
composer require aliarefavin/avinauthpackage
php artisan migrate
Publish config file using:
php artisan vendor:publish --tag=avinauth-config
Configuration
Configuration is located at config/avinauthconfig.php. Here's what you can adjust:
connection
: you can set your connection to redis or database as you wish
Note: The default connection is
redis
and we recommend to keep it that way specially for large scale projects. If you are not using redis on your project and want to usedatabase
connection make sure to runphp artisan migrate
after installing the package.
code
: OTP code generation rules.
resend_delay
: Time delay (in seconds) before allowing another resend.
max_attemps
: Maximum verification attempts allowed.
max_resends
: Total resends allowed in one hour.
Usage
Send code to the user
use AliArefAvin\AvinAuthPackage\Services\AvinAuthService; $result = (new AvinAuthService())->sendOTP($mobile, $request, $class); // Check if the request was successful if ($result['success'] && !array_key_exists('seconds', $result)) { // If the request was successful and the 'seconds' key is not present in the result, // set the 'seconds' key to the configured resend delay time $result['seconds'] = config('avinauthconfig.resend_delay'); } // Return the result array, which contains information about the request status return $result;
$class
is your class that implements AliArefAvin\AvinAuthPackage\Contracts\AvinAuthInterface
this $class
contains your custom function named send
that you use to send the code for users (email|sms)
for exmaple your $class
will be new AuthenticateService()
namespace App\Services\Auth; use AliArefAvin\AvinAuthPackage\Contracts\AvinAuthInterface; class AuthenticateService implements AvinAuthInterface { public function send(string $receiver, string $code) { try { $Message = 'کد ورود شما:' . PHP_EOL . "code: $code" . PHP_EOL ; // If the receiver is not in the list of test numbers, send the SMS notification Notification::route(NotifyType::TSMS, []) // Set the notification route for SMS ->notify( new SendSmsNotification( // Create a new SMS notification $receiver, // The receiver's mobile number $Message // The message content ) ); return true; // Return true if the message was sent successfully } catch (Exception $e) { // If there is an exception (e.g., sending fails), return false return false; // Indicate that sending the code failed } } }
Verify
You can verify code with request validation.
$request->validate([ 'mobile' => ['required'], 'code' => 'required|avin_verify:mobile', ]);
mobile
is your receiver which in this case is mobile.
Note: You can verify a code just once. so if you need to check code in two different requests then you should use something like the session to handle that.
Credits & Inspiration 🙌
- This package is heavily inspired by the excellent work of the Sanjab Verify package. Special thanks to the Sanjab team for their elegant design and contribution to the Laravel ecosystem.
Contributing 🛠️
Contributions are welcome!
- Fork the Project
- Create a new branch
- Add your changes
- Submit a pull request 🙌
License 📝
This project is open-sourced under the MIT license.