Controls various aspects of Enacts behavior.
Your general configuration options are stored in enact/config/config.php, the config file returns an array that gets merge with the default configurations stored in enact/app/config/enact.php.
For example, to change the control panel slug and timezone return an array like so:
return Array( 'cpAccessSlug' => '/control/', 'timezone' => 'America/Chicago' );
Below is the full listing of default configuration settings.
Whether or not your application is running in Development mode.
'devMode' => true,
The control panel access slug. Must begin and end with a slash!
'cpAccessSlug' => '/control/',
They key user sessions will be stored in.
'sessionKey' => 'site-user',
Define how session files should be stored
true - Enact should store it in enact/storage/session.
false - Use the default server configuration.
string - A valid path to a writable directory on the web server
'PHPSessionStorage' => '/home/user/sessions/',
The key for storing session ids in cookies.
'PHPSessionName' => 'siteSession',
The name of the cookie used to store the permanent login token of the user, enabling permanent login sessions.
'permanentLoginTokenCookieName' => 'site-perm',
The number of seconds the permanent login token should last.
'permanentLoginLength' => 2592000,
Maximum number of invalid login attempts before maxedLoginAttemptsLockOutSleep seconds must be waited.
'maxLoginAttempts' => 8,
After the maxLoginAttempts this many seconds must pass until another login can be attempted again.
'maxedLoginAttemptsLockOutSeconds' => 60,
Minimum length passwords must be.
'minPasswordLength' => 6,
Minimum length user names and display names must be.
'minUserNameLength' => 6,
the string used to provide paginated URIs, must contain a ? placeholder where the page number will be.
'paginate' => '/p-?',
Can URI paths have trailing slashes and still match an entry or template?
For example if set to true:
'allowURITrailingSlashes' => false,
The template to match when the root of a directory is requested.
/state/ == enact/template/state/index.html
'directoryIndexFile' => 'root.html',
A prefix specifying that a template is not allowed to be served publicly as a direct match to a route/URI.
'privateTemplatePrefix' => '.',
Where HTTP Error code responses are stored, such as 404, or 500.
'errorTemplateDirectory' => '_siteErrors/',
The default format to display dates in on Entry pages.
Find the formatting rules here: http://amsul.ca/pickadate.js/date/#formatting-rules
'entryDateFormat' => 'mmm dd - yyyy',
The default format to display times in on Entry pages.
Find the formatting rules here: http://amsul.ca/pickadate.js/time/#formatting-rules
'entryTimeFormat' => 'hA',
The interval between times when selecting time values.
'timeSelectionInterval' => 30,
The format to display dates in admin feeds.
Format rules for moment.js can be found here: http://momentjs.com/docs/#/displaying/format/
'momentDateFormat' => 'MM/DD/YY hA',
The default expiration for redirects.
'redirectDefaultExpiration' => (new DateTime('+3 month'))->format('Y-m-d H:i:s'),
Should draft previews be made publicly available? Meaning you don't have to have a enact user session going to see them? This is for sharing changes you have done with the outside world, before you actually publish them.
'publicDraftPreview' => false,
Should Enact use XSendFile to serve resources that aren't available in the public folder?
'useXSendFile' => true
The number of results that will be returned per page in admin control panels.
'feedPerPage' => 50,
The system timezone, must be a valid PHP timezone, see http://php.net/manual/en/timezones.php.
'timezone' => 'America/Chicago',
When a template is called and doesn't exist, the defined extension(s) will be applied to the template name and searched for.
'defaultTemplateExtensions' => '.html',
Whether to force all requests to be HTTPS, will redirect any non HTTPS requests with a 301 to the HTTPS page. You must have a valid SSL certificate installed and setup on your server to use HTTPS.
'forceSecureRequests' => true,
The domain of the site, if not set the domain will be determined via the $_SERVER['SERVER_NAME'] directive. However, if the constant ENACT_SITE_DOMAIN is defined it will take precedence over either. Do not specify http, the proper protocol will be determined based on the current request. Remember you can force all requests to redirect to https with forceSecureRequests.
'siteDomain' => 'yoursite.com',
Include powered by Enact header.
'includePoweredByHeader' => false,
The default control panel language to use.
'defaultCPLanguage' => 'es',
The slug users login at, should never begin with a slash.
'userLoginSlug' => 'access',
The slug users logout at, should never begin with a slash.
'userLogoutSlug' => 'destroy',
The slug to send users to once they have logged in, should never begin with a slash.
'afterLoginRedirectSlug' => 'entry/',
The slug to send users to once they have logged out, begin the slug with a slash if you want to send users to a non admin control panel slug, such as your custom login page slug.
'afterLogoutRedirectSlug' => '/login',
The slug that is emailed to users when they request a password reset email. Begin it with a slash to indicate that your using a custom password reset page that doesn't exist within the admin control panel.
'resetPasswordSlug' => '/pw-reset',
The slug that is emailed to users when an account is created for them and the admin sends an account activation email. Begin it with a slash to indicate that your using a custom account activation page that doesn't exist within the admin control panel.
'accountActivationSlug' => '/account-activation'
Force all emails to be sent to specific email address. Can be a string for a single email eg: email@example.com or an array of emails eg: ['firstname.lastname@example.org','email@example.com'].
'forceSendToEmail' => 'firstname.lastname@example.org',
Only allow assets with the specified extensions to be uploaded to Enact.
'assetExtensionWhiteList' => ['jpg','jpeg','png'],
Don't allow assets with the specified extensions to be uploaded to Enact.
'assetExtensionBlackList' => ['pdf'],
'resourceCacheDuration' => 5184000
Whether your site is down for temporary maintenance. If true no application logic will be processed, a HTTP 503 response code will be sent along with the message provided by maintenanceMessage.
'maintenanceMode' => true,
The message to be displayed when your site is in maintenance mode.
'maintenanceMessage' => 'Sorry for the inconvenience, but were performing some necessary maintenance on the site and will be back up shortly',
Whether Cross Site Request Forgery (CSRF) tokens are enabled and required to perform POST, PUT, and DELETE requests.
'CSRFEnabled' => false,
The name of the CSRF token as used by cookies, and hidden inputs.
'CSRFTokenName' => 'my_csrf_token_name',