1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-18 05:09:05 +01:00
php-e107/e107_handlers/pref_class.php

1299 lines
28 KiB
PHP
Raw Normal View History

2006-12-02 04:36:16 +00:00
<?php
/*
* e107 website system
*
* Copyright (C) 2008-2010 e107 Inc (e107.org)
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
* e107 Preference Handler
*
* $URL$
* $Id$
2006-12-02 04:36:16 +00:00
*/
if (!defined('e107_INIT')) { exit; }
2009-08-20 13:06:34 +00:00
require_once(e_HANDLER.'model_class.php');
2006-12-02 04:36:16 +00:00
/**
* Base preference object - shouldn't be used direct,
* used internal by {@link e_plugin_pref} and {@link e_core_pref classes}
*
* @package e107
* @category e107_handlers
* @version $Id$
* @author SecretR
* @copyright Copyright (c) 2009, e107 Inc.
*/
class e_pref extends e_front_model
{
/**
* Preference ID - DB row value
*
* @var string
*/
protected $prefid;
2009-12-02 16:51:04 +00:00
/**
* Preference ID alias e.g. 'core' is an alias of prefid 'SitePrefs'
* Used in e.g. server cache file name
2009-12-02 16:51:04 +00:00
*
* @var string
*/
protected $alias;
2009-12-02 16:51:04 +00:00
/**
* Runtime cache, set on first data load
*
* @var string
*/
protected $pref_cache = '';
2009-12-02 16:51:04 +00:00
/**
* Backward compatibility - serialized preferences
* Note: serialized preference storage is deprecated
*
* @var boolean
*/
protected $serial_bc = false;
2009-12-02 16:51:04 +00:00
/**
* If true, $prefid.'_Backup' row will be created/updated
* on every {@link save()} call
*
* @var boolean
*/
protected $set_backup = false;
2009-12-02 16:51:04 +00:00
/**
* Constructor
*
* @param string $prefid
* @param string $alias Used by cache file.
* @param array $data
* @param boolean $sanitize_data
*/
function __construct($prefid, $alias = '', $data = array(), $sanitize_data = true)
{
require_once(e_HANDLER.'cache_handler.php');
2009-12-02 16:51:04 +00:00
$this->prefid = preg_replace('/[^\w\-]/', '', $prefid);
if(empty($alias))
{
$alias = $prefid;
}
$this->alias = preg_replace('/[^\w\-]/', '', $alias);
2009-12-02 16:51:04 +00:00
$this->loadData($data, $sanitize_data);
}
2009-12-02 16:51:04 +00:00
/**
2009-12-02 16:51:04 +00:00
* Advanced getter - $pref_name could be path in format 'pref1/pref2/pref3' (multidimensional arrays support),
* alias of {@link e_model::getData()}
* If $pref_name is empty, all data array will be returned
*
* @param string $pref_name
* @param mixed $default
* @param integer $index
* @return mixed
*/
public function getPref($pref_name = '', $default = null, $index = null)
{
return $this->getData($pref_name, $default, $index);
}
2009-12-02 16:51:04 +00:00
/**
* Simple getter - $pref_name is not parsed (no multidimensional arrays support), alias of {@link e_model::get()}
2009-12-02 16:51:04 +00:00
* This is the prefered (performance wise) method when simple preference is retrieved
*
2020-12-18 19:55:12 -08:00
* @param string $key (pref name)
* @param mixed $default
* @return mixed
*/
2020-12-18 19:55:12 -08:00
public function get($key, $default = null)
{
2020-12-18 19:55:12 -08:00
return parent::get((string) $key, $default);
}
2009-12-02 16:51:04 +00:00
/**
* Advanced setter - $pref_name could be path in format 'pref1/pref2/pref3' (multidimensional arrays support)
* If $pref_name is array, it'll be merged with existing preference data, non existing preferences will be added as well
2009-12-02 16:51:04 +00:00
*
* @param string|array $pref_name
* @param mixed $value
* @return e_pref
*/
public function setPref($pref_name, $value = null)
{
global $pref;
//object reset not allowed, adding new pref is allowed
if(empty($pref_name))
{
2009-12-02 16:51:04 +00:00
return $this;
}
2009-12-02 16:51:04 +00:00
2009-09-04 15:27:28 +00:00
//Merge only allowed
if(is_array($pref_name))
{
$this->mergeData($pref_name, false, false, false);
return $this;
}
2009-12-02 16:51:04 +00:00
parent::setData($pref_name, $value, false);
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Reset preference object to given/empty state
* @param array $prefs
* @return $this
*/
public function reset($prefs = array())
{
parent::setData(array());
return $this;
}
/**
* Advanced setter - $pref_name could be path in format 'pref1/pref2/pref3' (multidimensional arrays support)
* Object data reseting is not allowed, adding new preferences is controlled by $strict parameter
2009-12-02 16:51:04 +00:00
*
* @param string|array $pref_name
* @param mixed $value
2009-09-04 15:27:28 +00:00
* @param boolean $strict true - update only, false - same as setPref()
* @return e_pref
*/
2009-09-04 15:27:28 +00:00
public function updatePref($pref_name, $value = null, $strict = false)
{
global $pref;
//object reset not allowed, adding new pref is not allowed
if(empty($pref_name))
{
2009-12-02 16:51:04 +00:00
return $this;
}
2009-12-02 16:51:04 +00:00
2009-09-04 15:27:28 +00:00
//Merge only allowed
if(is_array($pref_name))
{
$this->mergeData($pref_name, $strict, false, false);
return $this;
}
2009-12-02 16:51:04 +00:00
2009-09-04 15:27:28 +00:00
parent::setData($pref_name, $value, $strict);
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Simple setter - $pref_name is not parsed (no multidimensional arrays support)
* Adding new pref is allowed
2009-12-02 16:51:04 +00:00
*
2020-12-18 19:55:12 -08:00
* @param string $key (pref name)
* @param mixed $value
* @return e_pref
*/
2020-12-18 19:55:12 -08:00
public function set($key, $value=null, $strict = false)
{
global $pref;
2020-12-18 19:55:12 -08:00
if(empty($key) || !is_string($key))
{
return $this;
}
2020-12-18 19:55:12 -08:00
if(!isset($this->_data[$key]) || $this->_data[$key] != $value) $this->data_has_changed = true;
$this->_data[$key] = $value;
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Simple setter - $pref_name is not parsed (no multidimensional arrays support)
* Non existing setting will be not created
2009-12-02 16:51:04 +00:00
*
* @param string $pref_name
* @param mixed $value
* @return e_pref
*/
2009-09-03 14:15:36 +00:00
public function update($pref_name, $value)
{
global $pref;
if(empty($pref_name) || !is_string($pref_name))
{
return $this;
}
if(array_key_exists($pref_name, $this->_data))
2012-01-06 11:42:47 +00:00
{
if($this->_data[$pref_name] != $value) $this->data_has_changed = true;
2012-01-06 11:42:47 +00:00
$this->_data[$pref_name] = $value;
}
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Add new (single) preference (ONLY if doesn't exist)
* No multidimensional arrays support
2009-12-02 16:51:04 +00:00
*
* @see addData()
* @param string $pref_name
* @param mixed $value
* @return e_pref
*/
2009-09-03 14:15:36 +00:00
public function add($pref_name, $value)
2009-12-02 16:51:04 +00:00
{
if(empty($pref_name) || !is_string($pref_name))
{
return $this;
}
2012-01-06 11:42:47 +00:00
if(!isset($this->_data[$pref_name]))
{
$this->_data[$pref_name] = $value;
$this->data_has_changed = true;
}
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
2009-12-02 16:51:04 +00:00
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Add new preference or preference array (ONLY if it/they doesn't exist)
* $pref_name could be path in format 'pref1/pref2/pref3'
2009-12-02 16:51:04 +00:00
*
* @see addData()
* @param string|array $pref_name
* @param mixed $value
* @return e_pref
*/
public function addPref($pref_name, $value = null)
2009-12-02 16:51:04 +00:00
{
$this->addData($pref_name, $value);
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Remove single preference
* $pref_name is not parsed as a path
2009-12-02 16:51:04 +00:00
*
2020-12-18 19:55:12 -08:00
* @param string $key (pref name)
* @return e_pref
2020-12-18 19:55:12 -08:00
*@see e_model::remove()
*/
2020-12-18 19:55:12 -08:00
public function remove($key)
{
global $pref;
2020-12-18 19:55:12 -08:00
parent::remove((string) $key);
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Remove single preference (parse $pref_name)
* $pref_name could be path in format 'pref1/pref2/pref3'
2009-12-02 16:51:04 +00:00
*
* @see removeData()
* @param string $pref_name
* @return e_pref
*/
public function removePref($pref_name)
{
2009-12-02 16:51:04 +00:00
$this->removeData($pref_name);
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Disallow public use of e_model::addData()
* Disallow preference override
*
2020-12-18 19:55:12 -08:00
* @param string|array $key (pref name or array)
* @param mixed value
* @param boolean $strict
2015-02-15 02:37:36 -08:00
* @return $this|\e_model
*/
2020-12-18 19:55:12 -08:00
final public function addData($key, $value = null, $override = true)
{
global $pref;
2020-12-18 19:55:12 -08:00
parent::addData($key, $value, false);
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Disallow public use of e_model::setData()
* Only data merge possible
2009-12-02 16:51:04 +00:00
*
2020-12-18 19:55:12 -08:00
* @param string|array $key
* @param mixed $value
* @return e_pref
*/
2020-12-18 19:55:12 -08:00
final public function setData($key, $value = null, $strict = false)
{
global $pref;
2020-12-18 19:55:12 -08:00
if(empty($key))
{
2009-12-02 16:51:04 +00:00
return $this;
}
2009-12-02 16:51:04 +00:00
//Merge only allowed
2020-12-18 19:55:12 -08:00
if(is_array($key))
{
2020-12-18 19:55:12 -08:00
$this->mergeData($key, false, false, false);
return $this;
}
2009-12-02 16:51:04 +00:00
2020-12-18 19:55:12 -08:00
parent::setData($key, $value, false);
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Disallow public use of e_model::removeData()
* Object data reseting is not allowed
*
2020-12-18 19:55:12 -08:00
* @param string $key (pref name)
* @return e_pref
*/
2020-12-18 19:55:12 -08:00
final public function removeData($key=null)
{
global $pref;
2020-12-18 19:55:12 -08:00
parent::removeData((string) $key);
2009-12-02 16:51:04 +00:00
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Reset object data
*
* @param array $data
* @param boolean $sanitize
* @return e_pref
*/
public function loadData(array $data, $sanitize = true)
{
global $pref;
if(!empty($data))
{
if($sanitize)
{
$data = e107::getParser()->toDB($data);
}
parent::setData($data, null, false);
$this->pref_cache = e107::getArrayStorage()->serialize($data, false); //runtime cache
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Load object data - public
*
* @see _load()
* @param boolean $force
* @return e_pref
*/
2016-04-21 12:04:09 -07:00
public function load($id=null, $force = false)
{
global $pref;
if($force || !$this->hasData())
{
$this->data_has_changed = false;
$this->_load($force);
//BC
if($this->alias === 'core')
{
$pref = $this->getData();
}
}
2009-12-02 16:51:04 +00:00
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Load object data
*
* @param boolean $force
* @return e_pref
*/
protected function _load($force = false)
{
$id = $this->prefid;
2009-12-02 16:51:04 +00:00
$data = $force ? false : $this->getPrefCache(true);
if(!empty($data))
{
$this->pref_cache = e107::getArrayStorage()->serialize($data, false); //runtime cache
$this->loadData((array) $data, false);
return $this;
}
2009-12-02 16:51:04 +00:00
if (e107::getDb()->select('core', 'e107_value', "e107_name='{$id}'"))
{
$row = e107::getDb()->fetch();
2009-12-02 16:51:04 +00:00
if($this->serial_bc)
{
2009-12-02 16:51:04 +00:00
$data = unserialize($row['e107_value']);
$row['e107_value'] = e107::getArrayStorage()->serialize($data, false);
}
2009-12-02 16:51:04 +00:00
else
{
$data = e107::unserialize($row['e107_value']);
}
2009-12-02 16:51:04 +00:00
$this->pref_cache = $row['e107_value']; //runtime cache
$this->setPrefCache($row['e107_value'], true);
}
2009-08-08 08:11:02 +00:00
if(empty($data))
$data = array();
2009-12-02 16:51:04 +00:00
$this->loadData($data, false);
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Save object data to DB
*
* @param boolean $from_post merge post data
* @param boolean $force
* @param mixed $session_messages null: normal messages displayed, true: session messages used, false: no messages displayed.
* @return boolean|integer 0 - no change, true - saved, false - error
*/
public function save($from_post = true, $force = false, $session_messages = null)
{
global $pref;
if(!$this->prefid)
{
return false;
}
e107::getMessage()->setUnique($this->prefid); // attempt to fix
if($from_post)
{
$this->mergePostedData(); //all posted data is sanitized and filtered vs preferences/_data_fields array
}
2009-12-02 16:51:04 +00:00
if($this->hasValidationError())
2009-12-02 16:51:04 +00:00
{
return false;
}
2009-12-02 16:51:04 +00:00
if(!$this->data_has_changed && !$force)
{
2016-11-01 12:12:00 -07:00
if($session_messages !== false)
{
e107::getMessage()->addInfo(LAN_SETTINGS_NOT_SAVED_NO_CHANGES_MADE, $this->prefid, $session_messages)->moveStack($this->prefid);
}
return 0;
}
$log = e107::getLog();
$disallow_logs = $this->getParam('nologs', false);
2009-12-02 16:51:04 +00:00
//Save to DB
if(!$this->hasError())
{
if($this->serial_bc)
{
2009-12-02 16:51:04 +00:00
$dbdata = serialize($this->getPref());
}
2009-12-02 16:51:04 +00:00
else
{
$dbdata = $this->toString(false);
}
2009-12-02 16:51:04 +00:00
if(e107::getDb()->gen("REPLACE INTO `#core` (e107_name,e107_value) values ('{$this->prefid}', '".addslashes($dbdata)."') "))
{
$this->data_has_changed = false; //reset status
2009-12-02 16:51:04 +00:00
if(!empty($this->pref_cache))
{
$old = e107::unserialize($this->pref_cache);
if($this->serial_bc)
{
$dbdata = serialize($old);
}
2009-12-02 16:51:04 +00:00
else
{
$dbdata = $this->pref_cache;
}
// auto admin log
if(is_array($old) && !$disallow_logs) // fix install problems - no old prefs available
2010-04-15 15:33:20 +00:00
{
$new = $this->getPref();
// $log->logArrayDiffs($new, $old, 'PREFS_02', false);
$log->addArray($new,$old);
2010-04-15 15:33:20 +00:00
unset($new, $old);
if(deftrue('e_DEBUG_PREFS'))
2021-01-29 20:11:49 -08:00
{
$backtrace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS,2);
$log->logMessage(print_a($backtrace,true), E_MESSAGE_DEBUG);
}
2010-04-15 15:33:20 +00:00
}
2021-01-13 16:16:50 -08:00
// Backup
if($this->set_backup === true && e107::getDb()->gen("REPLACE INTO `#core` (e107_name,e107_value) values ('".$this->prefid."_Backup', '".addslashes($dbdata)."') "))
{
2021-01-13 16:16:50 -08:00
// trigger_error("Performing a pref backup", E_USER_NOTICE);
if(!$disallow_logs) $log->logMessage('Backup of <strong>'.$this->alias.' ('.$this->prefid.')</strong> successfully created.', E_MESSAGE_DEBUG, E_MESSAGE_SUCCESS, $session_messages);
e107::getCache()->clear_sys('Config_'.$this->alias.'_backup');
if(deftrue('e_DEBUG_PREFS'))
2019-01-13 14:08:46 -08:00
{
$backtrace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS,2);
$log->logMessage(print_a($backtrace,true), E_MESSAGE_DEBUG);
}
}
}
2009-08-27 23:03:34 +00:00
$this->setPrefCache($this->toString(false), true); //reset pref cache - runtime & file
if($this->alias == 'search') // Quick Fix TODO Improve.
{
$logId = 'SEARCH_04';
}
elseif($this->alias == 'notify')
{
$logId = 'NOTIFY_01';
}
else
{
$logId = 'PREFS_01';
}
// FIXME: Admin LAN dependency out of nowhere
e107::includeLan(e_LANGUAGEDIR . e_LANGUAGE . '/admin/lan_admin.php');
2016-11-02 08:57:29 +01:00
$log->addSuccess(LAN_SETSAVED, ($session_messages === null || $session_messages === true));
$uid = USERID;
if(empty($uid)) // Log extra details of any pref changes made by a non-user.
{
$log->addWarning(print_r(debug_backtrace(null,2), true), false);
}
$log->save($logId);
2009-12-02 16:51:04 +00:00
// if(!$disallow_logs) $log->logSuccess('Settings successfully saved.', true, $session_messages)->flushMessages($logId, E_LOG_INFORMATIVE, '', $this->prefid);
//BC
if($this->alias === 'core')
{
$pref = $this->getPref();
}
e107::getMessage()->moveStack($this->prefid);
2009-12-02 16:51:04 +00:00
return true;
}
elseif(e107::getDb()->getLastErrorNumber())
{
if(!$disallow_logs)
$log->addError('mySQL error #'.e107::getDb()->getLastErrorNumber().': '.e107::getDb()->getLastErrorText(), true, $session_messages)
->addError('Settings not saved.', true, $session_messages)
->flushMessages('PREFS_03', E_LOG_INFORMATIVE, '', $this->prefid);
e107::getMessage()->moveStack($this->prefid);
return false;
}
}
2009-12-02 16:51:04 +00:00
if($this->hasError())
{
//add errors to the eMessage stack
//$this->setErrors(true, $session_messages); old - doesn't needed anymore
if(!$disallow_logs)
$log->addError('Settings not saved.', true, $session_messages)
->flushMessages('LAN_FIXME', E_LOG_INFORMATIVE, '', $this->prefid);
e107::getMessage()->moveStack($this->prefid);
2021-01-13 16:16:50 -08:00
trigger_error("Settings not saved", E_USER_NOTICE);
return false;
}
2009-12-02 16:51:04 +00:00
else
{
e107::getMessage()->addInfo(LAN_SETTINGS_NOT_SAVED_NO_CHANGES_MADE, $this->prefid, $session_messages);
if(!$disallow_logs) $log->flushMessages('LAN_FIXME', E_LOG_INFORMATIVE, '', $this->prefid);
e107::getMessage()->moveStack($this->prefid);
return 0;
}
}
2009-12-02 16:51:04 +00:00
/**
* Get cached data from server cache file
*
* @param boolean $toArray convert to array
* @return string|array|false
*/
protected function getPrefCache($toArray = true)
{
if(!$this->pref_cache)
{
$this->pref_cache = e107::getCache()->retrieve_sys('Config_'.$this->alias, 24 * 60, true);
}
2009-12-02 16:51:04 +00:00
return ($toArray && $this->pref_cache ? e107::unserialize($this->pref_cache) : $this->pref_cache);
}
2009-12-02 16:51:04 +00:00
/**
* Convert data to a string and store it to a server cache file
* If $cache_string is an array, it'll be converted to a string
* If $save is string, it'll be used for building the cache filename
*
* @param string|array $cache_string
* @param string|boolean $save write to a file
* @return e_pref
*/
protected function setPrefCache($cache_string, $save = false)
{
if(is_array($cache_string))
{
$cache_string = e107::serialize($cache_string, false);
}
if(is_bool($save))
{
$this->pref_cache = $cache_string;
}
if($save)
{
e107::getCache()->set_sys('Config_'.($save !== true ? $save : $this->alias), $cache_string, true);
}
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Clear pref cache
2009-12-02 16:51:04 +00:00
*
* @param string $cache_name default to current alias
* @param boolean $runtime clear runtime cache as well ($this->pref_cache)
* @return e_pref
*/
public function clearPrefCache($cache_name = '', $runtime = true)
{
if($runtime)
{
$this->pref_cache = '';
}
e107::getCache()->clear_sys('Config_'.(!empty($cache_name) ? $cache_name : $this->alias));
return $this;
}
2009-12-02 16:51:04 +00:00
2009-10-21 11:57:15 +00:00
/**
* Validation
2009-11-17 15:04:46 +00:00
*
* @param array $data [optional] null to use Posted data
2009-11-17 15:04:46 +00:00
* @return boolean
2009-10-21 11:57:15 +00:00
*/
public function validate($data = null)
2009-10-21 11:57:15 +00:00
{
return parent::validate($data);
2009-10-21 11:57:15 +00:00
}
2009-12-02 16:51:04 +00:00
/**
* Set $set_backup option
*
* @param boolean $optval
* @return e_pref
2009-12-02 16:51:04 +00:00
*
*/
public function setOptionBackup($optval)
{
$this->set_backup = $optval;
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Set $serial_bc option
*
* @param boolean $optval
* @return e_pref
2009-12-02 16:51:04 +00:00
*
*/
public function setOptionSerialize($optval)
{
$this->serial_bc = $optval;
return $this;
}
2009-12-02 16:51:04 +00:00
/**
* Override
*/
2016-02-14 19:00:12 -08:00
public function delete($ids, $destroy = true, $session_messages = false)
{
}
2009-12-02 16:51:04 +00:00
/**
* Override
*/
2016-02-14 19:00:12 -08:00
protected function dbUpdate($force = false, $session_messages = false)
{
}
}
/**
* Handle core preferences
2009-12-02 16:51:04 +00:00
*
* @package e107
* @category e107_handlers
* @version 1.0
* @author SecretR
* @copyright Copyright (c) 2009, e107 Inc.
*/
2009-12-02 16:51:04 +00:00
final class e_core_pref extends e_pref
{
/**
* Allowed core id array
*
* @var array
*/
public $aliases = array(
2009-12-02 16:51:04 +00:00
'core' => 'SitePrefs',
'core_backup' => 'SitePrefs_Backup',
'core_old' => 'pref',
2009-12-02 16:51:04 +00:00
'emote' => 'emote_default', //TODO include other emote packs of the user.
'menu' => 'menu_pref',
'search' => 'search_prefs',
2010-04-15 15:33:20 +00:00
'notify' => 'notify_prefs',
'history' => 'history_prefs',
);
2009-12-02 16:51:04 +00:00
/**
* Backward compatibility - list of prefid's which operate wit serialized data
*
* @var array
*/
// protected $serial_bc_array = array('core_old', 'emote', 'menu', 'search');
protected $serial_bc_array = array('core_old');
/**
* Constructor
*
* @param string $alias
* @param boolean $load load DB data on startup
*/
function __construct($alias, $load = true)
{
$pref_alias = $alias;
if($alias == 'emote')
{
$pack = e107::pref('core','emotepack');
$this->aliases['emote'] = 'emote_'.$pack;
}
$pref_id = $this->getConfigId($alias);
2009-12-02 16:51:04 +00:00
2009-12-02 16:51:04 +00:00
if(!$pref_id)
{
$pref_id = $pref_alias = '';
trigger_error('Core config ID '.$alias.' not found!', E_USER_WARNING);
return;
}
2009-12-02 16:51:04 +00:00
if(in_array($pref_alias, $this->serial_bc_array))
{
$this->setOptionSerialize(true);
}
2009-12-02 16:51:04 +00:00
if('core' === $pref_alias)
{
$this->setOptionBackup(true);
}
2009-12-02 16:51:04 +00:00
parent::__construct($pref_id, $pref_alias);
if($load && $pref_id)
{
2018-07-22 11:43:13 -07:00
$this->load();
}
}
2009-12-02 16:51:04 +00:00
/**
* Get config ID
* Allowed values: key or value from $alias array
* If id not found this method returns false
*
* @param string $alias
* @return string
*/
public function getConfigId($alias)
{
$alias = trim($alias);
if(isset($this->aliases[$alias]))
{
return $this->aliases[$alias];
}
return false;
}
2009-12-02 16:51:04 +00:00
/**
* Get config ID
* Allowed values: key or value from $alias array
* If id not found this method returns false
*
* @param string $prefid
* @return string
*/
public function getAlias($prefid)
{
$prefid = trim($prefid);
return array_search($prefid, $this->aliases);
}
/**
* Export data from core pref and remove if needed. Useful for core pref -> menu table parm migration.
* @param array $prefList key/value pairs. key = oldpref value = new pref key
* @param bool|false $remove
* @return array|false if no match found.
*/
public function migrateData($prefList=array(), $remove=false)
{
$data = self::getData();
$array = array();
$save = false;
if(empty($prefList))
{
return false;
}
foreach($data as $k=>$v)
{
if(isset($prefList[$k]))
{
$key = $prefList[$k];
$array[$key] = $v;
if($remove == true)
{
self::remove($k);
$save = true;
}
}
}
if(empty($array))
{
return false;
}
if(!empty($save))
{
self::save(false,true,false);
}
return $array;
}
}
/**
* Handle plugin preferences
2009-12-02 16:51:04 +00:00
*
* @package e107
* @category e107_handlers
* @version 1.0
* @author SecretR
* @copyright Copyright (c) 2009, e107 Inc.
*/
2009-12-02 16:51:04 +00:00
class e_plugin_pref extends e_pref
{
/**
* Unique plugin name
*
* @var string
*/
protected $plugin_id;
2009-12-02 16:51:04 +00:00
/**
* Constructor
* Note: object data will be loaded only if the plugin is installed (no matter of the passed
* $load value)
*
* @param string $plugin_id unique plugin name
* @param string $multi_row additional field identifier appended to the $prefid
* @param boolean $load load on startup
*/
function __construct($plugin_id, $multi_row = '', $load = true)
{
$this->plugin_id = $plugin_id;
if($multi_row)
{
$plugin_id = $plugin_id.'_'.$multi_row;
}
parent::__construct('plugin_'.$plugin_id, "plugin_".$this->plugin_id);
2009-09-08 14:48:44 +00:00
if($load && e107::findPref('plug_installed/'.$this->plugin_id))
{
$this->load();
}
}
2009-12-02 16:51:04 +00:00
/**
* Retrive unique plugin name
*
* @return string
*/
public function getPluginId()
{
return $this->plugin_id;
}
/**
* Delete plugin preferences
* @see e107_handlers/e_pref#delete()
* @return boolean
*/
2016-02-14 19:00:12 -08:00
public function delete($ids, $destroy = true, $session_messages = false)
{
$ret = false;
if($this->plugin_id)
{
$ret = e107::getDb($this->plugin_id)->delete('core', "e107_name='{$this->plugin_id}'");
$this->destroy();
}
return $ret;
}
}
/**
* Handle plugin preferences
*
* @package e107
* @category e107_handlers
* @version 1.0
* @author SecretR
* @copyright Copyright (c) 2009, e107 Inc.
*/
class e_theme_pref extends e_pref
{
/**
* Unique plugin name
*
* @var string
*/
protected $theme_id;
/**
* Constructor
* Note: object data will be loaded only if the plugin is installed (no matter of the passed
* $load value)
*
* @param string $theme_id unique plugin name
* @param string $multi_row additional field identifier appended to the $prefid
* @param boolean $load load on startup
*/
function __construct($theme_id, $multi_row = '', $load = true)
{
$this->theme_id = $theme_id;
if($multi_row)
{
$theme_id = $theme_id.'_'.$multi_row;
}
parent::__construct('theme_'.$theme_id, "theme_".$this->theme_id);
// if($load && e107::findPref('plug_installed/'.$this->theme_id))
{
$this->load();
}
}
/**
* Retrive unique plugin name
*
* @return string
*/
public function getPluginId()
{
return $this->theme_id;
}
/**
* Delete plugin preferences
* @see e107_handlers/e_pref#delete()
* @return boolean
*/
public function delete($ids, $destroy = true, $session_messages = false)
{
$ret = false;
if($this->theme_id)
{
$ret = e107::getDb($this->theme_id)->delete('core', "e107_name='{$this->theme_id}'");
$this->destroy();
}
return $ret;
}
}
/**
* DEPRECATED - see e107::getConfig(), e_core_pref and e_plugin_pref
*
*/
2006-12-02 04:36:16 +00:00
//
// Simple functionality:
// Grab all prefs once, in one DB query. Reuse them throughout the session.
//
// get/set methods serve/consume strings (with slashes taken care of)
// getArray/setArray methods serve/consume entire arrays (since most prefs are such!)
//
// NOTE: Use of this class is VALUABLE (efficient) yet not NECESSARY (i.e. the system
// will not break if it is ignored)... AS LONG AS there is no path consisting of:
// - modify pref value(s) IGNORING this class
// - retrieve pref value(s) USING this class
// (while processing a single web page)
// Just to be safe I have changed a number of menu_pref edits to use setArray().
//
2009-12-02 16:51:04 +00:00
class prefs
2008-12-30 16:51:07 +00:00
{
2006-12-02 04:36:16 +00:00
var $prefVals;
var $prefArrays;
2008-12-30 16:51:07 +00:00
// Default prefs to load
2006-12-02 04:36:16 +00:00
var $DefaultRows = "e107_name='e107' OR e107_name='menu_pref' OR e107_name='notify_prefs'";
2008-12-30 16:51:07 +00:00
// Read prefs from DB - get as many rows as are required with a single query.
// $RowList is an array of pref entries to retrieve.
// If $use_default is TRUE, $RowList entries are added to the default array. Otherwise only $RowList is used.
// Returns TRUE on success (measured as getting at least one row of data); false on error.
// Any data read is buffered (in serialised form) here - retrieve using get()
2009-12-02 16:51:04 +00:00
function ExtractPrefs($RowList = "", $use_default = FALSE)
2008-12-30 16:51:07 +00:00
{
2006-12-02 04:36:16 +00:00
global $sql;
$Args = '';
if($use_default)
{
$Args = $this->DefaultRows;
}
if(is_array($RowList))
{
foreach($RowList as $v)
{
$Args .= ($Args ? " OR e107_name='{$v}'" : "e107_name='{$v}'");
}
}
if (!$sql->select('core', '*', $Args, 'default'))
2008-12-30 16:51:07 +00:00
{
return FALSE;
}
while ($row = $sql->fetch())
2006-12-02 04:36:16 +00:00
{
$this->prefVals['core'][$row['e107_name']] = $row['e107_value'];
}
2008-12-30 16:51:07 +00:00
return TRUE;
2006-12-02 04:36:16 +00:00
}
2008-12-30 16:51:07 +00:00
2006-12-02 04:36:16 +00:00
/**
* Return current pref string $name from $table (only core for now)
*
2009-11-17 15:04:46 +00:00
* @param string $name -- name of pref row
* @param string $table -- "core"
* @return string pref value, slashes already stripped. FALSE on error
* @access public
2006-12-02 04:36:16 +00:00
*/
2009-12-02 16:51:04 +00:00
function get($Name)
2008-12-30 16:51:07 +00:00
{
if(isset($this->prefVals['core'][$Name]))
{
if($this->prefVals['core'][$Name] != '### ROW CACHE FALSE ###')
{
return $this->prefVals['core'][$Name]; // Dava from cache
2009-12-02 16:51:04 +00:00
}
else
2008-12-30 16:51:07 +00:00
{
2006-12-02 04:36:16 +00:00
return false;
}
}
2008-12-30 16:51:07 +00:00
// Data not in cache - retrieve from DB
2009-12-02 16:51:04 +00:00
$get_sql = new db; // required so sql loops don't break using $tp->toHTML().
2020-12-14 16:21:48 -08:00
if($get_sql->select('core', '*', "`e107_name` = '{$Name}'", 'default'))
2008-12-30 16:51:07 +00:00
{
2020-12-14 16:21:48 -08:00
$row = $get_sql->fetch();
2006-12-02 04:36:16 +00:00
$this->prefVals['core'][$Name] = $row['e107_value'];
return $this->prefVals['core'][$Name];
2009-12-02 16:51:04 +00:00
}
else
2008-12-30 16:51:07 +00:00
{ // Data not in DB - put a 'doesn't exist' entry in cache to save another DB access
2006-12-02 04:36:16 +00:00
$this->prefVals['core'][$Name] = '### ROW CACHE FALSE ###';
return false;
}
}
/**
* Return current array from pref string $name in $table (core only for now)
*
2009-12-16 22:26:27 +00:00
* @param string $name -- name of pref row
2009-11-17 15:04:46 +00:00
* @param string $table -- "core" only now
* @return array pref values
* @access public
2006-12-02 04:36:16 +00:00
*/
// retrieve prefs as an array of values
function getArray($name)
{
return e107::unserialize($this->get($name));
// return unserialize($this->get($name));
2006-12-02 04:36:16 +00:00
}
/**
* Update pref set and cache
*
* @param string val -- pre-serialized string
* @param string $name -- name of pref row
* @param string $table -- "core" or "user"
2009-12-13 21:52:32 +00:00
* @global mixed $$name
2006-12-02 04:36:16 +00:00
* @access public
*
* set("val") == 'core', 'pref'
* set("val","rowname") == 'core', rowname
* set("val","","user") == 'user', 'user_pref' for current user
* set("val","","user",uid) == 'user', 'user_pref' for user uid
* set("val","fieldname","user") == 'user', fieldname
*
*/
function set($val, $name = "", $table = "core", $uid = USERID) {
global $sql;
if (!strlen($name)) {
switch ($table) {
case 'core':
$name = "pref";
break;
case 'user':
$name = "user_pref";
break;
}
}
$val = addslashes($val);
2020-12-14 16:21:48 -08:00
switch ($table )
{
2006-12-02 04:36:16 +00:00
case 'core':
2020-12-14 16:21:48 -08:00
if(!$sql->update($table, "e107_value='$val' WHERE e107_name='$name'"))
2006-12-02 04:36:16 +00:00
{
2020-12-14 16:21:48 -08:00
$sql->insert($table, "'{$name}', '{$val}'");
2006-12-02 04:36:16 +00:00
}
$this->prefVals[$table][$name] = $val;
unset($this->prefArrays[$table][$name]);
break;
case 'user':
2020-12-14 16:21:48 -08:00
$sql->update($table, "user_prefs='$val' WHERE user_id=$uid");
2006-12-02 04:36:16 +00:00
break;
}
}
/**
* Update pref set and cache
*
* - @param string $name -- name of pref row
* - @param string $table -- "core" or "user"
* - @global $$name
* - @access public
*
* set() == core, pref
* set("rowname") == core, rowname
* set("","user") == user, user_pref for current user
* set("","user",uid) == user, user_pref for user uid
* set("fieldname","user") == user, fieldname
*
* all pref sets other than menu_pref get toDB()
*/
function setArray($name = '', $table = 'core', $uid = USERID)
2009-12-09 20:35:58 +00:00
{
$tp = e107::getParser();
2006-12-02 04:36:16 +00:00
if (!strlen($name))
2009-12-09 20:35:58 +00:00
{
switch ($table)
2009-12-09 20:35:58 +00:00
{
2006-12-02 04:36:16 +00:00
case 'core':
2009-12-09 20:35:58 +00:00
$name = 'pref';
2006-12-02 04:36:16 +00:00
break;
case 'user':
2009-12-09 20:35:58 +00:00
$name = 'user_pref';
2006-12-02 04:36:16 +00:00
break;
}
}
global $$name;
if ($name != 'menu_pref')
2009-12-09 20:35:58 +00:00
{
foreach($$name as $key => $prefvalue)
2009-12-09 20:35:58 +00:00
{
2006-12-02 04:36:16 +00:00
$$name[$key] = $tp->toDB($prefvalue);
}
}
$tmp = e107::serialize($$name, FALSE); // $this->set() adds slashes now
// $tmp = serialize($$name);
2006-12-02 04:36:16 +00:00
$this->set($tmp, $name, $table, $uid);
}
}
2020-06-05 11:34:17 -07:00