git-svn-id: http://xe-core.googlecode.com/svn/trunk@151 201d5d3c-b55e-5fd7-737f-ddc643e51545

This commit is contained in:
zero 2007-02-22 01:42:15 +00:00
parent c5867a7706
commit b293901543
5 changed files with 29 additions and 21 deletions

View file

@ -18,6 +18,13 @@
* @brief 모듈객체를 받아서 content 출력
**/
function printContent(&$oModule) {
// 모듈이 정상적이지 않으면 system message 출력
if(!is_object($oModule)) {
$oModule = &getView('message');
Context::set('system_message', Context::getLang('msg_invalid_request_module'));
}
// header 출력
$this->_printHeader();

View file

@ -2,14 +2,12 @@
/**
* @class ModuleHandler
* @author zero (zero@nzeo.com)
* @brief mid의 값으로 모듈을 찾아 객체 생성 & 모듈 정보 세팅
* @brief 모듈 핸들링을 위한 Handler
*
* ModuleHandler는 RequestArgument중 $mid 값을 이용하여\n
* 모듈을 찾아서 객체를 생성한다.\n
* act 값을 이용하여 actType(view, controller) 판단하여\n
* 객체를 생성해야 한다.\n
* 그리고 $mid값을 이용 해당 모듈의 config를 읽어와 생성된\n
* 모듈 객체에 전달하고 실행까지 진행을 한다.
* 모듈을 실행시키기 위한 클래스.
* constructor에 아무 인자 없이 객체를 생성하면 현재 요청받은
* 상태를 바탕으로 적절한 모듈을 찾게 되고,
* 별도의 인자 값을 경우 그에 맞는 모듈을 찾아서 실행한다.
**/
class ModuleHandler extends Handler {
@ -23,10 +21,14 @@
var $module_info = NULL; ///< 모듈의 정보
var $check_standalone = false; ///< 요청된 모듈의 standalone을 체크할 것인지에 설정
/**
* @brief constructor
*
* ModuleHandler에서 사용할 변수를 미리 세팅
* 인자를 넘겨주지 않으면 페이지 요청받은 Request Arguments를 이용하여
* 변수를 세팅한다.
**/
function ModuleHandler($module = '', $act = '', $mid = '', $document_srl = '') {
// Request Argument중 모듈을 찾을 수 있는 변수를 구함
@ -43,14 +45,16 @@
else $this->document_srl = $document_srl;
// 설치가 안되어 있다면 install module을 지정
if(!Context::isInstalled()) return $this->module = 'install';
if(!Context::isInstalled()) $this->module = 'install';
}
/**
* @brief
* module, mid, document_srl을 이용하여 모듈을 찾고 act를 실행하기 위한 준비를
* @brief module, mid, document_srl을 이용하여 모듈을 찾고 act를 실행하기 위한 준비를
**/
function init() {
// 일반적인 요청으로 간주 standalone를 체크하도록 설정
$this->check_standalone = true;
// ModuleModel 객체 생성
$oModuleModel = &getModel('module');
@ -85,7 +89,7 @@
/**
* @brief 모듈과 관련된 정보를 이용하여 객체를 구하고 act 실행까지 진행시킴
**/
function getModule() {
function procModule() {
// $module이 세팅되어 있지 않다면 return NULL, 이럴 경우가 없어야 함
if(!$this->module) return;
@ -96,14 +100,11 @@
$xml_info = $oModuleModel->getModuleXmlInfo($this->module);
// module_info가 없고(mid가 없다는 의미) standalone이 false이면 오류 표시
// @todo standalone에 대해 조금 더 고민 필요
/*
if(!$this->module_info && !$xml_info->standalone) {
if($this->check_standalone && !$this->mid && !$xml_info->standalone) {
$this->module = 'message';
Context::set('system_message', Context::getLang('msg_invalid_request_module'));
$xml_info = $oModuleModel->getModuleXmlInfo($module);
$xml_info = $oModuleModel->getModuleXmlInfo($this->module);
}
*/
// 현재 요청된 act가 있으면 $xml_info에서 type을 찾음, 없다면 기본 action을 이용
if(!$this->act || !$xml_info->action->{$this->act}) $this->act = $xml_info->default_action;
@ -114,6 +115,7 @@
// 모듈 객체 생성
$oModule = &$this->getModuleInstance($this->module, $type);
if(!is_object($oModule)) return;
// 모듈에 act값을 세팅
$oModule->setAct($this->act);
@ -121,8 +123,6 @@
// 모듈 정보 세팅
$oModule->setModuleInfo($this->module_info, $xml_info);
if(!is_object($oModule)) return;
$oModule->proc();
return $oModule;

View file

@ -10,7 +10,8 @@
var $mid = NULL; ///< module로 생성한 instance(관리상)의 값
var $module = NULL; ///< mid로 찾아서 생성한 모듈 class 이름
var $module_srl = NULL; ///< 모듈 객체의 고유값인 module_srl
var $module_info = NULL; ///< 모듈의 정보
var $module_info = NULL; ///< 모듈의 설정 정보
var $xml_info = NULL; ///< 모듈 자체 정보
var $module_path = NULL; ///< 모듈 class file의 실행 위치

View file

@ -42,7 +42,7 @@
**/
$oModuleHandler = new ModuleHandler();
$oModuleHandler->init();
$oModule = &$oModuleHandler->getModule();
$oModule = &$oModuleHandler->procModule();
/**
* @brief DisplayHandler 객체를 생성하여 모듈의 처리 결과를 출력

View file

@ -45,7 +45,7 @@
// 있다면 해당 모듈의 xml_info를 구함
if($sid) {
$oModuleHandler = new ModuleHandler($sid, $act);
$oModule = &$oModuleHandler->getModule();
$oModule = &$oModuleHandler->procModule();
// 내용을 요청받은 모듈의 것으로 변경
$this->setTemplatePath($oModule->getTemplatePath());