|
Server IP : 10.2.73.233 / Your IP : 216.73.216.59 Web Server : Apache/2.4.59 (Debian) System : Linux polon 4.19.0-27-amd64 #1 SMP Debian 4.19.316-1 (2024-06-25) x86_64 User : www-data ( 33) PHP Version : 5.6.40-64+0~20230107.71+debian10~1.gbp673146 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority, MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home/ifk/web/assets/../prado4.3.2/Data/SqlMap/ |
| [ Home ] | [ C0mmand ] | [ Upload File ] |
|---|
<?php
/**
* TSqlMapConfig class file.
*
* @author Wei Zhuo <weizhuo[at]gmail[dot]com>
* @link https://github.com/pradosoft/prado
* @license https://github.com/pradosoft/prado/blob/master/LICENSE
*/
namespace Prado\Data\SqlMap;
use Prado\Data\TDataSourceConfig;
use Prado\Exceptions\TConfigurationException;
use Prado\Prado;
use Prado\TApplicationMode;
use Prado\TPropertyValue;
/**
* TSqlMapConfig module configuration class.
*
* Database connection and TSqlMapManager configuration.
*
* @author Wei Zhuo <weizho[at]gmail[dot]com>
* @since 3.1
*/
class TSqlMapConfig extends TDataSourceConfig
{
private $_configFile;
private $_sqlmap;
private $_enableCache = false;
/**
* File extension of external configuration file
*/
public const CONFIG_FILE_EXT = '.xml';
/**
* @return string module ID + configuration file path.
*/
private function getCacheKey()
{
return $this->getID() . $this->getConfigFile();
}
/**
* Deletes the configuration cache.
*/
public function clearCache()
{
$cache = $this->getApplication()->getCache();
if ($cache !== null) {
$cache->delete($this->getCacheKey());
}
}
/**
* Create and configure the data mapper using sqlmap configuration file.
* Or if cache is enabled and manager already cached load from cache.
* If cache is enabled, the data mapper instance is cached.
*
* @return TSqlMapManager SqlMap manager instance
* @since 3.1.7
*/
public function getSqlMapManager()
{
if (($manager = $this->loadCachedSqlMapManager()) === null) {
$manager = new TSqlMapManager($this->getDbConnection());
if (strlen($file = $this->getConfigFile()) > 0) {
$manager->configureXml($file);
$this->cacheSqlMapManager($manager);
}
} elseif ($this->getConnectionID() !== '') {
$manager->setDbConnection($this->getDbConnection());
}
return $manager;
}
/**
* Saves the current SqlMap manager to cache.
* @param mixed $manager
* @return bool true if SqlMap manager was cached, false otherwise.
*/
protected function cacheSqlMapManager($manager)
{
if ($this->getEnableCache()) {
$cache = $this->getApplication()->getCache();
if ($cache !== null) {
$dependencies = null;
if ($this->getApplication()->getMode() !== TApplicationMode::Performance) {
$dependencies = $manager->getCacheDependencies();
}
return $cache->set($this->getCacheKey(), $manager, 0, $dependencies);
}
}
return false;
}
/**
* Loads SqlMap manager from cache.
* @return TSqlMapManager SqlMap manager intance if load was successful, null otherwise.
*/
protected function loadCachedSqlMapManager()
{
if ($this->getEnableCache()) {
$cache = $this->getApplication()->getCache();
if ($cache !== null) {
$manager = $cache->get($this->getCacheKey());
if ($manager instanceof TSqlMapManager) {
return $manager;
}
}
}
return null;
}
/**
* @return string SqlMap configuration file.
*/
public function getConfigFile()
{
return $this->_configFile;
}
/**
* @param string $value external configuration file in namespace format. The file
* extension must be '.xml'.
* @throws TConfigurationException if the file is invalid.
*/
public function setConfigFile($value)
{
if (is_file($value)) {
$this->_configFile = $value;
} else {
$file = Prado::getPathOfNamespace($value, self::CONFIG_FILE_EXT);
if ($file === null || !is_file($file)) {
throw new TConfigurationException('sqlmap_configfile_invalid', $value);
} else {
$this->_configFile = $file;
}
}
}
/**
* Set true to cache sqlmap instances.
* @param bool $value true to cache sqlmap instance.
*/
public function setEnableCache($value)
{
$this->_enableCache = TPropertyValue::ensureBoolean($value);
}
/**
* @return bool true if configuration should be cached, false otherwise.
*/
public function getEnableCache()
{
return $this->_enableCache;
}
/**
* @return TSqlMapGateway SqlMap gateway instance.
*/
protected function createSqlMapGateway()
{
return $this->getSqlMapManager()->getSqlmapGateway();
}
/**
* Initialize the sqlmap if necessary, returns the TSqlMapGateway instance.
* @return TSqlMapGateway SqlMap gateway instance.
*/
public function getClient()
{
if ($this->_sqlmap === null) {
$this->_sqlmap = $this->createSqlMapGateway();
}
return $this->_sqlmap;
}
}