123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- <?php
- /**
- * Manage application and plugins configurations with key/value pair.
- *
- * **nb:** It's possible to specify namespace in order to distinct global configuration to plugin custom configuration
- *
- * @author valentin carruesco
- *
- * @category Core
- *
- * @license copyright
- */
- class Configuration extends Entity
- {
- protected $id,$key,$value,$confTab;
- protected $fields =
- array(
- 'id' => 'key',
- 'key' => 'longstring',
- 'value' => 'longstring',
- );
- /**
- * Get all configurations from database OR session if it was yet loaded
- * This function is called at start of program and global var '$conf' is filled with response, so use global $conf instead of call this function.
- * #### Example
- * ```php
- * $confs = Configuration::getAll();
- * var_dump($confs);
- * ```.
- *
- * @return array Array of configurations
- */
- public function getAll()
- {
- if (!isset($_SESSION['configuration'])) {
- $configurationManager = new self();
- $configs = $configurationManager->populate();
- $confTab = array();
- foreach ($configs as $config) {
- $this->confTab[$config->getKey()] = Functions::decrypt($config->getValue());
- }
- $_SESSION['configuration'] = serialize($this->confTab);
- } else {
- $this->confTab = unserialize($_SESSION['configuration']);
- }
- }
- /**
- * Get configuration value from it key
- * #### Example
- * ```php
- * global $conf; // global var, contain configurations
- * echo $conf->get('myConfigKey'); // print myConfigKey value
- * ```.
- *
- * @param string configuration key
- * @param string configuration namespace (default is 'conf')
- *
- * @return string valeur de la configuration
- */
- public function get($key)
- {
- return isset($this->confTab[$key]) ? $this->confTab[$key] : '';
- }
- /**
- * Update or insert configuration value in database with specified key
- * #### Example
- * ```php
- * global $conf; // global var, contain configurations
- * echo $conf->put('myNewConfigKey','hello!'); //create configuration myNewConfigKey with value 'hello!'
- * echo $conf->put('myNewConfigKey','hello 2!'); //update configuration myNewConfigKey with value 'hello2!'
- * ```.
- *
- * @param string configuration key
- * @param string configuration value
- * @param string configuration namespace (default is 'conf')
- */
- public function put($key, $value)
- {
- $secured_value = Functions::crypt($value);
- $configurationManager = new self();
- if (isset($this->confTab[$key])) {
- $configurationManager->change(array('value' => $secured_value), array('key' => $key));
- } else {
- $configurationManager->add($key, $secured_value);
- }
- $this->confTab[$key] = $value;
- unset($_SESSION['configuration']);
- }
- /**
- * Remove configuration value in database with specified key
- * #### Example
- * ```php
- * global $conf; // global var, contain configurations
- * echo $conf->remove('myNewConfigKey'); //delete myNewConfigKey from 'conf' default namespace
- * echo $conf->remove('myNewConfigKey','myCustomPluginConfig'); //delete myNewConfigKey from 'myCustomPluginConfig' namespace
- * ```.
- *
- * @param string configuration key
- * @param string configuration namespace (default is 'conf')
- */
- public function add($key, $value)
- {
- $config = new self();
- $config->setKey($key);
- $config->setValue($value);
- $config->save();
- $this->confTab[$key] = $value;
- unset($_SESSION['configuration']);
- }
- public function getId()
- {
- return $this->id;
- }
- public function getKey()
- {
- return $this->key;
- }
- public function setKey($key)
- {
- $this->key = $key;
- }
- public function getValue()
- {
- return $this->value;
- }
- public function setValue($value)
- {
- $this->value = $value;
- }
- }
|