176 lines
5.1 KiB
PHP
176 lines
5.1 KiB
PHP
<?php
|
|
/**
|
|
* @brief User prefs handler
|
|
*
|
|
* dcPrefs provides user preferences management. This class instance exists as
|
|
* dcAuth $prefs property. You should create a new prefs instance when
|
|
* updating another user prefs.
|
|
*
|
|
* @package Dotclear
|
|
* @subpackage Core
|
|
*
|
|
* @copyright Olivier Meunier & Association Dotclear
|
|
* @copyright GPL-2.0-only
|
|
*/
|
|
|
|
if (!defined('DC_RC_PATH')) {return;}
|
|
|
|
class dcPrefs
|
|
{
|
|
protected $con; ///< <b>connection</b> Database connection object
|
|
protected $table; ///< <b>string</b> Prefs table name
|
|
protected $user_id; ///< <b>string</b> User ID
|
|
|
|
protected $workspaces = []; ///< <b>array</b> Associative workspaces array
|
|
|
|
protected $ws; ///< <b>string</b> Current workspace
|
|
|
|
/**
|
|
Object constructor. Retrieves user prefs and puts them in $workspaces
|
|
array. Local (user) prefs have a highest priority than global prefs.
|
|
|
|
@param core <b>dcCore</b> dcCore object
|
|
@param user_id <b>string</b> User ID
|
|
*/
|
|
public function __construct($core, $user_id)
|
|
{
|
|
$this->con = &$core->con;
|
|
$this->table = $core->prefix . 'pref';
|
|
$this->user_id = &$user_id;
|
|
try { $this->loadPrefs();} catch (Exception $e) {
|
|
if (version_compare($core->getVersion('core'), '2.3', '>')) {
|
|
trigger_error(__('Unable to retrieve workspaces:') . ' ' . $this->con->error(), E_USER_ERROR);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
Retrieves all workspaces (and their prefs) from database, with one query.
|
|
*/
|
|
private function loadPrefs()
|
|
{
|
|
$strReq = 'SELECT user_id, pref_id, pref_value, ' .
|
|
'pref_type, pref_label, pref_ws ' .
|
|
'FROM ' . $this->table . ' ' .
|
|
"WHERE user_id = '" . $this->con->escape($this->user_id) . "' " .
|
|
'OR user_id IS NULL ' .
|
|
'ORDER BY pref_ws ASC, pref_id ASC';
|
|
try {
|
|
$rs = $this->con->select($strReq);
|
|
} catch (Exception $e) {
|
|
throw $e;
|
|
}
|
|
|
|
/* Prevent empty tables (install phase, for instance) */
|
|
if ($rs->isEmpty()) {
|
|
return;
|
|
}
|
|
|
|
do {
|
|
$ws = trim($rs->f('pref_ws'));
|
|
if (!$rs->isStart()) {
|
|
// we have to go up 1 step, since workspaces construction performs a fetch()
|
|
// at very first time
|
|
$rs->movePrev();
|
|
}
|
|
$this->workspaces[$ws] = new dcWorkspace($GLOBALS['core'], $this->user_id, $ws, $rs);
|
|
} while (!$rs->isStart());
|
|
}
|
|
|
|
/**
|
|
Create a new workspace. If the workspace already exists, return it without modification.
|
|
|
|
@param ws <b>string</b> Workspace name
|
|
@return <b>dcWorkspace</b> The workspace created
|
|
*/
|
|
public function addWorkspace($ws)
|
|
{
|
|
if (!array_key_exists($ws, $this->workspaces)) {
|
|
$this->workspaces[$ws] = new dcWorkspace($GLOBALS['core'], $this->user_id, $ws);
|
|
}
|
|
return $this->workspaces[$ws];
|
|
}
|
|
|
|
/**
|
|
Rename a workspace.
|
|
|
|
@param oldWs <b>string</b> Old workspace name
|
|
@param newws <b>string</b> New workspace name
|
|
@return <b>boolean</b>
|
|
*/
|
|
public function renWorkspace($oldNs, $newNs)
|
|
{
|
|
if (!array_key_exists($oldWs, $this->workspaces) || array_key_exists($newWs, $this->workspaces)) {
|
|
return false;
|
|
}
|
|
|
|
// Rename the workspace in the workspace array
|
|
$this->workspaces[$newWs] = $this->workspaces[$oldWs];
|
|
unset($this->workspaces[$oldWs]);
|
|
|
|
// Rename the workspace in the database
|
|
$strReq = 'UPDATE ' . $this->table .
|
|
" SET pref_ws = '" . $this->con->escape($newWs) . "' " .
|
|
" WHERE pref_ws = '" . $this->con->escape($oldWs) . "' ";
|
|
$this->con->execute($strReq);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
Delete a whole workspace with all preferences pertaining to it.
|
|
|
|
@param ws <b>string</b> Workspace name
|
|
@return <b>boolean</b>
|
|
*/
|
|
public function delWorkspace($ws)
|
|
{
|
|
if (!array_key_exists($ws, $this->workspaces)) {
|
|
return false;
|
|
}
|
|
|
|
// Remove the workspace from the workspace array
|
|
unset($this->workspaces[$ws]);
|
|
|
|
// Delete all preferences from the workspace in the database
|
|
$strReq = 'DELETE FROM ' . $this->table .
|
|
" WHERE pref_ws = '" . $this->con->escape($ws) . "' ";
|
|
$this->con->execute($strReq);
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
Returns full workspace with all prefs pertaining to it.
|
|
|
|
@param ws <b>string</b> Workspace name
|
|
@return <b>dcWorkspace</b>
|
|
*/
|
|
public function get($ws)
|
|
{
|
|
if (array_key_exists($ws, $this->workspaces)) {
|
|
return $this->workspaces[$ws];
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
/**
|
|
Magic __get method.
|
|
@copydoc ::get
|
|
*/
|
|
public function __get($n)
|
|
{
|
|
return $this->get($n);
|
|
}
|
|
|
|
/**
|
|
Returns $workspaces property content.
|
|
|
|
@return <b>array</b>
|
|
*/
|
|
public function dumpWorkspaces()
|
|
{
|
|
return $this->workspaces;
|
|
}
|
|
|
|
}
|