allow_fileupload) $allow_fileupload = false; else $allow_fileupload = true; // 자동 저장 유무 옵션 설정 if(!$option->enable_autosave) $enable_autosave = false; else $enable_autosave = true; // 기본 에디터 컴포넌트 사용 설정 if(!$option->enable_default_component) $enable_default_component = false; else $enable_default_component = true; // 확장 컴포넌트 사용 설정 if(!$option->enable_component) $enable_component = false; else $enable_component = true; // 크기 조절 옵션 설정 if(!$option->resizable) $resizable = 'false'; else $resizable = 'true'; // 높이 설정 if(!$option->height) $editor_height = 400; else $editor_height = $option->height; // 스킨 설정 if(!$option->skin) $skin = 'default'; else $skin = $option->skin; /** * 자동백업 기능 체크 (글 수정일 경우는 사용하지 않음) **/ if(!$upload_target_srl && $enable_autosave) { // 자동 저장된 데이터를 추출 $saved_doc = $this->getSavedDoc(); // 자동저장된 데이터에 실제하는 문서 번호가 있다면 해당 문서 번호를 세팅 if($saved_doc->document_srl) $upload_target_srl = $saved_doc->upload_target_srl; // 자동 저장 데이터를 context setting Context::set('saved_doc', $saved_doc); } Context::set('enable_autosave', $enable_autosave); /** * 에디터의 고유 번호 추출 (한 페이지에 여러개의 에디터를 출력하는 경우를 대비) **/ if($option->editor_sequence) $editor_sequence = $option->editor_sequence; else { if(!$GLOBALS['_editor_sequence_']) $GLOBALS['_editor_sequence_'] = 1; $editor_sequence = $GLOBALS['_editor_sequence_'] ++; } /** * 업로드 활성화시 내부적으로 file 모듈의 환경설정을 이용하여 설정 **/ if($allow_fileupload) { $oFileModel = &getModel('file'); // SWFUploader에 세팅할 업로드 설정 구함 $file_config = $oFileModel->getUploadConfig(); $file_config->attached_size = FileHandler::filesize($file_config->allowed_attach_size*1024*1024); $file_config->allowed_filesize = FileHandler::filesize($file_config->allowed_filesize*1024*1024); Context::set('file_config',$file_config); // 업로드 가능 용량등에 대한 정보를 세팅 $upload_status = $oFileModel->getUploadStatus(); Context::set('upload_status', $upload_status); // upload가능하다고 설정 (내부적으로 캐싱하여 처리) $oFileController = &getController('file'); $oFileController->setUploadInfo($editor_sequence, $upload_target_srl); } Context::set('allow_fileupload', $allow_fileupload); // 에디터 동작을 위한 editor_sequence값 설정 Context::set('editor_sequence', $editor_sequence); // 파일 첨부 관련 행동을 하기 위해 문서 번호를 upload_target_srl로 설정 // 신규문서일 경우 upload_target_srl=0 이고 첨부파일 관련 동작이 요청될때 이 값이 변경됨 Context::set('upload_target_srl', $upload_target_srl); // 문서 혹은 댓글의 primary key값을 세팅한다. Context::set('editor_primary_key_name', $option->primary_key_name); // 내용을 sync 맞추기 위한 content column name을 세팅한다 Context::set('editor_content_key_name', $option->content_key_name); /** * 에디터 컴포넌트 체크 **/ if($enable_component) { if(!Context::get('component_list')) { $component_list = $this->getComponentList(); Context::set('component_list', $component_list); } } Context::set('enable_component', $enable_component); Context::set('enable_default_component', $enable_default_component); /** * resizable 가능한지 변수 설정 **/ Context::set('enable_resizable', $resizable); /** * 에디터 세로 크기 설정 **/ Context::set('editor_height', $editor_height); /** * 템플릿을 미리 컴파일해서 컴파일된 소스를 하기 위해 스킨의 경로를 설정 **/ $tpl_path = sprintf('%sskins/%s/', $this->module_path, $skin); $tpl_file = 'editor.html'; Context::set('editor_path', $tpl_path); // tpl 파일을 compile한 결과를 return $oTemplate = &TemplateHandler::getInstance(); return $oTemplate->compile($tpl_path, $tpl_file); } /** * @brief 자동저장되어 있는 정보를 가져옴 **/ function getSavedDoc() { // 로그인 회원이면 member_srl, 아니면 ipaddress로 저장되어 있는 문서를 찾음 if(Context::get('is_logged')) { $logged_info = Context::get('logged_info'); $auto_save_args->member_srl = $logged_info->member_srl; } else { $auto_save_args->ipaddress = $_SERVER['REMOTE_ADDR']; } // DB에서 자동저장 데이터 추출 $output = executeQuery('editor.getSavedDocument', $auto_save_args); $saved_doc = $output->data; // 자동저장한 결과가 없으면 null값 return if(!$saved_doc) return; // 자동저장 데이터에 문서번호가 있고 이 번호에 파일이 있다면 파일을 모두 이동하고 // 해당 문서 번호를 editor_sequence로 세팅함 if($saved_doc->document_srl) { $module_srl = Context::get('module_srl'); $oFileController = &getController('file'); $oFileController->moveFile($saved_doc->document_srl, $module_srl, $saved_doc->document_srl); } return $saved_doc; } /** * @brief component의 객체 생성 **/ function getComponentObject($component, $editor_sequence = 0) { if(!$this->loaded_component_list[$component][$editor_sequence]) { // 해당 컴포넌트의 객체를 생성해서 실행 $class_path = sprintf('%scomponents/%s/', $this->module_path, $component); $class_file = sprintf('%s%s.class.php', $class_path, $component); if(!file_exists($class_file)) return new Object(-1, sprintf(Context::getLang('msg_component_is_not_founded'), $component)); // 클래스 파일을 읽은 후 객체 생성 require_once($class_file); $eval_str = sprintf('$oComponent = new %s("%s","%s");', $component, $editor_sequence, $class_path); @eval($eval_str); if(!$oComponent) return new Object(-1, sprintf(Context::getLang('msg_component_is_not_founded'), $component)); // 설정 정보를 추가 $component_info = $this->getComponent($component); $oComponent->setInfo($component_info); $this->loaded_component_list[$component][$editor_sequence] = $oComponent; } return $this->loaded_component_list[$component][$editor_sequence]; } /** * @brief component 목록을 return (DB정보 보함) **/ function getComponentList($filter_enabled = true) { if($filter_enabled) $args->enabled = "Y"; $output = executeQuery('editor.getComponentList', $args); $db_list = $output->data; // 파일목록을 구함 $downloaded_list = FileHandler::readDir($this->module_path.'components'); // DB 목록을 loop돌면서 xml정보까지 구함 if(!is_array($db_list)) $db_list = array($db_list); foreach($db_list as $component) { if(in_array($component->component_name, array('colorpicker_text','colorpicker_bg'))) continue; $component_name = $component->component_name; if(!$component_name) continue; if(!in_array($component_name, $downloaded_list)) continue; unset($xml_info); $xml_info = $this->getComponentXmlInfo($component_name); $xml_info->enabled = $component->enabled; if($component->extra_vars && $xml_info->extra_vars) { $extra_vars = unserialize($component->extra_vars); foreach($xml_info->extra_vars as $key => $val) { $xml_info->extra_vars->{$key}->value = $extra_vars->{$key}; } } $component_list->{$component_name} = $xml_info; } // enabled만 체크하도록 하였으면 그냥 return if($filter_enabled) return $component_list; // 다운로드된 목록의 xml_info를 마저 구함 foreach($downloaded_list as $component_name) { if(in_array($component_name, array('colorpicker_text','colorpicker_bg'))) continue; // 설정된 것이라면 패스 if($component_list->{$component_name}) continue; // DB에 입력 $oEditorController = &getAdminController('editor'); $oEditorController->insertComponent($component_name, false); // component_list에 추가 unset($xml_info); $xml_info = $this->getComponentXmlInfo($component_name); $xml_info->enabled = 'N'; $component_list->{$component_name} = $xml_info; } return $component_list; } /** * @brief compnent의 xml+db정보를 구함 **/ function getComponent($component_name) { $args->component_name = $component_name; $output = executeQuery('editor.getComponent', $args); $component = $output->data; $component_name = $component->component_name; unset($xml_info); $xml_info = $this->getComponentXmlInfo($component_name); $xml_info->enabled = $component->enabled; if($component->extra_vars) { $extra_vars = unserialize($component->extra_vars); foreach($xml_info->extra_vars as $key => $val) { $xml_info->extra_vars->{$key}->value = $extra_vars->{$key}; } } return $xml_info; } /** * @brief component의 xml정보를 읽음 **/ function getComponentXmlInfo($component) { $lang_type = Context::getLangType(); // 요청된 컴포넌트의 xml파일 위치를 구함 $component_path = sprintf('%s/components/%s/', $this->module_path, $component); $xml_file = sprintf('%sinfo.xml', $component_path); $cache_file = sprintf('./files/cache/editor/%s.%s.php', $component, $lang_type); // 캐시된 xml파일이 있으면 include 후 정보 return if(file_exists($cache_file) && file_exists($xml_file) && filemtime($cache_file) > filemtime($xml_file)) { include($cache_file); return $xml_info; } // 캐시된 파일이 없으면 파싱후 캐싱 후 return $oParser = new XmlParser(); $xml_doc = $oParser->loadXmlFile($xml_file); // 정보 정리 $xml_info->component_name = $component; $xml_info->version = $xml_doc->component->attrs->version; $xml_info->title = $xml_doc->component->title->body; $xml_info->author->name = $xml_doc->component->author->name->body; $xml_info->author->email_address = $xml_doc->component->author->attrs->email_address; $xml_info->author->link = $xml_doc->component->author->attrs->link; $xml_info->author->date = $xml_doc->component->author->attrs->date; $xml_info->description = str_replace('\n', "\n", $xml_doc->component->author->description->body); $buff = 'component_name = "%s";', $component); $buff .= sprintf('$xml_info->version = "%s";', $xml_info->version); $buff .= sprintf('$xml_info->title = "%s";', $xml_info->title); $buff .= sprintf('$xml_info->author->name = "%s";', $xml_info->author->name); $buff .= sprintf('$xml_info->author->email_address = "%s";', $xml_info->author->email_address); $buff .= sprintf('$xml_info->author->link = "%s";', $xml_info->author->link); $buff .= sprintf('$xml_info->author->date = "%s";', $xml_info->author->date); $buff .= sprintf('$xml_info->description = "%s";', $xml_info->description); // 추가 변수 정리 (에디터 컴포넌트에서는 text형만 가능) $extra_vars = $xml_doc->component->extra_vars->var; if($extra_vars) { if(!is_array($extra_vars)) $extra_vars = array($extra_vars); foreach($extra_vars as $key => $val) { unset($obj); $key = $val->attrs->name; $title = $val->title->body; $description = $val->description->body; $xml_info->extra_vars->{$key}->title = $title; $xml_info->extra_vars->{$key}->description = $description; $buff .= sprintf('$xml_info->extra_vars->%s->%s = "%s";', $key, 'title', $title); $buff .= sprintf('$xml_info->extra_vars->%s->%s = "%s";', $key, 'description', $description); } } $buff .= ' ?>'; FileHandler::writeFile($cache_file, $buff, "w"); return $xml_info; } } ?>