bnomei / kirby3-dotenv
Kirby Plugin for environment variables from .env
Installs: 37 678
Dependents: 1
Suggesters: 4
Security: 0
Stars: 40
Watchers: 2
Forks: 2
Open Issues: 1
Type:kirby-plugin
pkg:composer/bnomei/kirby3-dotenv
Requires
- php: >=8.2
- getkirby/composer-installer: ^1.1
- vlucas/phpdotenv: ^5.3
Requires (Dev)
- getkirby/cli: ^1.5
- getkirby/cms: ^5.0.0-alpha.4
- larastan/larastan: ^v3.0.0
- laravel/pint: ^1.13
- pestphp/pest: ^v3.5.1
- spatie/ray: ^1.39
Suggests
- bnomei/kirby3-janitor: Use a Panel Button or PHP code to clear the cache
- bnomei/kirby3-lapse: For faster and automatic caching based on modification of Kirby Objects
- bnomei/kirby3-security-headers: CPS headers to make the the web a saver place. Sensible defaults with zero configuration.
README
Kirby Plugin for environment variables from .env files
Installation
- unzip master.zip as folder site/plugins/kirby3-dotenvor
- git submodule add https://github.com/bnomei/kirby3-dotenv.git site/plugins/kirby3-dotenvor
- composer require bnomei/kirby3-dotenv
Usage
Create a .env file in the root of your Kirby installation. Within your Kirby project you can access the environment variables using various PHP helper functions.
in production or with default environment
Based on an environment like
- /site/config/config.phpKirby configuration file and given a
- /.envfile.
/.env
APP_MODE=production APP_DEBUG=false ALGOLIA_APIKEY=12d7331a21d8a28b3069c49830f463e833e30f6d KIRBY_API_USER=bnomei KIRBY_API_PW=52d3a0edcc78be6c5645fdb7568f94d3d83d1c2a
<?php echo $_ENV['APP_MODE']; // production echo env('APP_DEBUG'); // false // or echo $page->getenv('ALGOLIA_APIKEY'); // 12d7331... echo $page->env('ALGOLIA_APIKEY'); // 12d7331... echo site()->getenv('ALGOLIA_APIKEY'); // 12d7331... echo site()->env('ALGOLIA_APIKEY'); // 12d7331...
on local or staging test server
You can also create files to have different settings for different environments. The plugin will try to automatically load the correct file based on the environment.
Based on an environment like
- http://dotenv.test matching a
- /site/config/config.dotenv.test.phpKirby configuration file and given a
- /.env.dotenv.testfile.
/.env.dotenv.test
APP_MODE=staging APP_DEBUG=true ALGOLIA_APIKEY=950306d052ec893b467f2ca088daf2964b9f9530 KIRBY_API_USER=notBnomei KIRBY_API_PW=37e30ad867ff3a427317dcd1852abbd692b39ffc
<?php echo $_ENV['APP_MODE']; // staging echo env('APP_DEBUG'); // true // ...
Default values
In case you want to provide a default value as fallback in case the environment variable is not set you can do that with the 2nd parameter in each helper function. Thanks for your PR @teichsta.
<?php // `true` as default value echo env('ALGOLIA_ENABLED', true);
Usage in Config files might require a manual load
The environment variables set by your hosting service are available in your PHP scripts by default using the $_ENV super-global and the getenv() function. They are injected into the PHP environment by the web server.
But the values from the .env files are NOT available in the same way. They need to be loaded manually. The Dotenv plugin will load these on it's first usage. But the plugin can only do so automatically once it has been loaded itself which is after the config files have been parsed by Kirby.
Using Callbacks or the Ready Option
Where possible you should use the callback option to provide a function that returns the value you need. Once the callback is called the .env file will already have been loaded and the value will be available. Not all options support callbacks though.
/site/config/config.php
<?php return [ // does not support callbacks // 'debug' => false, // some plugins support callbacks for sensitive data options 'bnomei.seobility.apikey' => function() { return env('SEOBILITY_APIKEY'); }, // alternatively you can use the `ready` option // https://getkirby.com/docs/reference/system/options/ready 'ready' => function() { return [ 'debug' => env('APP_DEBUG', false), 'email' => [ 'transport' => [ 'type' => 'smtp', 'host' => 'smtp.postmarkapp.com', 'port' => 587, 'security' => true, 'auth' => true, 'username' => env('POSTMARK_USERNAME'), 'password' => env('POSTMARK_PASSWORD'), ], ], ]; } ];
Manually load the .env file in the config file
If you still decide you need to use the values from the .env files in the config files of Kirby directly, you can manually initialize the loading of these like so:
/site/config/config.php
<?php require_once __DIR__ . '/../plugins/kirby3-dotenv/global.php'; loadenv(); return [ 'debug' => env('APP_DEBUG', false), //... ];
You can provide a custom options as an array to that function if you want to force loading a specific directory or file.
Other Environment Variables Sources
If you set environment variables in your server configuration these will be available as well.
Warning
This plugin will load environment variables from .env files and potentially overwrite existing environment
variables.
In the CLI
When running Kirby commands in the CLI make sure you prefix the command with the environment variable for the HOST you want to use.
env KIRBY_HOST=dotenv.test kirby my:command
Similar Plugins
Settings
| bnomei.dotenv. | Default | Description | 
|---|---|---|
| dir | callback | returning kirby()->roots()->index().When installing Kirby 3 with Composer use afunction() { return realpath(kirby()->roots()->index() . '/../'); } | 
| file | .env | |
| environment | callback | auto-detection for the current environment | 
| required | callback or [] | You can define required variables in the settings using an array. If any of these is missing a RuntimeExceptionwill be thrown. | 
| setup | callback | perform additional tasks on raw dotenv class instance | 
Dependencies
Disclaimer
This plugin is provided "as is" with no guarantee. Use it at your own risk and always test it yourself before using it in a production environment. If you find any issues, please create a new issue.
License
It is discouraged to use this plugin in any project that promotes racism, sexism, homophobia, animal abuse, violence or any other form of hate speech.
Credits
based on K2 version of