Want to get started using Better WP-Config ASAP?
- Check out our Quick Start, or
- Check our our more in-depth 7 Step Tutorial.
- No brittle PHP constants required
- Better WP-Config
define()
s all constants required by WordPress core for you - You configure with
.php
associate arrays, an.env
file or aJSON
file. - Config options are organized by area, e.g.
db
,debug
,error
,salts
, etc. - Specifying options is consistent; no needed to know
define()
vs.ini_set()
, etc. - But you can specify
define()
constants needed by any plugin or theme
- Better WP-Config
- Directory-layout agnostic
- Store config files in ANY directory, parent or subdir
- Use the
private
directories of managed web hosts to store config - Set
ABSPATH
(e.g. WP core) to web root,/wp
or any other subdir - Set
WP_CONTENT_DIR
to/wp-content
,/app
or any other subdir
- Configurations cascade (like CSS) for easy maintenance
- Better WP-Config has defaults for common WP and PHP config options
- Use platform defaults to override Better WP-Config defaults
- Use project defaults to overide platform defaults, etc.
- Use environment defaults that override platform defaults, etc.
- Use secrets to override environment defaults, etc.
- Finally web host configuration can override secrets, etc.
- Provides first-class multi-environment support
- Define unlimited environments:
local
,test
,stage
,prod
, etc. - Map named environments to
HTTP_HOST
domains by regular expression - Version-control config for all environments (except
secrets
) - Deploy with no build changes needed to
index.php
orwp-config.php
- Define unlimited environments:
- Optional handling of secrets
- Exclude from version-controlled config
- Load from
$_ENV
,$_SERVER
orgetenv()
- Optional support for:
- Custom configurations for managed web hosts (If you are a web host, talk to us!)
- phpdotenv
- Custom config file location; outside web root, or in
private
directories - Trivial to implement multi-tenancy
- Discoverability
- See all options and their values w/
wp_config()->print_config();
- See all options and their values w/
(Note: The following will not be true until we complete this issue. Until then, see our quick start)
-
Just create a file named
/wp-content/config/config.php
and add your site's configuration using the format here:<?php return array( 'db[name]' => 'example_db', 'db[user]' => 'example_user', 'db[pass]' => '1234567890abcdef', 'db[charset]' => 'utf8mb4_unicode_ci', 'db[collate]' => 'utf8mb4', 'db[host]' => 'localhost', 'db[table_prefix]' => 'wp_', 'defines' => array( 'CONSTANT_REQUIRED_BY_A_PLUGIN' => 'it's value' ), );
-
You will also need to replace your site's
/index.php
and/wp-config.php
with very simple alternatives that you can find here and here, respectively.
However, before you make wrong assumptions:
Better WP-Config can load config files from ../config
, /private/config
, or wherever you like.
You can use phpdotenv and .env files!
If you are a fan of separating configuration and code, you can set your file_format
to 'env'
.
It may look simple — which was intentional to make getting started easy — but Better WP-Config was architected to handle highly complex configuration requirements. Once you get started and you encounter more complex use-cases such as multiple environments and automated deployment you will see how flexible and powerful Better WP-Config truly is.
You may ask what problem Better WP-Config is trying to solve. You may ask: "Why do we need a better WordPress configuration solution?" Well, we need one because we have found that far too many use-cases beyond the trivial demand a better configuration solution. Read on:
WordPress is a great CMS, but it ignores the needs of WordPress developers who would like to use a more professional workflow such as with test
/stage
/live
environments. The default WordPress configuration was designed to manage configuration for one environment; if you want to manage more you have to roll-your-own multi-environment configuration solution.
WordPress allows you to store configuration in wp-config.php
in the web root, or one directory level above. Although you can store your configuration in another file and then require()
it in wp-config.php
(which is what Better WP-Config does) hacking together a custom solution means you'll also need to document and maintain it, assuming you want to depend on it in the future.
And if you do go to the trouble to develop and document a solution such as Better WP-Config you'll basically have invested time (and money?) into duplicating that which you cpould have just used without any development and documentation effort.
Adding insult to injury each WordPress managed host — such as Pantheon and WPEngine — each roll their own arbitrarily-incompatible configuration solutions to support their own managed WordPress offering.
Here is how various WordPress managed webhosts handle and/or limit you with wp-config.php
.
If you are familiar with how other managed WordPress websites handle wp-config.php
please consider submitting a pull request with documentation on how they handle their wp-config.php
to help us and others.
Anyone who has worked with WordPress knows about configuring WordPress' database credentials via the PHP constants DB_HOST
, DB_NAME
, DB_USER
and DB_PASSWORD
. This seems simple and easy when you firstt start working with WordPress, but over time you realize that it makes configuration very inflexible because you cannot cascade configurations from WordPress' defaults, your project's defaults, to your environment's specifics and finally to your web host's configuration.
Better WPConfig does not eliminate the use of immutable constants but instead waits until all cascading configuration is merged before define()
ing these constants. (But this could be a first step to eradicate the use of PHP's define()
d constants from WordPress. It's a thought, because PHP's immutable constants makes automated testing of WordPress functionality much harder than it needs to be.)
Unfortunately there is no simple way to find all the options available to WordPress core since they are implied throughout WordPress' codebase and various documented locations onlines. Better WP-Config (mostly) solves this problem with "wp_config()->print_config()
, analogous to phpinfo()
A lot of configuration options have no defaults, such as a the database configuration which adds to learning required for local development. Better WP-Config provides default options for all "known" options.
By itself you could come up with a set of workable conventions for being able to version control your configuration for all the different environments your project needs — we did — but then you realize that each webhost handles it differently and try-as-you-might, you feel like it is impossible to find one consistent solution your team can use that will work with the different web hosts you and your clients have chosen.
To better understand why this is difficult be sure to read about how Pantheon and WPEngine handle their wp-config.php
files, respectively.
Lastly, the problems related to professional workflow and version control uses-cases excerbated by the incompatible choices made by managed WordPress web hosts simply because of the lack of standarization of wp-config.php
just makes deployment harder than it needs to be. This applies whether you are using SFTP upload, Git deployment such as Pantheon has, or deployment via a continuous integration provider like CircleCI.
The good news is Better WP-Config solves (almost) all these problems, today! Get started.
We are really happy with how well Better WP-Config. However, things could be:
-
Great if the ClassicPress and CalmPress forks were to adopt Better WP-Config for configuration,
-
Even better if WordPress managed webhosts would standardize on Better WP-Config for their services, or
-
Best of all if WordPress itself were to use Better WP-Config for new installs, while still maintaining ongoing support for existing sites that are already using
wp-config.php
as it has been for years.
GPLv2