2019-11-18 17:58:33 +13:00
---
title: Environment Management
summary: How to configure your server environment for Silverstripe CMS
---
2011-02-07 19:48:44 +13:00
# Environment management
2017-01-30 15:34:55 +00:00
As part of website development and hosting it is natural for our sites to be hosted on several different environments.
2019-02-27 14:50:49 +13:00
These can be our laptops for local development, a testing server for customers to test changes on, or a production
2017-01-30 15:34:55 +00:00
server.
For each of these environments we may require slightly different configurations for our servers. This could be our debug
level, caching backends, or - of course - sensitive information such as database credentials.
2021-06-22 09:41:48 +01:00
To manage environment variables, as well as other server globals, the [api:SilverStripe\Core\Environment] class provides
a set of APIs and helpers.
2017-01-30 15:34:55 +00:00
## Security considerations
2019-02-27 14:50:49 +13:00
Sensitive credentials should not be stored in a VCS or project code and should only be stored on the environment in
2017-01-30 15:34:55 +00:00
question. When using live environments the use of `.env` files is discouraged and instead one should use "first class"
environment variables.
If you do use a `.env` file on your servers, you must ensure that external access to `.env` files is blocked by the
webserver.
2021-08-22 00:25:24 -07:00
## Managing environment variables with .env files
2017-01-30 15:34:55 +00:00
2021-06-22 09:41:48 +01:00
By default a file named `.env` must be placed in your project root (ie: the same folder as your `composer.json` ) or the
parent directory. If this file exists, it will be automatically loaded by the framework and the environment variables
will be set. An example `.env` file is included in the default installer named `.env.example` .
2017-11-24 10:56:57 +00:00
2021-06-22 09:41:48 +01:00
**Note:** The file must be named exactly `.env` and not any variation (such as `mysite.env` or `.env.mysite` ) or it will
not be detected automatically. If you wish to load environment variables from a file with a different name, you will
need to do so manually. See the [Including an extra `.env` file ](#including-an-extra-env-file ) section below for more
information.
2017-01-30 15:34:55 +00:00
## Managing environment variables with Apache
2019-02-27 14:50:49 +13:00
You can set "real" environment variables using Apache. Please
2021-06-22 09:41:48 +01:00
[see the Apache docs for more information ](https://httpd.apache.org/docs/current/env.html ).
2017-01-30 15:34:55 +00:00
## How to access the environment variables
2021-06-22 09:41:48 +01:00
Accessing the environment variables should be done via the `Environment::getEnv()` method.
2017-01-30 15:34:55 +00:00
```php
2017-10-16 16:43:12 +13:00
use SilverStripe\Core\Environment;
Environment::getEnv('SS_DATABASE_CLASS');
```
Individual settings can be assigned via `Environment::setEnv()` or `Environment::putEnv()` methods.
```php
use SilverStripe\Core\Environment;
Environment::setEnv('API_KEY', 'AABBCCDDEEFF012345');
2017-01-30 15:34:55 +00:00
```
2018-11-26 08:42:10 +13:00
### Using environment variables in config
2022-05-12 17:12:14 +12:00
To use environment variables in `.yaml` configs you can reference them using backticks. You can have multiple
environment variables within a single value, though the overall value must start and end with backticks.
2018-11-26 08:42:10 +13:00
```yaml
SilverStripe\Core\Injector\Injector:
2021-06-22 09:41:48 +01:00
MyServiceClass:
properties:
2022-05-12 17:12:14 +12:00
MyProperty: '`ENV_VAR_ONE` '
MultiValueProperty: '`ENV_VAR_ONE` :`ENV_VAR_TWO` '
ThisWillNotSubstitute: 'lorem `REGULAR_TEXT` ipsum'
2018-11-26 08:42:10 +13:00
```
2019-11-18 17:58:33 +13:00
[info]
2019-11-19 13:53:43 +13:00
Environment variables cannot be used outside of Injector config as of version 4.2.
2019-11-18 17:58:33 +13:00
[/info]
2018-11-26 09:17:48 +13:00
2021-08-22 00:25:24 -07:00
## Including an extra .env file
2017-01-30 15:34:55 +00:00
Sometimes it may be useful to include an extra `.env` file - on a shared local development environment where all
2018-06-25 10:39:53 +12:00
database credentials could be the same. To do this, you can add this snippet to your `app/_config.php` file:
2017-01-30 15:34:55 +00:00
2021-06-22 09:41:48 +01:00
Note that by default variables cannot be overloaded from this file; Existing values will be preferred over values in
this file.
2017-10-16 16:43:12 +13:00
2017-01-30 15:34:55 +00:00
```php
2017-10-16 16:43:12 +13:00
use SilverStripe\Core\EnvironmentLoader;
2018-06-25 10:39:53 +12:00
$env = BASE_PATH . '/app/.env';
2017-10-16 16:43:12 +13:00
$loader = new EnvironmentLoader();
$loader->loadFile($env);
2017-01-30 15:34:55 +00:00
```
## Core environment variables
2021-06-22 09:41:48 +01:00
Silverstripe core environment variables are listed here, though you're free to define any you need for your application.
2013-03-21 19:48:54 +01:00
2013-04-03 15:29:27 +13:00
| Name | Description |
| ---- | ----------- |
2019-07-01 10:37:19 +12:00
| `SS_DATABASE_CLASS` | The database class to use, MySQLPDODatabase, MySQLDatabase, MSSQLDatabase, etc. defaults to MySQLDatabase.|
2015-06-09 16:53:20 +12:00
| `SS_DATABASE_SERVER` | The database server to use, defaulting to localhost.|
| `SS_DATABASE_USERNAME` | The database username (mandatory).|
| `SS_DATABASE_PASSWORD` | The database password (mandatory).|
| `SS_DATABASE_PORT` | The database port.|
2013-03-21 19:48:54 +01:00
| `SS_DATABASE_SUFFIX` | A suffix to add to the database name.|
| `SS_DATABASE_PREFIX` | A prefix to add to the database name.|
| `SS_DATABASE_TIMEZONE` | Set the database timezone to something other than the system timezone.
2013-04-22 13:33:19 +02:00
| `SS_DATABASE_NAME` | Set the database name. Assumes the `$database` global variable in your config is missing or empty. |
2021-06-22 09:41:48 +01:00
| `SS_DATABASE_CHOOSE_NAME` | Boolean/Int. If defined, then the system will choose a default database name for you if one isn't give in the $database variable. The database name will be "SS_" followed by the name of the folder into which you have installed Silverstripe. If this is enabled, it means that the phpinstaller will work out of the box without the installer needing to alter any files. This helps prevent accidental changes to the environment. If `SS_DATABASE_CHOOSE_NAME` is an integer greater than one, then an ancestor folder will be used for the database name. This is handy for a site that's hosted from /sites/examplesite/www or /buildbot/allmodules-2.3/build. If it's 2, the parent folder will be chosen; if it's 3 the grandparent, and so on.|
2015-06-10 10:27:54 +12:00
| `SS_DEPRECATION_ENABLED` | Enable deprecation notices for this environment.|
2013-03-21 19:48:54 +01:00
| `SS_ENVIRONMENT_TYPE` | The environment type: dev, test or live.|
2014-10-06 16:01:33 +13:00
| `SS_DEFAULT_ADMIN_USERNAME` | The username of the default admin. This is a user with administrative privileges.|
| `SS_DEFAULT_ADMIN_PASSWORD` | The password of the default admin. This will not be stored in the database.|
2021-06-22 09:41:48 +01:00
| `SS_USE_BASIC_AUTH` | Baseline protection for requests handled by Silverstripe. Usually requires additional security measures for comprehensive protection. See [Environment Types ](/developer_guides/debugging/environment_types ) for caveats.|
2015-06-09 16:53:20 +12:00
| `SS_SEND_ALL_EMAILS_TO` | If you define this constant, all emails will be redirected to this address.|
| `SS_SEND_ALL_EMAILS_FROM` | If you define this constant, all emails will be sent from this address.|
| `SS_ERROR_LOG` | Relative path to the log file. |
2018-10-04 04:34:16 +02:00
| `SS_PROTECTED_ASSETS_PATH` | Path to secured assets - defaults to ASSETS_PATH/.protected |
2017-01-30 15:34:55 +00:00
| `SS_DATABASE_MEMORY` | Used for SQLite3 DBs |
2017-04-13 13:33:29 +12:00
| `SS_TRUSTED_PROXY_IPS` | IP address or CIDR range to trust proxy headers from. If left blank no proxy headers are trusted. Can be set to 'none' (trust none) or '*' (trust all) |
2017-01-30 15:34:55 +00:00
| `SS_ALLOWED_HOSTS` | A comma deliminated list of hostnames the site is allowed to respond to |
2017-03-14 15:20:51 +13:00
| `SS_MANIFESTCACHE` | The manifest cache to use (defaults to file based caching). Must be a CacheInterface or CacheFactory class name |
2017-01-30 15:34:55 +00:00
| `SS_IGNORE_DOT_ENV` | If set the .env file will be ignored. This is good for live to mitigate any performance implications of loading the .env file |
2017-04-13 13:33:29 +12:00
| `SS_BASE_URL` | The url to use when it isn't determinable by other means (eg: for CLI commands) |
2017-08-07 16:26:37 +08:00
| `SS_DATABASE_SSL_KEY` | Absolute path to SSL key file |
| `SS_DATABASE_SSL_CERT` | Absolute path to SSL certificate file |
| `SS_DATABASE_SSL_CA` | Absolute path to SSL Certificate Authority bundle file |
| `SS_DATABASE_SSL_CIPHER` | Optional setting for custom SSL cipher |
2019-02-27 14:50:49 +13:00
| `SS_FLUSH_ON_DEPLOY` | Try to detect deployments through file system modifications and flush on the first request after every deploy. Does not run "dev/build", but only "flush". Possible values are `true` (check for a framework PHP file modification time), `false` (no checks, skip deploy detection) or a path to a specific file or folder to be checked. See [DeployFlushDiscoverer ](api:SilverStripe\Core\Startup\DeployFlushDiscoverer ) for more details.< br />< br /> False by default. |
2021-11-15 20:35:28 +00:00
| `SS_TEMP_PATH` | File storage used for the default cache adapters in [Manifests ](/developer_guides/execution_pipeline/manifests ), [Object Caching ](/developer_guides/performance/caching ) and [Partial Template Caching ](/developer_guides/templates/partial_template_caching ). It defaults to creating a sub-directory of PHP's built-in `sys_get_temp_dir()` . Can be an absolute path (with a leading `/` ), or a path relative to the project root. |