Support installing/updating namespaced modules

모듈 설치 및 업데이트 메소드를 Rhymix\Modules\모듈명\Install 클래스에
넣을 수 있도록 지원한다. 이 클래스가 있는 경우 모듈명과 동일한 클래스를
찾지 않는다. 이로써 클래스 전체를 네임스페이스화할 수 있게 되었다.
This commit is contained in:
Kijin Sung 2022-01-04 01:37:38 +09:00
parent adbd29231f
commit f334889047
5 changed files with 38 additions and 19 deletions

View file

@ -153,12 +153,8 @@ class ModuleInstaller
{
$path_array = explode("/", $this->package->path);
$target_name = array_pop($path_array);
$oModule = getModule($target_name, "class");
if(!$oModule)
{
return new BaseObject(-1, 'msg_invalid_request');
}
if(!method_exists($oModule, "moduleUninstall"))
$oModule = ModuleModel::getModuleInstallClass($target_name);
if(!$oModule || !method_exists($oModule, 'moduleUninstall'))
{
return new BaseObject(-1, 'msg_invalid_request');
}
@ -203,16 +199,15 @@ class ModuleInstaller
if($type == "module")
{
$oModuleModel = getModel('module');
$oInstallController = getController('install');
$module_path = ModuleHandler::getModulePath($target_name);
if($oModuleModel->checkNeedInstall($target_name))
if(ModuleModel::checkNeedInstall($target_name))
{
$oInstallController->installModule($target_name, $module_path);
}
if($oModuleModel->checkNeedUpdate($target_name))
if(ModuleModel::checkNeedUpdate($target_name))
{
$oModule = getModule($target_name, 'class');
$oModule = ModuleModel::getModuleInstallClass($target_name);
if(method_exists($oModule, 'moduleUpdate'))
{
$oModule->moduleUpdate();

View file

@ -316,7 +316,7 @@ class autoinstallModel extends autoinstall
{
$path_array = explode("/", $path);
$target_name = array_pop($path_array);
$oModule = getModule($target_name, "class");
$oModule = ModuleModel::getModuleInstallClass($target_name);
if(!$oModule)
{
return FALSE;

View file

@ -38,8 +38,11 @@ class installAdminController extends install
$module_name = Context::get('module_name');
if(!$module_name) throw new Rhymix\Framework\Exceptions\InvalidRequest;
$oModule = getModule($module_name, 'class');
if(!$oModule) throw new Rhymix\Framework\Exceptions\InvalidRequest;
$oModule = ModuleModel::getModuleInstallClass($module_name);
if(!$oModule || !method_exists($oModule, 'moduleUpdate'))
{
throw new Rhymix\Framework\Exceptions\InvalidRequest;
}
Rhymix\Framework\Session::close();

View file

@ -472,7 +472,7 @@ class installController extends install
}
// Install "module" module in advance
$this->installModule('module','./modules/module');
$oModule = getClass('module');
$oModule = ModuleModel::getModuleInstallClass($module);
if($oModule->checkUpdate()) $oModule->moduleUpdate();
// Determine the order of module installation depending on category
$install_step = array('system','content','member');
@ -486,7 +486,7 @@ class installController extends install
if($module == 'module') continue;
$this->installModule($module, sprintf('./modules/%s', $module));
$oModule = getClass($module);
$oModule = ModuleModel::getModuleInstallClass($module);
if(is_object($oModule) && method_exists($oModule, 'checkUpdate'))
{
if($oModule->checkUpdate()) $oModule->moduleUpdate();
@ -507,7 +507,7 @@ class installController extends install
if($module == 'module') continue;
$this->installModule($module, sprintf('./modules/%s', $module));
$oModule = getClass($module);
$oModule = ModuleModel::getModuleInstallClass($module);
if($oModule && method_exists($oModule, 'checkUpdate') && method_exists($oModule, 'moduleUpdate'))
{
if($oModule->checkUpdate()) $oModule->moduleUpdate();
@ -555,7 +555,7 @@ class installController extends install
}
// Create a table and module instance and then execute install() method
unset($oModule);
$oModule = getClass($module);
$oModule = ModuleModel::getModuleInstallClass($module);
if(method_exists($oModule, 'moduleInstall')) $oModule->moduleInstall();
return new BaseObject();
}

View file

@ -1375,6 +1375,27 @@ class moduleModel extends module
return $list;
}
/**
* Get module install class
*
* This method supports namespaced modules as well as XE-compatible modules.
*
* @param string $module_name
* @return ModuleObject|null
*/
public static function getModuleInstallClass(string $module_name)
{
$class_name = 'Rhymix\\Modules\\' . ucfirst($module_name) . '\\Install';
if (class_exists($class_name))
{
return $class_name::getInstance();
}
elseif ($oModule = getModule($module_name, 'class'))
{
return $oModule;
}
}
public static function checkNeedInstall($module_name)
{
$oDB = &DB::getInstance();
@ -1402,7 +1423,7 @@ class moduleModel extends module
public static function checkNeedUpdate($module_name)
{
// Check if it is upgraded to module.class.php on each module
$oDummy = getModule($module_name, 'class');
$oDummy = self::getModuleInstallClass($module_name);
if($oDummy && method_exists($oDummy, "checkUpdate"))
{
return $oDummy->checkUpdate();
@ -1502,7 +1523,7 @@ class moduleModel extends module
}
// Check if it is upgraded to module.class.php on each module
$oDummy = getModule($module_name, 'class');
$oDummy = self::getModuleInstallClass($module_name);
if($oDummy && method_exists($oDummy, "checkUpdate"))
{
$info->need_update = $oDummy->checkUpdate();