Download the PHP package sergkulich/laravel-key-rotate without Composer
On this page you can find all versions of the php package sergkulich/laravel-key-rotate. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download sergkulich/laravel-key-rotate
More information about sergkulich/laravel-key-rotate
Files in sergkulich/laravel-key-rotate
Package laravel-key-rotate
Short Description A Laravel package to rotate app key and re-encrypt data stored in eloquent models.
License MIT
Informations about the package laravel-key-rotate
Laravel Key Rotate
Laravel Key Rotate package allows automatically copy current APP_KEY
and update APP_PREVIOUS_KEYS
with it,
After that it will call key:generate
artisan command to generate new APP_KEY
, and, optionally, update all your
Eloquent Models encrypted fields.
The Command available only then app()->runningInConsole()
as it may take a while to update Models.
[!WARNING]
The package is in beta. Use with caution.
Never run in production without previous local testing and fresh
.env
copy andDB
dump.
Table of contents
- Installation
- Usage
- Dive Deeper
- The Event
- The Listener
- Models
- Casts
- Tests
- Changelog
- Contributing
- License
Installation
Install the package via composer:
Usage
Run artisan command to rotate the key.
Use --force
option to run the command in production to avoid confirmation prompt.
Dive deeper
Quick example of extended usage.
You need to register KeyRotate::useListener()
only if you want your model encrypted fields to be re-encrypted.
The Event
The key:rotate
command fires an event after successful completion.
The Event Class
The package provides helper to get the event class name to subscribe listeners to it.
The Listener
The package provides default listener that update encrypted models fields after key rotation.
The Listener Class
The package provides helper to get the listener class name in case you need it.
Get Instance of the Listener
Simply subscribe the listener to the event in your app service provider boot method.
Or get singleton instance of the listener and call it anywhere in your code.
Models
The package discovers all Models in your app()->path()
folder with app()->getNamespace()
namespace.
But only then app()->runningInConsole()
, so no unnecessary file scans happen during http requests.
Discover Models
It's possible to discover Models with defined namespace that are not located in your app()->path()
but in a custom
directory.
Include Models
It's possible to include Model to be updated with the listener without scanning directories.
Exclude Models
It's possible to exclude Model from being updated with the listener.
Exclude Model Fields
It's possible to exclude some Model fields from being updated with the listener.
Casts
By default, the listener takes care of Laravel's predefined encrypted
Casts.
At your disposal there are helpers to reduce the above list or extend it with your custom cast that implements
Castable
, CastsAttributes
, or CastsInboundAttributes
interfaces.
Tests
Run the entire test suite:
Changelog
Please see CHANGELOG for more information.
Contributing
Please see CONTRIBUTING for more information.
License
The MIT License (MIT). Please see LICENSE for more information.