anexia / laravel-encryption
Encryption and decryption for eloquent models
Installs: 4 054
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 0
Open Issues: 0
This package is auto-updated.
Last update: 2025-01-17 22:05:39 UTC
README
A Laravel package that adds database encryption support to eloquent models.
1. Installation and configuration
1. Install via composer
Install the module via composer, therefore adapt the require part of your composer.json:
"require": {
"anexia/laravel-encryption": "1.0.0"
}
Now run
composer update [-o]
to add the packages source code to your /vendor directory and update the autoloading.
2. Add service provider to app config
'providers' => [
/*
* Package Service Providers...
*/
\Anexia\LaravelEncryption\DatabaseEncryptionServiceProvider::class,
]
3. Add cipher to database config
Currently only Postgres and PGP is supported.
'pgsql' => [
'driver' => 'pgsql',
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '5432'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'charset' => 'utf8',
'prefix' => '',
'schema' => 'public',
'sslmode' => 'prefer',
'cipher' => 'pgp'
],
2. Usage
2.1 Models
Add the DatabaseEncryption Trait to your eloquent model.
<?php
namespace App;
use Anexia\LaravelEncryption\DatabaseEncryption;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable, DatabaseEncryption;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
/**
* @return array
*/
protected static function getEncryptedFields()
{
return [
'password'
];
}
/**
* @return string
*/
protected function getEncryptKey()
{
return 'thisismysupersecretencryptionkey';
}
}
2.2 Updates
Just call the save() method on the model. Fields will be encrypted automatically.
2.3 Queries
Per default the encrypted properties will be replaced by their corresponding "_encrypted" value.
$user = User::find(1);
The above query will have the property "password_encrypted" and no "password" property.
2.3.1 Decrypted properties
Use the macro withDecryptKey
for automatic decryption.
2.3.1 'select *' queries
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1);
In the example above $user will have two properties:
- password: the decrypted password
- password_encrypted: the encrypted value from the database
- id
- name
- remember_token
2.3.2 Select certain fields
$user = User::->find(1, ['id']);
or
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1, ['id']);
In both examples above $user will only have one property:
- id
$user = User::->find(1, ['id', 'password']);
In the example above $user will only have two properties:
- id
- password_encrypted: the encrypted value from the database
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1, ['id', 'password']);
In the example above $user will only have three properties:
- id
- password: the decrypted password
- password_encrypted: the encrypted value from the database
2.3.3 Check for certain decoded values
Use the macro whereDecripted
to run a "where field = value" query on an encrypted property.
$user = User::whereDecrypted('password', 'thisIsTheWantedPassword', 'thisismysupersecretencryptionkey')->first();
In the example above $user will be the first entry with the (decrypted) password 'thisIsTheWantedPassword'.