Site config

Your initial config values should be setup in:

/app/library/setup/config.php

Which is done via the $config array, for example:

$config['name'] = 'Value';

This allows you to include this file via other systems, without providing the config object.

After this file has been processed, you should use the config helper to set/get values.


Servers

In your config.php file, you should set the 'SERVER' constant. This will allow your scripts to determine if they are running on a development server (stage), demo or live.

There are many ways to detect which server your running on, but my preferred method is to use the path:

if (preg_match('/^\/(Library|Volumes)\//i', ROOT)) {

    define('SERVER', 'stage');

} else if (str_starts_with(ROOT, '/www/demo/')) {

    define('SERVER', 'demo');

} else {

    define('SERVER', 'live');

}

Detection for stage is a simple regexp (as most OSX developers either use the /Library/ folder, or a case-sensitive volume). Then demo uses str_starts_with, and the default is to assume we are running on live.

This allows you to setup the database connection details (probably different).

And if you are using the email helper, it might be worth setting the following on stage:

$config['email.testing'] = 'admin@example.com';

It should also be noted that on stage, development mode is enabled by default.


Session Key

$config['session.key'] = '123...';

Simply used to ensure sessions are valid for this website, it just needs to be unique (not really a secret).

This avoids a form of session fixation, where a session created by another website hosted on the same server isn't recognised by this website.


Output

Hopefully most of these are self explanatory, and shown in the development mode notes.

Some special cases though:

  • output.protocols: Ideally set to array('https') on live (for only https connections).

  • output.mime: Set to "application/xhtml+xml" on stage, to ensure good markup.

  • output.framing: For basic Framing protection.

  • output.csp_*: For CSP setup.

  • output.js_*: For JavaScript setup.

  • output.css_*: For CSS setup.

  • output.timestamp_url: For resource and file URLs to include a timestamp.