polokij / laravel-vault-env
Hashicorp Vault client for Laravel with possibility set the env variables from Vault secret dynamically
Installs: 2 370
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 0
Open Issues: 1
Requires
- php: >=8.1
- laravel/framework: ^9.0 | ^10.0 | ^11.0
Requires (Dev)
- barryvdh/laravel-ide-helper: ^2.13
- phpunit/phpunit: ^10.4
This package is auto-updated.
Last update: 2025-03-29 19:17:51 UTC
README
This package provide the base features for Hashicorp Vault API.
Motivation
Developing my multi-tenant application using Laravel I've faced with lacking of the package which could fetch the env variables from vault and apply it on bootstrapping the application. Here it bref implementation of the required features:
- Vault API Client + Service + Facade
- artisan command to unseal the vault
- artisan command for create the secret engine
- Laravel bootstraper which apply the env variables fetched from Vault
Requirements
- Laravel 9+
- PHP 8+
Installation
Adding composer package
composer require polokij/laravel-vault-env
Setting up the .env variables
VAULT_ADDR=http://vault:8200
# Required is no VAULT_ADDR specified
VAULT_HOST=vault
VAULT_PORT=8200
VAULT_SCHEME=https
# The storage engine thich will be used by default kv2 or secrets, or whatewhere
VAULT_DEFAULT_ENGINE=kv2
# The prefix will be added to each key on put/get requests
VAULT_KEY_PREFIX=TenantRootPath
VAULT_TOKEN=
Publishing the config
php artisan vendor:publish --provider="LaravelVault\VaultServiceProvider"
Usage
- Unseal Vault using json
php artisan vault:unseal -f secret/file.json
- Unseal Vault using key as command arguments
php artisan vault:unseal $key
- Check the seal status
php artisan vault:unseal -s
- Create new secret storage
php artisan vault:storage create new_storage_name
- Access to Secrets
Vault::secret('my-secret', ['foo' => 'bar']); // push the secret to Vault Vault::secret('my-secret'); // pull the secret from Vault - return ['foo' => 'bar'] Vault::instance()->sys->get('some/not/implemented/endpoints'); // call the other endpoints on sys group Vault::instance()->auth->get('some/not/implemented/endpoints'); // call the other endpoints on auth group
Bootstrap the application with dynamic env variables
Example for Multi-tenant application:
bootstrap/app.php
$app = new Illuminate\Foundation\Application( $_ENV['APP_BASE_PATH'] ?? dirname(__DIR__) ); $app->afterLoadingEnvironment(function () use ($app) { // checking is the feature enabled if (env('VAULT_LOAD_ENV', false)) { try { $tenantId = env('TENANT_ID'); // resolving tenant_id by headers - make sure proxy override this header for security reason if (!$tenantId) { $headers = collect(getallheaders()); $tenantIdHeader = env('TENANT_ID_HEADER', 'tenant-id'); $tenantId = $headers ->first(fn($value, $key) => $key === $tenantIdHeader || strtolower($key) === $tenantIdHeader); } if (!$tenantId) { throw new Exception('Missed Tenant_id '); } $envRepository = Env::getRepository(); $vaultDefaultPrefix = $envRepository->get('VAULT_KEY_PREFIX'); $envRepository->set('VAULT_KEY_PREFIX', $vaultDefaultPrefix.'/'.$tenantId); (new LoadEnvironmentVariablesVault)->bootstrap($app); } catch (Throwable $e) { // preparing the logs for exception $app->instance('config', $config = new Repository([])); throw $e; } } });
Alternative way
To enable this feature override the array of bootstrappers on app/Console/Kernel.php and app/Http/Kernel.php files app/Console/Kernel.php
use LaravelVault\LoadEnvironmentVariablesVault; class Kernel extends ConsoleKernel { /** * The bootstrap classes for the application. * * @var string[] */ protected $bootstrappers = [ LoadEnvironmentVariables::class, LoadEnvironmentVariablesVault::class, // <-- added custom bootstrapper LoadConfiguration::class, HandleExceptions::class, RegisterFacades::class, SetRequestForConsole::class, RegisterProviders::class, BootProviders::class, ];
app/Http/Kernel.php
use LaravelVault\LoadEnvironmentVariablesVault; class Kernel extends HttpKernel { /** * The bootstrap classes for the application. * * @var string[] */ protected $bootstrappers = [ LoadEnvironmentVariables::class, LoadEnvironmentVariablesVault::class, LoadConfiguration::class, HandleExceptions::class, RegisterFacades::class, RegisterProviders::class, BootProviders::class, ];
Performance
Under investigation ))
TODO
- Tests implementation
- Refactor the VaultClient to separate the methods by entrypoints to simplify the project development
License
The MIT License (MIT). Please see License File for more information.