striderwhite / encryptable
A Laravel trait for encrypting and decrypting model attributes using MySQL AES encryption.
Requires
- php: >=8.0
- illuminate/support: ^9.0|^10.0|^11.0
This package is not auto-updated.
Last update: 2025-06-22 17:36:08 UTC
README
A Laravel trait for automatically encrypting and decrypting model attributes using MySQL AES encryption.
✨ Features:
- Models attributes that are marked as
encryptable
will automatically be AES encrypted upon persisting to the database. - Attributes are automatically decrypted upon retrieval via Eloquent model attributes or when serializing to JSON/array.
- Provides query builder helper methods for searching on the fields using Eloquent, supports both full and partial searching.
🚀 Installation
Install the package via Composer:
composer require striderwhite/encryptable
📖 Usage
- Database Setup: Ensure the database column you wish to encrypt is of
binary
datatype. - Add the Trait: Add the
Encryptable
trait to your Eloquent model. - Define Encryptable Fields: Define an
$encryptable
property in your model with the list of attributes to encrypt.
use StriderWhite\Encryptable; class YourModel extends Model { use Encryptable; protected $encryptable = ['field1', 'field2']; }
- 💾 Persisting and Retrieving Data
Using the Encryptable
trait, you can persist and retrieve data just like normal Eloquent attributes. The encryption and decryption process is handled automatically.
Example
use App\Models\YourModel; // Persisting data $model = new YourModel(); $model->field1 = 'Sensitive Data'; $model->field2 = 'Another Secret'; $model->save(); // Retrieving data $retrievedModel = YourModel::find($model->id); echo $retrievedModel->field1; // Outputs: Sensitive Data echo $retrievedModel->field2; // Outputs: Another Secret
🔎 Searching Encrypted Fields
The package provides two query scopes for searching encrypted fields:
scopeWhereEncrypted
Use this scope to search for an exact match on an encrypted field:
YourModel::whereEncrypted('field1', 'value')->get();
scopeWhereEncryptedLike
Use this scope to perform a partial search on an encrypted field:
YourModel::whereEncryptedLike('field1', 'value')->get();
🙏 Credits
Developed and maintained by Strider White. If you find this package helpful, feel free to ⭐ the repository or contribute!
📜 License
This package is open-sourced software licensed under the MIT license.