mwguerra / email-security-manager
A robust Laravel package for managing email verification, password security, and audit trails
Requires
- php: ^8.2
- illuminate/support: ^11.0
Requires (Dev)
- orchestra/testbench: ^9.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpunit/php-code-coverage: ^10.0
- phpunit/phpunit: ^10.0
README
A comprehensive Laravel package for managing email verification and password security with built-in audit trails. This package helps you enforce security best practices and comply with data protection regulations.
Key Features
-
π‘οΈ Enhanced Security
- Force periodic email reverification
- Require regular password changes
- Support for multiple authentication models
- Configurable expiry periods
-
π Complete Audit Trail
- Track all verification events
- Monitor password changes
- Record security-related actions
- Polymorphic relationships for flexibility
-
π Automated Security
- Middleware for automatic checks
- Event-driven audit logging
- Bulk operation support
- Configurable security policies
-
π Compliance Ready
- GDPR compliance support
- LGPD requirements
- CCPA alignment
- Security best practices
Requirements
- PHP 8.2 or higher
- Laravel 11.0 or higher
Installation
composer require mwguerra/email-security-manager
Setup
- Publish the configuration and migrations:
php artisan vendor:publish --provider="MWGuerra\EmailSecurityManager\EmailSecurityManagerServiceProvider"
- Run the migrations:
php artisan migrate
- Add the
HasEmailSecurity
trait to your authenticatable models:
use MWGuerra\EmailSecurityManager\Traits\HasEmailSecurity; class User extends Authenticatable { use HasEmailSecurity; }
Configuration
Basic Configuration
Configure your authenticatable models and security settings in config/email-security.php
:
return [ // Configure authenticatable models 'authenticatable_models' => [ 'default' => \App\Models\User::class, 'admin' => \App\Models\Admin::class, 'customer' => \App\Models\Customer::class, ], // Set expiry periods 'verification_expiry_days' => env('EMAIL_VERIFICATION_EXPIRY_DAYS', 30), 'password_expiry_days' => env('PASSWORD_EXPIRY_DAYS', 90), // Configure redirect route 'redirect_route' => 'verification.notice', // Routes to skip verification 'skip_routes' => [ 'verification.notice', 'verification.verify', 'verification.send', 'password.request', 'password.reset', 'password.update', 'logout' ], ];
Middleware Setup
Add the middleware to your app/Http/Kernel.php
:
protected $routeMiddleware = [ 'verify.email' => \MWGuerra\EmailSecurityManager\Middleware\EmailSecurityMiddleware::class, ];
Usage
Basic Usage
use MWGuerra\EmailSecurityManager\Services\EmailSecurityService; class SecurityController extends Controller { public function __construct( protected EmailSecurityService $securityService ) {} public function requireVerification(User $user) { $this->securityService->requestReverification( authenticatable: $user, reason: 'Security policy update', triggeredBy: auth()->user() ); } }
Multiple Authentication Models
// Using different authenticatable models $this->securityService ->useAuthenticatable(Admin::class) ->requestReverification($admin); // Or specify in the method call $this->securityService->requestReverification( authenticatable: $customer, authenticatableClass: Customer::class );
Bulk Operations
// Force reverification for multiple users $users = User::where('department', 'IT')->get(); $this->securityService->requestReverification( authenticatables: $users, reason: 'Department security update' ); // Request password change for all active admins $admins = Admin::where('is_active', true)->get(); $this->securityService ->useAuthenticatable(Admin::class) ->requestPasswordChange($admins);
Middleware Usage
// In your routes file Route::middleware(['auth', 'verify.email'])->group(function () { // Protected routes requiring valid email verification });
Audit Trail
// Get verification history $user->securityAudits()->latest()->get(); // Get recent verifications $user->securityAudits() ->emailVerifications() ->recent() ->get(); // Get password changes $user->securityAudits() ->passwordChanges() ->get();
Advanced Features
// Custom expiry periods $this->securityService ->setVerificationExpiryDays(60) ->setPasswordExpiryDays(45) ->requestReverification($user); // Get entities requiring action $needsAction = $this->securityService->getAuthenticatablesRequiringAction();
Events
The package automatically listens for and logs these Laravel events:
Illuminate\Auth\Events\Verified
Illuminate\Auth\Events\PasswordReset
Testing
composer test
Security
If you discover any security issues, please email mwguerra@gmail.com instead of using the issue tracker.
Credits
Special Thanks
Special thanks to the Beer and Code Laravel Community for all the support, feedback, and great discussions that helped shape this package. Their dedication to sharing knowledge and fostering collaboration in the Laravel ecosystem is truly inspiring. πΊπ¨βπ»
About
I'm a software engineer specializing in Laravel and PHP development. Visit mwguerra.com to learn more about my work.
License
The MIT License (MIT). Please see License File for more information.