How should I store settings for project?
Which is better - to use a $settings
array with all my settings:
$settings[\'max_photos\'] = 30;
//
I think it is best to use constants for configuration. For example using class constants:
class Config {
const
max_photos = 30,
something_else = 100,
// ...
;
}
echo Config::max_photos;
If you have PHP 5.3 you could also define them as global constants:
const MAX_PHOTOS = 30;
echo MAX_PHOTOS;
But I think this is far less clean and straightforward.
Obviously this will only work as long as you are only storing constants, i.e. scalar, non-expression values. If your configuration contains arrays for example, this won't work anymore. In this case I would use a Config class with public static properties:
class Config {
public static $per_page = 30;
public static $array = array(...);
}
echo Config::$per_page;
The latter is very similar to the $config
array approach, but has the benefit (or may this be a drawback?) that the class is accessible from everywhere including functions and classes, whereas the array is accessible only in the global space unless you import it into functions/classes using global $config;
.
My two cents: Use both. Most application configuration settings belong in a global array variable. Config data needs to be accessible from diverse application parts, and this is what global variables are for. And keeping everything together in a an array is most sensible. An array can be extended, e.g. some options set in a config.php and the rest read from a config.ini for example.
But there is also a place for CONSTANTS. The fine line to draw is, if an option is really something that MIGHT change during the application runtime, or if it is more a of fixed/magic value. If once set up, you should not change an application setting (or rendering might fail), then this option shouldn't be in the array, but sementically fixed as constant. (That's an interpretative rule of thumb, but served me well.)
If the project settings is too heavy, then file(xml is better) is good and a dedicated class for settings is also good.
If the project settings is small, then array is best, its very fast and no I/O related issue will arise.
Even you can use database (slower and auth issue).
I tend to put configuration values that are only accessed globally in a config array and define values that are accessed anywhere. For example:
inc/config.php
// only accessed in global scope (see init.php)
$config['error_reporting'] = E_ALL & ~E_NOTICE;
$config['memory_limit'] = '16M';
$config['time_zone'] = 'America/Los_Angeles';
// accessed within functions or class methods (see somefile.php)
define('HTTP', 'http://imac.local/my_site/');
define('HTTPS', 'http://imac.local/my_site/');
define('FILE_ROOT', '/Library/WebServer/Documents/my_site/');
inc/init.php
require 'inc/config.php';
/* Set some php configurations */
isset($config['error_reporting']) ? error_reporting($config['error_reporting']) : '';
isset($config['time_limit']) ? set_time_limit($config['time_limit']) : '';
isset($config['memory_limit']) ? ini_set('memory_limit', $config['memory_limit']) : '';
isset($config['timezone']) ? date_default_timezone_set($config['timezone']) : date_default_timezone_set('America/Los_Angeles');
somefile.php
require 'inc/init.php';
function site_url($uri, $secure = FALSE)
{
return $secure ? HTTPS . $uri : HTTP . $uri;
}
Keep in mind this example is stripped down to demonstrate an idea.
If you go for the array approach, you could use array literals for slightly more readable code:
$settings = array(
'max_photos' => 30,
'max_width' => 100
//...
)
Either will work nicely, do whichever you feel most comfortable with.