sierratecnologia / crypto
Cryptography tools for Laravel and Lumen
Fund package maintenance!
ricasolucoes
ricasolucoes.com.br/open-source/support-us
Requires
- php: >=5.6.4
- illuminate/support: 5.*
- ramsey/uuid: >=3.8
Requires (Dev)
- mikey179/vfsstream: >=1.6
- mockery/mockery: >=0.9.4
- orchestra/testbench: >=3.3
- phpunit/phpunit: >=5.0
This package is auto-updated.
Last update: 2024-09-16 05:12:16 UTC
README
Crypto - Powerful and elegant cryptography tools for Laravel and Lumen
The Cryptograpy toolset Crypto provides a collection of methods for handy, encryption, decryption, uuid generating, app key generating and more.
Author(s):
- Matt Lantz (@mattylantz, mattlantz at gmail dot com)
Requirements
- PHP 5.6+
- OpenSSL
- Laravel 5.3+ or Lumen
- For Lumen you must enable Facades:
$app->withFacades()
Installation
Start a new Laravel project:
composer create-project laravel/laravel your-project-name
Then run the following to add Crypto
composer require "sierratecnologia/crypto"
Documentation
https://docs.sierratecnologia.ca/others/crypto
License
Crypto is open-sourced software licensed under the MIT license
Bug Reporting and Feature Requests
Please add as many details as possible regarding submission of issues and feature requests
Disclaimer
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Laravel Encryptable Trait
Provides a trait to decrypt or encrypt values in a Laravel model.
Usage
Add the trait to your model, define the $encrypted
array and fields in it will be encrypted and decrypted on the fly by default.
namespace App; use Cheezykins\LaravelEncryptable\Traits\Encryptable; use Illuminate\Database\Eloquent\Model; class MyModel extends Model { use Encryptable; protected $encrypted = [ 'email' ]; }
Then in usage:
$model = new MyModel(); $model->name = 'Chris'; $model->email = 'chris@test.com'; $model->save();
The email field in the database will now be the encrypted value.
eyJpdiI6IkRZS0lOUlwvR29MbU4zN1diYzl2ZCtnPT0iLCJ2YWx1ZSI6IldEYzVUajlUcDdvVHE0M0kxdForNlE9PSIsIm1hYyI6ImY1MzQ2ZWYwNTNkZDI2YTY2MDgyMmVjZmU3MmI0MGU0NTNmMmU4NWE4OGFmYzZhYTJlYzczMWU1YTdmNzNjYjQifQ==
When retrieved, the data will be automatically decrypted for you.
$model = MyModel::find(1); echo $model->email;
> "chris@test.com"
Same for other ways of accessing model data.
$model = MyModel::find(1); return response()->json($model->toArray());
{ "id": 1, "name": "Chris", "email": "chris@test.com" }
WARNING
The encrypted value is stored based on your Laravel APP_KEY using the algorithm defined in your config/app.php cipher setting. If your application key is changed or lost there is no way to retrieve the data.
Installation
require the project and use it. There is no service provider as it is not needed.
composer require cheezykins/laravel-encryptable