forked from netgen/ezpublish-legacy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
config.php-RECOMMENDED
299 lines (250 loc) · 9.97 KB
/
config.php-RECOMMENDED
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
<?php
/*
WHAT THIS FILE IS ABOUT - READ CAREFULLY
----------------------------------------
This file contains a documented list of the few configuration points
available from config.php. The proposed default values below are meant
to be the most optimized ones, or meaningful examples of what can be achieved.
In order to have the present settings taken into account, you will need to
rename this file into config.php, and keep it placed at the root of eZ Publish,
where config.php-RECOMMENDED is currently placed. Plus, you will need to
*uncomment* the proposed settings.
*/
/*
PATH TO THE EZCOMPONENTS
------------------------
config.php can set the components path like:
*/
//ini_set( 'include_path', ini_get( 'include_path' ). PATH_SEPARATOR . '../ezcomponents/trunk' );
/*
USING COMPONENTS VIA COMPOSER
-----------------------------
If installation is in a eZ Publish 5/Symfony context, composer will be attempted to be used
if the following file is found: '../EZP_APP_FOLDER_NAME/autoload.php'
Default EZP_APP_FOLDER_NAME value is "app" and this constant gives you possibility to change it.
In eZ Publish 5.x, default value of EZP_APP_FOLDER_NAME was "ezpublish".
*/
//define( 'EZP_APP_FOLDER_NAME', 'my_app' );
/*
USING BUNDLED COMPONENTS
------------------------
If you are using a distribution of eZ Publish with which the necessary
eZ Components are bundled (in lib/ezc), then you can use this setting to
control if the bundled eZ Components should be used (true) or not (false).
By default, when this setting is not present and the bundled eZ Components are
present, they will be used. If you're using the bundled eZ Components it's recommended
to define EZP_USE_BUNDLED_COMPONENTS as a boolean true anyway, for optimal speed.
*/
//define( 'EZP_USE_BUNDLED_COMPONENTS', true );
/*
If you are not using the bundled eZ Components, then for optimal speed it is
recommended to set EZC_BASE_PATH to either ezc/Base/base.php or Base/src/base.php,
depending on how you installed the eZ Components. By default, if this setting
is not present, eZ Publish first tries to include ezc/Base/base.php in the standard
php include path. If that fails Base/src/base.php is included.
*/
//define( 'EZC_BASE_PATH', '/usr/lib/ezc/Base/base.php' );
/*
TIMEZONES
---------
The recommended way of setting timezones is via php.ini.
However you can set the default timezone for your eZ Publish application as shown below.
More on supported timezones : http://www.php.net/manual/en/timezones.php
*/
//date_default_timezone_set( 'Europe/Paris' );
/*
INI FILES OPTIMIZATIONS
-----------------------
This new setting controls whether eZINI should check if the settings have
been updated in the *.ini-files*. If this check is disabled eZ Publish
will always used the cached values, lowering the amount of stat-calls to
the file system, and thus increasing performance.
Set EZP_INI_FILEMTIME_CHECK constant to false to improve performance by
not checking modified time on ini files.
You can also set it to the name of an ini file you still want to check
modified time for. For example, set it to 'site.ini' to make the system
still check if that file has been modified, while ignoring changes for
any other file.
Note that independently of this setting, new INI override files will NEVER
be found automatically. You will need to clear at least the INI cache
when a new INI file override is added to the structure. Note that new files
are not affected, but this is an edge situation.
*/
//define( 'EZP_INI_FILEMTIME_CHECK', false );
/*
KERNEL OVERRIDES
----------------
This setting controls if eZ Publish's autoload system should allow, and
load classes, which override kernel classes from extensions.
NB1: Not all classes can be overridden because of existing includes for eg handlers.
NB2: This feature is not covered by support and any kind of kernel overrides
needs to be explicitly informed to eZ Systems on support requests.
*/
//define( 'EZP_AUTOLOAD_ALLOW_KERNEL_OVERRIDE', false );
/*
Set EZP_INI_FILE_PERMISSION constant to the permissions you want saved
ini and cache files to have. This setting also applies to generated autoload files.
Do keep an octal number as value here ( meaning it starts by a 0 ).
*/
//define( 'EZP_INI_FILE_PERMISSION', 0666 );
/*
CUSTOM AUTOLOAD MECHANISM
-------------------------
It is also possible to push a custom autoload method to the autoload
function stack. Remember to check for class prefixes in such a method, if it
will not serve classes from eZ Publish and eZ Components.
Here is an example code snippet to be placed right in this file, in the case
you would be using your custom Foo framework, in which all PHP classes would be
prefixed by 'Foo' :
<code>
ini_set( 'include_path', ini_get( 'include_path' ). ':/usr/lib/FooFramework/' );
require 'Foo/ClassLoader.php';
function fooAutoload( $className )
{
if ( 'Foo' == substr( $className, 0, 3 ) )
{
FooClassLoader::loadClass( $className );
}
}
spl_autoload_register( 'fooAutoload' );
</code>
*/
/*
CLUSTERING
----------
In order to serve binary files over HTTP, eZ Publish needs informations about your cluster backend.
Most of these settings will duplicate those found in your file.ini.append.php.
You can optionnaly define those constants in config.cluster.php
*/
/**
* Storage backend. Possible values:
* - dfsmysqli (DFS cluster, mysqli based)
* - dfspostgres (DFS cluster, postgresql based)
* - dfsoracle (with appropriate extension)
*/
// define( 'CLUSTER_STORAGE_BACKEND', 'dfsmysqli' );
/**
* Custom cluster storage backend
* Root relative path to the custom clustering backend. When provided, the gateway filename won't be built based
* on the default path + CLUSTER_STORAGE_BACKEND.
*
* Example: define( 'CLUSTER_STORAGE_GATEWAY_PATH', 'extension/ezoracle/clusterfilehandlers/gateway/dfs.php' );
*/
// define( 'CLUSTER_STORAGE_GATEWAY_PATH', 'extension/name/path/to/gateway.php' );
/**
* Cluster storage host.
* Required.
*/
// define( 'CLUSTER_STORAGE_HOST', 'localhost' );
/**
* Cluster storage port.
* Optional: the default RDBMS port will be used if set to false
*/
// define( 'CLUSTER_STORAGE_PORT', 3306 );
/**
* Cluster storage user
* Required
*/
// define( 'CLUSTER_STORAGE_USER', 'dbuser' );
/**
* Cluster storage password
* Required
*/
// define( 'CLUSTER_STORAGE_PASS', 'dbpassword' );
/**
* Database name
* Required for most RDBMS
*/
// define( 'CLUSTER_STORAGE_DB', 'ezpcluster' );
/**
* Charset to use when communicating with the database.
* Must match the value in file.ini
*/
// define( 'CLUSTER_STORAGE_CHARSET', 'utf8' );
/**
* NFS share path.
* Required ONLY for DFS based clusters
*/
// define( 'CLUSTER_MOUNT_POINT_PATH', '/media/nfs' );
/**
* Enable persistent database connections, for backends with support (currently: Oracle, with appropriate extension)
* Optional. Defaults to false.
*/
// define( 'CLUSTER_PERSISTENT_CONNECTION', false );
/**
* Allow cluster index debugging.
* This MAY reveal internal details, and should not be used in a production environnement.
* Optional. Defaults to false.
*/
// define( 'CLUSTER_ENABLE_DEBUG', true );
/**
* Enable HTTP cache features: if-modified-since & eTags
* Optional. Defaults to true.
*/
// define( 'CLUSTER_ENABLE_HTTP_CACHE', false );
/**
* Enable HTTP range support (partial HTTP downloads)
* Optional. Defaults to true.
* NOTE: This feature is ONLY available for DFS based cluster handlers.
*/
// define( 'CLUSTER_ENABLE_HTTP_RANGE', true );
/**
* Enable usage of "Expires" headers.
* Optional. Defaults to 86400 (one day).
* Possible values: false (disable), or a TTL in seconds.
* Can be set to a VERY high value (315569260 for 10 years) as long as you enable
* ezjscore.ini/[Packer]/AppendLastModifiedTime so that the generation timestamp is appended
* to ezjscore pack files
*/
// define( 'CLUSTER_EXPIRY_TIMEOUT', 86400 );
/**
* Enable usage of "X-Powered-By" headers.
* Optional. Defaults: eZ Publish.
* Setting it to false will disable the custom header, but you still need to set expose_php to off
* in the php configuration to get rid of the X-Powered-By header completely.
*/
// define( 'CLUSTER_HEADER_X_POWERED_BY', 'eZ Publish' );
/**
* DFS/MySQLi only: custom table name for cache files metadata
* Optional. Defaults: "ezdfsfile_cache"
* If set to an existing mysql table, this table will be used for cache files.
* Storage files will always remain inside ezdfsfile.
*/
// define( 'CLUSTER_METADATA_TABLE_CACHE', 'ezdfsfile_cache' );
/**
* DFS/MySQLi only: search string to distinguish cache files and storage files
* Optional. Defaults: "/cache/", "/storage/"
*
* This is an advanced setting.
* Changing it only makes sense if FileSettings.CacheDir or FileSettings.StorageDir have been modified.
*/
// define( 'CLUSTER_METADATA_CACHE_PATH', '/cache/' );
// define( 'CLUSTER_METADATA_STORAGE_PATH', '/storage/' );
/*
LOG HANDLING
------------
Those constants allow to change the max log file size and the number of files
to keep while the logs are rotated for files generated by eZ Publish
(eZDebug) and custom log files (eZLog)
*/
/**
* Maximum file size in bytes of eZ Publish generated log, ie
* error.log, warning.log, notice.log and strict.log files
* Default is 200Kb
*/
// define( 'EZPUBLISH_LOG_MAX_FILE_SIZE', 204800 );
/**
* Number of files to keep while rotating eZ Publish generated log.
* Set this constant to 0 to disable the built-in log rotation.
*/
// define( 'EZPUBLISH_LOG_ROTATE_FILES', 3 );
/**
* Maximum file size in bytes of custom log file generated with eZLog class
*/
// define( 'CUSTOM_LOG_MAX_FILE_SIZE', 204800 );
/**
* Number of files to keep while rotating custom log file.
* Set this constant to 0 to disable the built-in log rotation.
*/
// define( 'CUSTOM_LOG_ROTATE_FILES', 3 );
?>