mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-07 18:51:41 +09:00
issue 2119. supporting php 5.4. addon module.
git-svn-id: http://xe-core.googlecode.com/svn/branches/maserati@12707 201d5d3c-b55e-5fd7-737f-ddc643e51545
This commit is contained in:
parent
8a7c28babc
commit
ee9247e866
4 changed files with 309 additions and 103 deletions
|
|
@ -1,10 +1,12 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* Addon module's controller class
|
||||
* @author NHN (developers@xpressengine.com)
|
||||
*/
|
||||
class addonController extends addon
|
||||
{
|
||||
|
||||
/**
|
||||
* Initialization
|
||||
*
|
||||
|
|
@ -12,6 +14,7 @@ class addonController extends addon
|
|||
*/
|
||||
function init()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -23,20 +26,34 @@ class addonController extends addon
|
|||
function getCacheFilePath($type = "pc")
|
||||
{
|
||||
static $addon_file;
|
||||
if(isset($addon_file)) return $addon_file;
|
||||
if(isset($addon_file))
|
||||
{
|
||||
return $addon_file;
|
||||
}
|
||||
|
||||
$site_module_info = Context::get('site_module_info');
|
||||
$site_srl = $site_module_info->site_srl;
|
||||
|
||||
$addon_path = _XE_PATH_.'files/cache/addons/';
|
||||
$addon_path = _XE_PATH_ . 'files/cache/addons/';
|
||||
|
||||
$addon_file = $addon_path.$site_srl.$type.'.acivated_addons.cache.php';
|
||||
$addon_file = $addon_path . $site_srl . $type . '.acivated_addons.cache.php';
|
||||
|
||||
if($this->addon_file_called) return $addon_file;
|
||||
$this->addon_file_called = true;
|
||||
if($this->addon_file_called)
|
||||
{
|
||||
return $addon_file;
|
||||
}
|
||||
|
||||
$this->addon_file_called = TRUE;
|
||||
|
||||
if(!is_dir($addon_path))
|
||||
{
|
||||
FileHandler::makeDir($addon_path);
|
||||
}
|
||||
if(!file_exists($addon_file))
|
||||
{
|
||||
$this->makeCacheFile($site_srl, $type);
|
||||
}
|
||||
|
||||
if(!is_dir($addon_path)) FileHandler::makeDir($addon_path);
|
||||
if(!file_exists($addon_file)) $this->makeCacheFile($site_srl, $type);
|
||||
return $addon_file;
|
||||
}
|
||||
|
||||
|
|
@ -49,7 +66,7 @@ class addonController extends addon
|
|||
*/
|
||||
function _getMidList($selected_addon, $site_srl = 0)
|
||||
{
|
||||
$oAddonAdminModel = &getAdminModel('addon');
|
||||
$oAddonAdminModel = getAdminModel('addon');
|
||||
$addon_info = $oAddonAdminModel->getAddonInfoXml($selected_addon, $site_srl);
|
||||
return $addon_info->mid_list;
|
||||
}
|
||||
|
|
@ -62,14 +79,14 @@ class addonController extends addon
|
|||
* @param int $site_srl Site srl
|
||||
* @return void
|
||||
*/
|
||||
function _setAddMid($selected_addon,$mid, $site_srl=0)
|
||||
function _setAddMid($selected_addon, $mid, $site_srl = 0)
|
||||
{
|
||||
// Wanted to add the requested information
|
||||
$mid_list = $this->_getMidList($selected_addon, $site_srl);
|
||||
|
||||
$mid_list[] = $mid;
|
||||
$new_mid_list = array_unique($mid_list);
|
||||
$this->_setMid($selected_addon,$new_mid_list, $site_srl);
|
||||
$this->_setMid($selected_addon, $new_mid_list, $site_srl);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -80,17 +97,20 @@ class addonController extends addon
|
|||
* @param int $site_srl Site srl
|
||||
* @return void
|
||||
*/
|
||||
function _setDelMid($selected_addon,$mid,$site_srl=0)
|
||||
function _setDelMid($selected_addon, $mid, $site_srl = 0)
|
||||
{
|
||||
// Wanted to add the requested information
|
||||
$mid_list = $this->_getMidList($selected_addon,$site_srl);
|
||||
$mid_list = $this->_getMidList($selected_addon, $site_srl);
|
||||
|
||||
$new_mid_list = array();
|
||||
if(is_array($mid_list))
|
||||
{
|
||||
for($i=0,$c=count($mid_list);$i<$c;$i++)
|
||||
for($i = 0, $c = count($mid_list); $i < $c; $i++)
|
||||
{
|
||||
if($mid_list[$i] != $mid) $new_mid_list[] = $mid_list[$i];
|
||||
if($mid_list[$i] != $mid)
|
||||
{
|
||||
$new_mid_list[] = $mid_list[$i];
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
|
|
@ -98,7 +118,7 @@ class addonController extends addon
|
|||
$new_mid_list[] = $mid;
|
||||
}
|
||||
|
||||
$this->_setMid($selected_addon,$new_mid_list,$site_srl);
|
||||
$this->_setMid($selected_addon, $new_mid_list, $site_srl);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -109,10 +129,10 @@ class addonController extends addon
|
|||
* @param int $site_srl Site srl
|
||||
* @return void
|
||||
*/
|
||||
function _setMid($selected_addon,$mid_list,$site_srl=0)
|
||||
function _setMid($selected_addon, $mid_list, $site_srl = 0)
|
||||
{
|
||||
$args->mid_list = join('|@|',$mid_list);
|
||||
$this->doSetup($selected_addon, $args,$site_srl);
|
||||
$args->mid_list = join('|@|', $mid_list);
|
||||
$this->doSetup($selected_addon, $args, $site_srl);
|
||||
$this->makeCacheFile($site_srl);
|
||||
}
|
||||
|
||||
|
|
@ -128,7 +148,7 @@ class addonController extends addon
|
|||
$args = Context::getRequestVars();
|
||||
$addon_name = $args->addon_name;
|
||||
$mid = $args->mid;
|
||||
$this->_setAddMid($addon_name,$mid,$site_module_info->site_srl);
|
||||
$this->_setAddMid($addon_name, $mid, $site_module_info->site_srl);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -144,7 +164,7 @@ class addonController extends addon
|
|||
$addon_name = $args->addon_name;
|
||||
$mid = $args->mid;
|
||||
|
||||
$this->_setDelMid($addon_name,$mid,$site_module_info->site_srl);
|
||||
$this->_setDelMid($addon_name, $mid, $site_module_info->site_srl);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -158,18 +178,30 @@ class addonController extends addon
|
|||
function makeCacheFile($site_srl = 0, $type = "pc", $gtype = 'site')
|
||||
{
|
||||
// Add-on module for use in creating the cache file
|
||||
$buff = "";
|
||||
$oAddonModel = &getAdminModel('addon');
|
||||
$buff = '';
|
||||
$oAddonModel = getAdminModel('addon');
|
||||
$addon_list = $oAddonModel->getInsertedAddons($site_srl, $gtype);
|
||||
foreach($addon_list as $addon => $val)
|
||||
{
|
||||
if($val->addon == "smartphone") continue;
|
||||
if(!is_dir(_XE_PATH_.'addons/'.$addon)) continue;
|
||||
if(($type == "pc" && $val->is_used != 'Y') || ($type == "mobile" && $val->is_used_m != 'Y') || ($gtype == 'global' && $val->is_fixed != 'Y')) continue;
|
||||
if($val->addon == "smartphone")
|
||||
{
|
||||
continue;
|
||||
}
|
||||
if(!is_dir(_XE_PATH_ . 'addons/' . $addon))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
if(($type == "pc" && $val->is_used != 'Y') || ($type == "mobile" && $val->is_used_m != 'Y') || ($gtype == 'global' && $val->is_fixed != 'Y'))
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
$extra_vars = unserialize($val->extra_vars);
|
||||
$mid_list = $extra_vars->mid_list;
|
||||
if(!is_array($mid_list)||!count($mid_list)) $mid_list = null;
|
||||
if(!is_array($mid_list) || !count($mid_list))
|
||||
{
|
||||
$mid_list = NULL;
|
||||
}
|
||||
|
||||
$buff .= '$rm = \'' . $extra_vars->xe_run_method . "';";
|
||||
$buff .= '$ml = array(';
|
||||
|
|
@ -202,11 +234,20 @@ class addonController extends addon
|
|||
|
||||
$buff = sprintf('<?php if(!defined("__XE__")) exit(); $_m = Context::get(\'mid\'); %s ?>', $buff);
|
||||
|
||||
$addon_path = _XE_PATH_.'files/cache/addons/';
|
||||
if(!is_dir($addon_path)) FileHandler::makeDir($addon_path);
|
||||
$addon_path = _XE_PATH_ . 'files/cache/addons/';
|
||||
if(!is_dir($addon_path))
|
||||
{
|
||||
FileHandler::makeDir($addon_path);
|
||||
}
|
||||
|
||||
if($gtype == 'site') $addon_file = $addon_path.$site_srl.$type.'.acivated_addons.cache.php';
|
||||
else $addon_file = $addon_path.$type.'.acivated_addons.cache.php';
|
||||
if($gtype == 'site')
|
||||
{
|
||||
$addon_file = $addon_path . $site_srl . $type . '.acivated_addons.cache.php';
|
||||
}
|
||||
else
|
||||
{
|
||||
$addon_file = $addon_path . $type . '.acivated_addons.cache.php';
|
||||
}
|
||||
|
||||
FileHandler::writeFile($addon_file, $buff);
|
||||
}
|
||||
|
|
@ -220,13 +261,20 @@ class addonController extends addon
|
|||
* @param string $gtype site or global
|
||||
* @return Object
|
||||
*/
|
||||
function doSetup($addon, $extra_vars,$site_srl=0, $gtype = 'site')
|
||||
function doSetup($addon, $extra_vars, $site_srl = 0, $gtype = 'site')
|
||||
{
|
||||
if(!is_array($extra_vars->mid_list)) unset($extra_vars->mid_list);
|
||||
if(!is_array($extra_vars->mid_list))
|
||||
{
|
||||
unset($extra_vars->mid_list);
|
||||
}
|
||||
|
||||
$args = new stdClass();
|
||||
$args->addon = $addon;
|
||||
$args->extra_vars = serialize($extra_vars);
|
||||
if($gtype == 'global') return executeQuery('addon.updateAddon', $args);
|
||||
if($gtype == 'global')
|
||||
{
|
||||
return executeQuery('addon.updateAddon', $args);
|
||||
}
|
||||
$args->site_srl = $site_srl;
|
||||
return executeQuery('addon.updateSiteAddon', $args);
|
||||
}
|
||||
|
|
@ -239,13 +287,18 @@ class addonController extends addon
|
|||
*/
|
||||
function removeAddonConfig($site_srl)
|
||||
{
|
||||
$addon_path = _XE_PATH_.'files/cache/addons/';
|
||||
$addon_file = $addon_path.$site_srl.'.acivated_addons.cache.php';
|
||||
if(file_exists($addon_file)) FileHandler::removeFile($addon_file);
|
||||
$addon_path = _XE_PATH_ . 'files/cache/addons/';
|
||||
$addon_file = $addon_path . $site_srl . '.acivated_addons.cache.php';
|
||||
if(file_exists($addon_file))
|
||||
{
|
||||
FileHandler::removeFile($addon_file);
|
||||
}
|
||||
|
||||
$args = new stdClass();
|
||||
$args->site_srl = $site_srl;
|
||||
executeQuery('addon.deleteSiteAddons', $args);
|
||||
}
|
||||
|
||||
}
|
||||
/* End of file addon.controller.php */
|
||||
/* Location: ./modules/addon/addon.controller.php */
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue