Since the original package does not seem to be maintained any more, this is an adaptation of the beyondcode/laravel-credentials
package. See here how to migrate.
The rto-websites/laravel-credentials
package allows you to store all your secret credentials in an encrypted file and put that file into version control instead of
having to add multiple credentials into your .env
file in your production environment.
There are a couple of benefits of using encrypted credentials instead of environment keys:
- Your credentials are encrypted. No one will be able to read your credentials without the key.
- The encrypted credentials are saved in your repository. You'll have a history of the changes and who made them.
- You can deploy credentials together with your code.
- All secrets are in one location. Instead of managing multiple environment variables, everything is in one file.
Here's how you can access your stored credentials. In this example we're retrieving the decrypted credential for the key api-password
:
$credential = credentials('api-password');
You can also specify a fallback value to be used if the credential for the specified key cannot be decrypted:
$credential = credentials('my-production-token', 'my-fallback-value');
With the built-in edit command, you can easily edit your existing credentials. They will be automatically encrypted after saving your changes.
php artisan credentials:edit
You can install the package via composer:
composer require rto-websites/laravel-credentials
The package will automatically register itself.
You can optionally publish the configuration with:
php artisan vendor:publish --provider="RtoWebsites\Credentials\CredentialsServiceProvider" --tag="config"
This is the content of the published config file:
<?php
return [
/*
* Defines the file that will be used to store and retrieve the credentials.
*/
'file' => config_path('credentials.php.enc'),
/**
*
*/
'editor' => env('CREDENTIALS_EDITOR', 'vi'),
/*
* Defines the key that will be used to encrypt / decrypt the credentials.
* The default is your application key. Be sure to keep this key secret!
*/
'key' => config('app.key'),
'cipher' => config('app.cipher'),
];
If you are about to move over from the original package to this one you may need to make some minor adjustments to your project.
In most cases all you have to do are the following three steps:
- run
composer require rto-websites/laravel-credentials
- remove
beyondcode/laravel-credentials
from youcomposer.json
- run
composer update beyondcode/laravel-credentials
If you published the config file you will need to add this line to your config/credentials.php
:
'editor' => env('CREDENTIALS_EDITOR', 'vi'),
If you are not using the package auto-discovery and registering the service provider by hand
you will need make a small adjustment to your registration since the service provider's namespace
has changed.
Go to your config/app.php
and replace
BeyondCode\Credentials\CredentialsServiceProvider::class
with RtoWebsites\Credentials\CredentialsServiceProvider::class
.
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.