vzlogger/backend/lib/Util/Configuration.php
2010-07-29 00:04:33 +02:00

146 lines
No EOL
3.6 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2010, The volkszaehler.org project
* @package util
* @license http://www.opensource.org/licenses/gpl-license.php GNU Public License
*/
/*
* This file is part of volkzaehler.org
*
* volkzaehler.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* volkzaehler.org is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with volkszaehler.org. If not, see <http://www.gnu.org/licenses/>.
*/
namespace Volkszaehler\Util;
/**
* Static configuration class for loading and storing the configuration to the disk
*
* @package util
* @author Steffen Vogel <info@steffenvogel.de>
*/
class Configuration {
static protected $values = array();
/**
* @param string $var A string delimited by dots
* @param mixed $value A scalar value or array which should be set as the value for $var
*/
static public function write($var, $value) {
if (!is_scalar($value) && !is_array($value)) {
throw new \Exception('sry we can\'t store this datatype in the configuration');
}
$values =& self::$values;
$tree = explode('.', $var);
foreach ($tree as $part) {
$values =& $values[$part]; // TODO use array_merge_recursive()
}
$values = $value;
}
/**
*
* @param string $var A string delimited by dots
* @return mixed the configuration value
*/
static public function read($var = NULL) {
$tree = explode('.', $var);
if (is_null($var)) {
return self::$values;
}
$values = self::$values;
foreach ($tree as $part) {
$values = $values[$part];
}
return $values;
}
/**
*
* @param string $var A string delimited by dots
*/
static public function delete($var) {
$tree = explode('.', $var);
$values =& self::$values;
foreach ($tree as $part) {
$values =& $values[$part];
}
unset($values);
}
/**
* loading configuration from fule
*
* @param string $filename A string pointing to a file on the filesystem
*/
static public function load($filename) {
$filename .= '.php';
if (!file_exists($filename)) {
throw new \Exception('configuration file not found: ' . $filename);
}
include $filename;
if (!isset($config)) {
throw new \Exception('no variable $config found in ' . $filename);
}
self::$values = $config;
}
/**
*
* @param string $filename A string pointing to a file on the filesystem
* @return boolean TRUE on success
*/
static public function store($filename) {
$filename .= '.php';
$delcaration = '';
foreach (self::$values as $key => $value) {
$export = var_export($value, TRUE);
$export = preg_replace('/=>\s+array/', '=> array', $export);
$export = str_replace(" ", "\t", $export);
$declaration .= '$config[\'' . $key . '\'] = ' . $export . ';' . PHP_EOL . PHP_EOL;
}
$content = <<<EOT
<?php
/**
* That's the volkszaehler.org configuration file.
* Please take care of the following rules:
* - you are allowed to edit it by your own
* - anything else than the \$config declaration
* will maybe be removed during the reconfiguration
* by the configuration parser!
* - only literals are allowed as parameters
* - expressions will be evaluated by the parser
* and saved as literals
*/
$declaration?>
EOT;
return file_put_contents($filename, $content);
}
}
?>