Files
EasySoft-ZenTaoPMS/module/setting/model.php
2012-12-02 07:54:23 +00:00

201 lines
6.4 KiB
PHP

<?php
/**
* The model file of setting module of ZenTaoPMS.
*
* @copyright Copyright 2009-2012 青岛易软天创网络科技有限公司 (QingDao Nature Easy Soft Network Technology Co,LTD www.cnezsoft.com)
* @license LGPL (http://www.gnu.org/licenses/lgpl.html)
* @author Chunsheng Wang <chunsheng@cnezsoft.com>
* @package setting
* @version $Id$
* @link http://www.zentao.net
*/
?>
<?php
class settingModel extends model
{
/**
* Get config of system and one user.
*
* @param string $account
* @access public
* @return array
*/
public function getSysAndPersonalConfig($account = '')
{
$owner = 'system,' . ($account ? $account : '');
$records = $this->dao->select('*')
->from(TABLE_CONFIG)
->where('owner')->in($owner)
->fetchAll();
if(!$records) return array();
/* Group records by owner and module. */
$config = array();
foreach($records as $record)
{
if(!isset($record->module)) return array(); // If no module field, return directly. Since 3.2 version, there's the module field.
if($record->section) $config[$record->owner]->{$record->module}[] = $record;
if(!$record->section) $config[$record->owner]->{$record->module}[] = $record;
}
return $config;
}
/**
* Get the version of current zentaopms.
*
* Since the version field not saved in db. So if empty, return 0.3 beta.
* @access public
* @return void
*/
public function getVersion()
{
$version = $this->dao->select('value')->from(TABLE_CONFIG)
->where('owner')->eq('system')
->andWhere('section')->eq('global')
->andWhere('`key`')->eq('version')
->andWhere('company')->eq(0)
->fetch('value', false);
if($version == '3.0.stable') $version = '3.0'; // convert 3.0.stable to 3.0.
if($version) return $version;
return '0.3 beta';
}
/**
* Update version
*
* @param string $version
* @access public
* @return void
*/
public function updateVersion($version)
{
if($version >= 3.2) return $this->setItem('system', 'common', 'global', 'version', $version, 0);
$this->dao->delete()->from(TABLE_CONFIG)
->where('owner')->eq('system')
->andWhere('section')->eq('global')
->andWhere('`key`')->eq('version')
->andWhere('company')->eq(0)
->exec();
$data->owner = 'system';
$data->section = 'global';
$data->key = 'version';
$data->company = 0;
return $this->dao->insert(TABLE_CONFIG)->data($data, false)->exec();
}
/**
* Compute a SN. Use the server ip, and server software string as seed, and an rand number, two micro time
*
* Note: this sn just to unique this zentaopms. No any private info.
*
* @access public
* @return string
*/
public function computeSN()
{
$seed = $this->server->SERVER_ADDR . $this->server->SERVER_SOFTWARE;
$sn = md5(str_shuffle(md5($seed . mt_rand(0, 99999999) . microtime())) . microtime());
return $sn;
}
/**
* Set the sn of current zentaopms.
*
* @access public
* @return void
*/
public function setSN()
{
$sn = $this->getItem('system', 'common', 'global', 'sn', 0);
if($sn == '' or
$sn == '281602d8ff5ee7533eeafd26eda4e776' or
$sn == '9bed3108092c94a0db2b934a46268b4a' or
$sn == '8522dd4d76762a49d02261ddbe4ad432' or
$sn == '13593e340ee2bdffed640d0c4eed8bec')
{
$sn = $this->computeSN();
$this->setItem('system', 'common', 'global', 'sn', $sn, 0);
}
}
/**
* Get value of an item.
*
* @param string $owner
* @param string $module
* @param string $section
* @param string $key
* @param string|int $company
* @access public
* @return misc
*/
public function getItem($owner, $module, $section, $key, $company = 'current')
{
if($company === 'current') $company = $this->app->company->id;
return $this->dao->select('`value`')->from(TABLE_CONFIG)
->where('company')->eq($company)
->andWhere('owner')->eq($owner)
->andWhere('module')->eq($module)
->andWhere('section')->eq($section)
->andWhere('`key`')->eq($key)
->fetch('value', $autoCompany = false);
}
/**
* Set value of an item.
*
* @param string $owner
* @param string $module
* @param string $section
* @param string $key
* @param string $value
* @param string|int $company
* @access public
* @return void
*/
public function setItem($owner, $module, $section, $key, $value = '', $company = 'current')
{
$item->company = $company === 'current' ? $this->app->company->id : $company;
$item->owner = $owner;
$item->module = $module;
$item->section = $section;
$item->key = $key;
$item->value = $value;
$this->dao->replace(TABLE_CONFIG)->data($item)->exec($autoCompany = false);
}
/**
* Delete value of item
*
* @param string $owner
* @param string $module
* @param string $section
* @param array $key
* @param string|int $company
* @access public
* @return void
*/
public function deleteItem($owner, $module, $section, $key, $company = 'current')
{
$fieldNames = array_keys($key);
$company = $company === 'current' ? $this->app->company->id : $company;
foreach($fieldNames as $fieldName)
{
$value = $key[$fieldName];
$more = (is_array($value) or is_object($value)) ? true : false;
$this->dao->delete()->from(TABLE_CONFIG)
->where('owner')->eq($owner)
->andWhere('module')->eq($module)
->andWhere('section')->eq($section)
->andWhere('company')->eq($company)
->beginIF($more)->andWhere("`$fieldName`")->in($value)->fi()
->beginIF(!$more)->andWhere("`$fieldName`")->eq($value)->fi()
->exec($autoCompany = false);
}
}
}