1
0
Fork 0
mirror of https://github.com/Oreolek/ifhub.club.git synced 2024-07-05 07:54:24 +03:00
ifhub.club/framework/classes/engine/Plugin.class.php

339 lines
12 KiB
PHP
Raw Normal View History

<?php
/*-------------------------------------------------------
*
* LiveStreet Engine Social Networking
* Copyright © 2008 Mzhelskiy Maxim
*
*--------------------------------------------------------
*
* Official site: www.livestreet.ru
* Contact e-mail: rus.engine@gmail.com
*
* GNU General Public License, version 2:
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
*
---------------------------------------------------------
*/
/**
* Абстракция плагина, от которой наследуются все плагины
* Файл плагина должен находиться в каталоге /plugins/plgname/ и иметь название PluginPlgname.class.php
*
* @package engine
* @since 1.0
*/
abstract class Plugin extends LsObject {
/**
* Путь к шаблонам с учетом наличия соответствующего skin`a
*
* @var array
*/
static protected $aTemplatePath=array();
/**
* Web-адрес директорий шаблонов с учетом наличия соответствующего skin`a
*
* @var array
*/
static protected $aTemplateWebPath=array();
/**
* Массив делегатов плагина
*
* @var array
*/
protected $aDelegates=array();
/**
* Массив наследуемых классов плагина
*
* @var array
*/
protected $aInherits=array();
/**
* Метод инициализации плагина
*
*/
public function Init() {
}
/**
* Передает информацию о делегатах в модуль ModulePlugin
* Вызывается Engine перед инициализацией плагина
* @see Engine::LoadPlugins
*/
final function Delegate() {
$aDelegates=$this->GetDelegates();
foreach ($aDelegates as $sObjectName=>$aParams) {
foreach ($aParams as $sFrom=>$sTo) {
$this->Plugin_Delegate($sObjectName,$sFrom,$sTo,get_class($this));
}
}
$aInherits=$this->GetInherits();
foreach ($aInherits as $sObjectName=>$aParams) {
foreach ($aParams as $sFrom=>$sTo) {
$this->Plugin_Inherit($sFrom,$sTo,get_class($this));
}
}
}
/**
* Возвращает массив наследников
*
* @return array
*/
final function GetInherits() {
$aReturn=array();
if(is_array($this->aInherits) and count($this->aInherits)) {
foreach ($this->aInherits as $sObjectName=>$aParams) {
if(is_array($aParams) and count($aParams)) {
foreach ($aParams as $sFrom=>$sTo) {
2010-04-25 15:07:11 +03:00
if (is_int($sFrom)) {
$sFrom=$sTo;
$sTo=null;
}
list($sFrom,$sTo)=$this->MakeDelegateParams($sObjectName,$sFrom,$sTo);
$aReturn[$sObjectName][$sFrom]=$sTo;
}
}
}
}
return $aReturn;
}
/**
* Возвращает массив делегатов
*
* @return array
*/
final function GetDelegates() {
$aReturn=array();
if(is_array($this->aDelegates) and count($this->aDelegates)) {
foreach ($this->aDelegates as $sObjectName=>$aParams) {
if(is_array($aParams) and count($aParams)) {
foreach ($aParams as $sFrom=>$sTo) {
if (is_int($sFrom)) {
$sFrom=$sTo;
$sTo=null;
}
list($sFrom,$sTo)=$this->MakeDelegateParams($sObjectName,$sFrom,$sTo);
$aReturn[$sObjectName][$sFrom]=$sTo;
}
}
}
}
return $aReturn;
}
/**
* Преобразовывает краткую форму имен делегатов в полную
*
* @param $sObjectName Название типа объекта делегата
* @see ModulePlugin::aDelegates
* @param $sFrom Что делегируем
* @param $sTo Что делегирует
* @return array
*/
public function MakeDelegateParams($sObjectName,$sFrom,$sTo) {
2010-04-25 15:07:11 +03:00
/**
* Если не указан делегат TO, считаем, что делегатом является
2010-04-25 15:07:11 +03:00
* одноименный объект текущего плагина
*/
if ($sObjectName=='template') {
if(!$sTo) {
$sTo = self::GetTemplatePath(get_class($this)).$sFrom;
2010-04-25 15:07:11 +03:00
} else {
$sTo=preg_replace("/^_/",$this->GetTemplatePath(get_class($this)),$sTo);
}
} else {
2010-06-01 19:20:30 +03:00
if(!$sTo) {
$sTo = get_class($this).'_'.$sFrom;
} else {
$sTo=preg_replace("/^_/",get_class($this).'_',$sTo);
}
2010-04-25 15:07:11 +03:00
}
return array($sFrom,$sTo);
}
/**
* Метод активации плагина
*
* @return bool
*/
public function Activate() {
return true;
}
/**
* Метод деактивации плагина
*
* @return bool
*/
public function Deactivate() {
return true;
}
/**
* Транслирует на базу данных запросы из указанного файла
* @see ModuleDatabase::ExportSQL
*
* @param string $sFilePath Полный путь до файла с SQL
* @return array
*/
protected function ExportSQL($sFilePath) {
return $this->Database_ExportSQL($sFilePath);
}
2011-04-25 17:07:40 +03:00
/**
* Выполняет SQL
* @see ModuleDatabase::ExportSQLQuery
2011-04-25 17:07:40 +03:00
*
* @param string $sSql Строка SQL запроса
2011-04-25 17:07:40 +03:00
* @return array
*/
protected function ExportSQLQuery($sSql) {
return $this->Database_ExportSQLQuery($sSql);
}
2010-05-04 14:24:15 +03:00
/**
* Проверяет наличие таблицы в БД
* @see ModuleDatabase::isTableExists
2010-05-04 14:24:15 +03:00
*
* @param string $sTableName Название таблицы, необходимо перед именем таблицы добавлять "prefix_", это позволит учитывать произвольный префикс таблиц у пользователя
* <pre>
* prefix_topic
* </pre>
* @return bool
2010-05-04 14:24:15 +03:00
*/
protected function isTableExists($sTableName) {
return $this->Database_isTableExists($sTableName);
2010-05-04 14:24:15 +03:00
}
/**
* Проверяет наличие поля в таблице
* @see ModuleDatabase::isFieldExists
*
* @param string $sTableName Название таблицы, необходимо перед именем таблицы добавлять "prefix_", это позволит учитывать произвольный префикс таблиц у пользователя
* @param string $sFieldName Название поля в таблице
* @return bool
*/
protected function isFieldExists($sTableName,$sFieldName) {
return $this->Database_isFieldExists($sTableName,$sFieldName);
}
/**
* Добавляет новый тип в поле enum(перечисление)
* @see ModuleDatabase::addEnumType
*
* @param string $sTableName Название таблицы, необходимо перед именем таблицы добавлять "prefix_", это позволит учитывать произвольный префикс таблиц у пользователя
* @param string $sFieldName Название поля в таблице
* @param string $sType Название типа
*/
protected function addEnumType($sTableName,$sFieldName,$sType) {
$this->Database_addEnumType($sTableName,$sFieldName,$sType);
}
/**
* Возвращает версию плагина
*
* @return string|null
*/
public function GetVersion() {
preg_match('/^Plugin([\w]+)$/i',get_class($this),$aMatches);
$sPluginXML = Config::Get('path.root.application').'/plugins/'.func_underscore($aMatches[1]).'/'.ModulePlugin::PLUGIN_XML_FILE;
if($oXml = @simplexml_load_file($sPluginXML)) {
return (string)$oXml->version;
}
return null;
}
/**
* Ставим хук на вызов неизвестного метода и считаем что хотели вызвать метод какого либо модуля
* @see Engine::_CallModule
*
* @param string $sName Имя метода
* @param array $aArgs Аргументы
* @return mixed
*/
public function __call($sName,$aArgs) {
return Engine::getInstance()->_CallModule($sName,$aArgs);
}
2010-04-29 22:45:54 +03:00
/**
* Возвращает полный серверный путь до плагина
2010-04-29 22:45:54 +03:00
*
* @param string $sName
* @return string
2010-04-29 22:45:54 +03:00
*/
static public function GetPath($sName) {
$sName = preg_match('/^Plugin([\w]+)(_[\w]+)?$/Ui',$sName,$aMatches)
2013-05-12 05:35:07 +03:00
? func_underscore($aMatches[1])
: func_underscore($sName);
return Config::Get('path.root.application').'/plugins/'.$sName.'/';
2010-04-29 22:45:54 +03:00
}
/**
* Возвращает полный web-адрес до плагина
*
* @param string $sName
* @return string
*/
static public function GetWebPath($sName) {
$sName = preg_match('/^Plugin([\w]+)(_[\w]+)?$/Ui',$sName,$aMatches)
2013-05-12 05:35:07 +03:00
? func_underscore($aMatches[1])
: func_underscore($sName);
return Config::Get('path.root.web').'/application/plugins/'.$sName.'/';
}
/**
* Возвращает правильный серверный путь к директории шаблонов с учетом текущего шаблона
* Если пользователь использует шаблон которого нет в плагине, то возвращает путь до шабона плагина 'default'
*
* @param string $sName Название плагина или его класс
* @return string|null
*/
static public function GetTemplatePath($sName) {
2010-05-01 16:59:03 +03:00
$sName = preg_match('/^Plugin([\w]+)(_[\w]+)?$/Ui',$sName,$aMatches)
2013-05-12 05:35:07 +03:00
? func_underscore($aMatches[1])
: func_underscore($sName);
if(!isset(self::$aTemplatePath[$sName])) {
$aPaths=glob(Config::Get('path.root.application').'/plugins/'.$sName.'/templates/skin/*',GLOB_ONLYDIR);
2010-04-17 18:12:10 +03:00
$sTemplateName=($aPaths and in_array(Config::Get('view.skin'),array_map('basename',$aPaths)))
? Config::Get('view.skin')
: 'default';
$sDir=Config::Get('path.root.application')."/plugins/{$sName}/templates/skin/{$sTemplateName}/";
self::$aTemplatePath[$sName] = is_dir($sDir) ? $sDir : null;
}
return self::$aTemplatePath[$sName];
}
/**
* Возвращает правильный web-адрес директории шаблонов
* Если пользователь использует шаблон которого нет в плагине, то возвращает путь до шабона плагина 'default'
*
* @param string $sName Название плагина или его класс
* @return string
*/
static public function GetTemplateWebPath($sName) {
2010-05-01 16:59:03 +03:00
$sName = preg_match('/^Plugin([\w]+)(_[\w]+)?$/Ui',$sName,$aMatches)
2013-05-12 05:35:07 +03:00
? func_underscore($aMatches[1])
: func_underscore($sName);
if(!isset(self::$aTemplateWebPath[$sName])) {
$aPaths=glob(Config::Get('path.root.application').'/plugins/'.$sName.'/templates/skin/*',GLOB_ONLYDIR);
2010-04-17 18:12:10 +03:00
$sTemplateName=($aPaths and in_array(Config::Get('view.skin'),array_map('basename',$aPaths)))
? Config::Get('view.skin')
: 'default';
self::$aTemplateWebPath[$sName]=Config::Get('path.root.web')."/application/plugins/{$sName}/templates/skin/{$sTemplateName}/";
}
return self::$aTemplateWebPath[$sName];
}
/**
* Устанавливает значение серверного пути до шаблонов плагина
*
* @param string $sName Имя плагина
* @param string $sTemplatePath Серверный путь до шаблона
* @return bool
*/
static public function SetTemplatePath($sName,$sTemplatePath) {
if(!is_dir($sTemplatePath)) return false;
self::$aTemplatePath[$sName]=$sTemplatePath;
return true;
}
/**
* Устанавливает значение web-пути до шаблонов плагина
*
* @param string $sName Имя плагина
* @param string $sTemplatePath Серверный путь до шаблона
*/
static public function SetTemplateWebPath($sName,$sTemplatePath) {
self::$aTemplateWebPath[$sName]=$sTemplatePath;
}
}
?>