diff --git a/modules/importer/conf/info.xml b/modules/importer/conf/info.xml new file mode 100644 index 000000000..aff460280 --- /dev/null +++ b/modules/importer/conf/info.xml @@ -0,0 +1,10 @@ + + + XML Importer + + 제로 + + XML파일을 이용하여 회원정보 또는 게시판등의 데이터를 입력합니다. + + + diff --git a/modules/importer/conf/module.xml b/modules/importer/conf/module.xml new file mode 100644 index 000000000..a65b3b133 --- /dev/null +++ b/modules/importer/conf/module.xml @@ -0,0 +1,8 @@ + + + + + + + + diff --git a/modules/importer/importer.class.php b/modules/importer/importer.class.php new file mode 100644 index 000000000..4e29bba1c --- /dev/null +++ b/modules/importer/importer.class.php @@ -0,0 +1,32 @@ + diff --git a/modules/importer/importer.view.class b/modules/importer/importer.view.class new file mode 100644 index 000000000..64b03b6fd --- /dev/null +++ b/modules/importer/importer.view.class @@ -0,0 +1,569 @@ +act, 'Admin')) $this->initAdmin(); + else $this->initNormal(); + } + + /** + * @brief 관리자 act 호출시에 관련 정보들 세팅해줌 + **/ + function initAdmin() { + // module_srl이 있으면 미리 체크하여 존재하는 모듈이면 module_info 세팅 + $module_srl = Context::get('module_srl'); + if(!$module_srl && $this->module_srl) { + $module_srl = $this->module_srl; + Context::set('module_srl', $module_srl); + } + + // module model 객체 생성 + $oModuleModel = &getModel('module'); + + // module_srl이 넘어오면 해당 모듈의 정보를 미리 구해 놓음 + if($module_srl) { + $module_info = $oModuleModel->getModuleInfoByModuleSrl($module_srl); + if($module_info->module_srl == $module_srl) { + $this->module_info = $module_info; + Context::set('module_info',$module_info); + } + } + + // 모듈 카테고리 목록을 구함 + $module_category = $oModuleModel->getModuleCategories(); + Context::set('module_category', $module_category); + + // 만약 블로그 서비스 페이지에서 관리자 기능 호출시 관련 정보를 위해서 initNoraml() method 호출 + if($this->mid) $this->initNormal(); + + // 템플릿 경로 지정 (blog의 경우 tpl에 관리자용 템플릿 모아놓음) + $this->setTemplatePath($this->module_path."tpl"); + } + + /** + * @brief 일반 블로그 호출시에 관련 정보를 세팅해줌 + **/ + function initNormal() { + // 템플릿에서 사용할 변수를 Context::set() + if($this->module_srl) Context::set('module_srl',$this->module_srl); + + // 기본 모듈 정보들 설정 + $this->list_count = $this->module_info->list_count?$this->module_info->list_count:1; + $this->page_count = $this->module_info->page_count?$this->module_info->page_count:10; + + // 카테고리 목록을 가져오고 선택된 카테고리의 값을 설정 + $oDocumentModel = &getModel('document'); + $this->category_list = $oDocumentModel->getCategoryList($this->module_srl); + Context::set('category_list', $this->category_list); + + // 선택된 카테고리 목록이 있으면 zbxe_url을 변경하여 트리메뉴에서 카테고리까지 참조할 수 있도록 함 + $category_srl = Context::get('category'); + if($this->category_list[$category_srl]) { + $this->category_srl = $category_srl; + Context::set('zbxe_url', sprintf("mid=%s&category=%d", $this->module_info->mid, $this->category_srl)); + } + + // 스킨 경로 구함 + $template_path = sprintf("%sskins/%s/",$this->module_path, $this->skin); + $this->setTemplatePath($template_path); + + // rss url + if($this->module_info->open_rss != 'N') Context::set('rss_url', getUrl('','mid',$this->mid,'act','dispRss')); + + // 레이아웃의 정보를 속이기 위해서 layout_srl을 현 블로그의 module_srl로 입력 + $this->module_info->layout_srl = $this->module_info->module_srl; + + /** + * 블로그는 자체 레이아웃을 관리하기에 이와 관련된 세팅을 해줌 + **/ + // 레이아웃 경로와 파일 지정 (블로그는 자체 레이아웃을 가지고 있음) + $this->setLayoutPath($template_path); + $this->setLayoutFile("layout"); + + // 수정된 레이아웃 파일이 있으면 지정 + $edited_layout = sprintf('./files/cache/layout/%d.html', $this->module_info->module_srl); + if(file_exists($edited_layout)) $this->setEditedLayoutFile($edited_layout); + + // 카테고리 xml 파일 위치 지정 + $this->module_info->category_xml_file = sprintf('./files/cache/blog_category/%d.xml.php', $this->module_info->module_srl); + + // 메뉴 등록시 메뉴 정보를 구해옴 + if($this->module_info->menu) { + foreach($this->module_info->menu as $menu_id => $menu_srl) { + $menu_php_file = sprintf("./files/cache/menu/%s.php", $menu_srl); + if(file_exists($menu_php_file)) @include($menu_php_file); + Context::set($menu_id, $menu); + } + } + + // layout_info 변수 설정 + Context::set('layout_info',$this->module_info); + + // 모듈정보 세팅 + Context::set('module_info',$this->module_info); + } + + /** + * @brief 목록 및 선택된 글 출력 + **/ + function dispBlogContent() { + // 권한 체크 + if(!$this->grant->list) return $this->dispBlogMessage('msg_not_permitted'); + + // 목록 구현에 필요한 변수들을 가져온다 + $document_srl = Context::get('document_srl'); + $page = Context::get('page'); + + // document 객체를 생성. 기본 데이터 구조의 경우 document모듈만 쓰면 만사 해결.. -_-; + $oDocumentModel = &getModel('document'); + + // document_srl이 있다면 해당 글을 구해오자 + if($this->grant->list && $document_srl) { + + // 글을 구함 + $document = $oDocumentModel->getDocument($document_srl, $this->grant->manager, true); + + // 찾아지지 않았다면 초기화 + if($document->document_srl != $document_srl) { + unset($document); + unset($document_srl); + Context::set('document_srl','',true); + + // 글이 찾아졌으면 댓글 권한과 허용 여부를 체크 + } elseif($this->grant->write_comment && $document->allow_comment == 'Y' && $document->lock_comment != 'Y') { + // 브라우저 타이틀 + $browser_title = $this->module_info->browser_title.' - '.$document->title; + Context::setBrowserTitle($browser_title); + } + + Context::set('document', $document); + } + + // 만약 document_srl은 있는데 page가 없다면 글만 호출된 경우 page를 구해서 세팅해주자.. + if($document_srl && !$page) { + $page = $oDocumentModel->getDocumentPage($document_srl, $this->module_srl, $this->list_count); + Context::set('page', $page); + } + + // 목록을 구하기 위한 옵션 + $args->module_srl = $this->module_srl; ///< 현재 모듈의 module_srl + $args->page = $page; ///< 페이지 + $args->list_count = $this->list_count; ///< 한페이지에 보여줄 글 수 + $args->page_count = $this->page_count; ///< 페이지 네비게이션에 나타날 페이지의 수 + + // 검색 옵션 + $args->search_target = trim(Context::get('search_target')); ///< 검색대상 + $args->search_keyword = trim(Context::get('search_keyword')); ///< 검색어 + + // 키워드 검색이 아닌 검색일 경우 목록의 수를 40개로 고정 + if($args->search_target && $args->search_keyword) $args->list_count = 40; + + // 키워드 검색의 경우 제목,내용으로 검색 대상 고정 + if($args->search_keyword && !$args->search_target) $args->search_target = "title_content"; + + // 블로그 카테고리 + $args->category_srl = $this->category_srl; + + $args->sort_index = 'list_order'; ///< 소팅 값 + + // 목록 구함, document->getDocumentList 에서 걍 알아서 다 해버리는 구조 + $output = $oDocumentModel->getDocumentList($args, true); + + // 템플릿에 쓰기 위해서 document_model::getDocumentList() 의 return object에 있는 값들을 세팅 + Context::set('total_count', $output->total_count); + Context::set('total_page', $output->total_page); + Context::set('page', $output->page); + Context::set('document_list', $output->data); + Context::set('page_navigation', $output->page_navigation); + + // 템플릿에서 사용할 검색옵션 세팅 + $count_search_option = count($this->search_option); + for($i=0;$i<$count_search_option;$i++) { + $search_option[$this->search_option[$i]] = Context::getLang($this->search_option[$i]); + } + Context::set('search_option', $search_option); + + // 블로그의 코멘트는 ajax로 호출되기에 미리 css, js파일을 import + Context::addJsFile('./modules/editor/tpl/js/editor.js'); + Context::addCSSFile('./modules/editor/tpl/css/editor.css'); + + $this->setTemplateFile('list'); + } + + /** + * @brief 글 작성 화면 출력 + **/ + function dispBlogWrite() { + // 권한 체크 + if(!$this->grant->write_document) return $this->dispBlogMessage('msg_not_permitted'); + + // GET parameter에서 document_srl을 가져옴 + $document_srl = Context::get('document_srl'); + + // document 모듈 객체 생성 + $oDocumentModel = &getModel('document'); + + // 지정된 글이 없다면 (신규) 새로운 번호를 만든다 + if($document_srl) { + $document = $oDocumentModel->getDocument($document_srl, $this->grant->manager); + if(!$document) { + unset($document_srl); + Context::set('document_srl',''); + } + } + + if(!$document_srl) $document_srl = getNextSequence(); + + // 글을 수정하려고 할 경우 권한이 없는 경우 비밀번호 입력화면으로 + if($document&&!$document->is_granted) return $this->setTemplateFile('input_password_form'); + + Context::set('document_srl',$document_srl); + Context::set('document', $document); + + // 에디터 모듈의 getEditor를 호출하여 세팅 + $oEditorModel = &getModel('editor'); + $editor = $oEditorModel->getEditor($document_srl, $this->grant->fileupload, true); + Context::set('editor', $editor); + + $this->setTemplateFile('write_form'); + } + + /** + * @brief 문서 삭제 화면 출력 + **/ + function dispBlogDelete() { + // 권한 체크 + if(!$this->grant->write_document) return $this->dispBlogMessage('msg_not_permitted'); + + // 삭제할 문서번호를 가져온다 + $document_srl = Context::get('document_srl'); + + // 지정된 글이 있는지 확인 + if($document_srl) { + $oDocumentModel = &getModel('document'); + $document = $oDocumentModel->getDocument($document_srl); + } + + // 삭제하려는 글이 없으면 에러 + if(!$document) return $this->dispBlogContent(); + + // 권한이 없는 경우 비밀번호 입력화면으로 + if($document&&!$document->is_granted) return $this->setTemplateFile('input_password_form'); + + Context::set('document',$document); + + $this->setTemplateFile('delete_form'); + } + + /** + * @brief 댓글의 답글 화면 출력 + **/ + function dispBlogReplyComment() { + // 권한 체크 + if(!$this->grant->write_comment) return $this->dispBlogMessage('msg_not_permitted'); + + // 목록 구현에 필요한 변수들을 가져온다 + $document_srl = Context::get('document_srl'); + $parent_srl = Context::get('comment_srl'); + + // 지정된 원 댓글이 없다면 오류 + if(!$parent_srl) return new Object(-1, 'msg_invalid_request'); + + // 해당 댓글를 찾아본다 + $oCommentModel = &getModel('comment'); + $source_comment = $oCommentModel->getComment($parent_srl, $this->grant->manager); + + // 댓글이 없다면 오류 + if(!$source_comment) return $this->dispBlogMessage('msg_invalid_request'); + + // 필요한 정보들 세팅 + Context::set('document_srl',$document_srl); + Context::set('parent_srl',$parent_srl); + Context::set('comment_srl',NULL); + Context::set('source_comment',$source_comment); + + // 댓글 에디터 세팅 + $this->setCommentEditor(); + + $this->setTemplateFile('comment_form'); + } + + /** + * @brief 댓글 수정 폼 출력 + **/ + function dispBlogModifyComment() { + // 권한 체크 + if(!$this->grant->write_comment) return $this->dispBlogMessage('msg_not_permitted'); + + // 목록 구현에 필요한 변수들을 가져온다 + $document_srl = Context::get('document_srl'); + $comment_srl = Context::get('comment_srl'); + + // 지정된 댓글이 없다면 오류 + if(!$comment_srl) return new Object(-1, 'msg_invalid_request'); + + // 해당 댓글를 찾아본다 + $oCommentModel = &getModel('comment'); + $comment = $oCommentModel->getComment($comment_srl, $this->grant->manager); + + // 댓글이 없다면 오류 + if(!$comment) return $this->dispBlogMessage('msg_invalid_request'); + + // 글을 수정하려고 할 경우 권한이 없는 경우 비밀번호 입력화면으로 + if($comment_srl&&$comment&&!$comment->is_granted) return $this->setTemplateFile('input_password_form'); + + // 필요한 정보들 세팅 + Context::set('document_srl',$document_srl); + Context::set('comment_srl',$comment_srl); + Context::set('comment', $comment); + + // 댓글 에디터 세팅 + $this->setCommentEditor($comment_srl); + + $this->setTemplateFile('comment_form'); + } + + /** + * @brief 댓글 삭제 화면 출력 + **/ + function dispBlogDeleteComment() { + // 권한 체크 + if(!$this->grant->write_comment) return $this->dispBlogMessage('msg_not_permitted'); + + // 삭제할 댓글번호를 가져온다 + $comment_srl = Context::get('comment_srl'); + + // 삭제하려는 댓글가 있는지 확인 + if($comment_srl) { + $oCommentModel = &getModel('comment'); + $comment = $oCommentModel->getComment($comment_srl, $this->grant->manager); + } + + // 삭제하려는 글이 없으면 에러 + if(!$comment) return $this->dispBlogContent(); + + // 권한이 없는 경우 비밀번호 입력화면으로 + if($comment_srl&&$comment&&!$comment->is_granted) return $this->setTemplateFile('input_password_form'); + + Context::set('comment',$comment); + + $this->setTemplateFile('delete_comment_form'); + } + + /** + * @brief 엮인글 삭제 화면 출력 + **/ + function dispBlogDeleteTrackback() { + // 삭제할 댓글번호를 가져온다 + $trackback_srl = Context::get('trackback_srl'); + + // 삭제하려는 댓글가 있는지 확인 + $oTrackbackModel = &getModel('trackback'); + $output = $oTrackbackModel->getTrackback($trackback_srl); + $trackback = $output->data; + + // 삭제하려는 글이 없으면 에러 + if(!$trackback) return $this->dispBlogContent(); + + Context::set('trackback',$trackback); + + $this->setTemplateFile('delete_trackback_form'); + } + + /** + * @brief 메세지 출력 + **/ + function dispBlogMessage($msg_code) { + $msg = Context::getLang($msg_code); + if(!$msg) $msg = $msg_code; + Context::set('message', $msg); + $this->setTemplateFile('message'); + } + + /** + * @brief 댓글의 editor 를 세팅 + * 댓글의 경우 수정하는 경우가 아니라면 고유값이 없음.\n + * 따라서 고유값이 없을 경우 고유값을 가져와서 지정해 주어야 함 + **/ + function setCommentEditor($comment_srl=0) { + if(!$comment_srl) { + $comment_srl = getNextSequence(); + Context::set('comment_srl', $comment_srl); + } + + // 에디터 모듈의 getEditor를 호출하여 세팅 + $oEditorModel = &getModel('editor'); + $comment_editor = $oEditorModel->getEditor($comment_srl, $this->grant->fileupload); + Context::set('comment_editor', $comment_editor); + } + + /** + * @brief 블로그 관리 목록 보여줌 + **/ + function dispBlogAdminContent() { + // 등록된 blog 모듈을 불러와 세팅 + $args->sort_index = "module_srl"; + $args->page = Context::get('page'); + $args->list_count = 40; + $args->page_count = 10; + $args->s_module_category_srl = Context::get('module_category_srl'); + $output = executeQuery('blog.getBlogList', $args); + + // 템플릿에 쓰기 위해서 context::set + Context::set('total_count', $output->total_count); + Context::set('total_page', $output->total_page); + Context::set('page', $output->page); + Context::set('blog_list', $output->data); + Context::set('page_navigation', $output->page_navigation); + + // 템플릿 파일 지정 + $this->setTemplateFile('index'); + } + + /** + * @brief 선택된 블로그의 정보 출력 + **/ + function dispBlogAdminBlogInfo() { + + // module_srl 값이 없다면 그냥 index 페이지를 보여줌 + if(!Context::get('module_srl')) return $this->dispBlogAdminContent(); + + // 레이아웃이 정해져 있다면 레이아웃 정보를 추가해줌(layout_title, layout) + if($this->module_info->layout_srl) { + $oLayoutModel = &getModel('layout'); + $layout_info = $oLayoutModel->getLayout($this->module_info->layout_srl); + $this->module_info->layout = $layout_info->layout; + $this->module_info->layout_title = $layout_info->layout_title; + } + + // 정해진 스킨이 있으면 해당 스킨의 정보를 구함 + if($this->module_info->skin) { + $oModuleModel = &getModel('module'); + $skin_info = $oModuleModel->loadSkinInfo($this->module_path, $this->module_info->skin); + $this->module_info->skin_title = $skin_info->title; + } + + // 템플릿 파일 지정 + $this->setTemplateFile('blog_info'); + } + + /** + * @brief 블로그 추가 폼 출력 + **/ + function dispBlogAdminInsertBlog() { + + // 스킨 목록을 구해옴 + $oModuleModel = &getModel('module'); + $skin_list = $oModuleModel->getSkins($this->module_path); + Context::set('skin_list',$skin_list); + + // 템플릿 파일 지정 + $this->setTemplateFile('blog_insert'); + } + + /** + * @brief 블로그 삭제 화면 출력 + **/ + function dispBlogAdminDeleteBlog() { + + if(!Context::get('module_srl')) return $this->dispBlogAdminContent(); + + $module_info = Context::get('module_info'); + + $oDocumentModel = &getModel('document'); + $document_count = $oDocumentModel->getDocumentCount($module_info->module_srl); + $module_info->document_count = $document_count; + + Context::set('module_info',$module_info); + + // 템플릿 파일 지정 + $this->setTemplateFile('blog_delete'); + } + + /** + * @brief 스킨 정보 보여줌 + **/ + function dispBlogAdminSkinInfo() { + + // 현재 선택된 모듈의 스킨의 정보 xml 파일을 읽음 + $module_info = Context::get('module_info'); + $skin = $module_info->skin; + + $oModuleModel = &getModel('module'); + $skin_info = $oModuleModel->loadSkinInfo($this->module_path, $skin); + + // skin_info에 extra_vars 값을 지정 + if(count($skin_info->extra_vars)) { + foreach($skin_info->extra_vars as $key => $val) { + $name = $val->name; + $type = $val->type; + $value = $module_info->{$name}; + if($type=="checkbox"&&!$value) $value = array(); + $skin_info->extra_vars[$key]->value= $value; + } + } + + // skin_info에 menu값을 지정 + if(count($skin_info->menu)) { + foreach($skin_info->menu as $key => $val) { + if($module_info->{$key}) $skin_info->menu->{$key}->menu_srl = $module_info->{$key}; + } + } + + // 메뉴를 가져옴 + $oMenuModel = &getModel('menu'); + $menu_list = $oMenuModel->getMenus(); + Context::set('menu_list', $menu_list); + + Context::set('skin_info', $skin_info); + $this->setTemplateFile('skin_info'); + } + + /** + * @brief 카테고리의 정보 출력 + **/ + function dispBlogAdminCategoryInfo() { + // module_srl을 구함 + $module_srl = $this->module_info->module_srl; + + // 카테고리 정보를 가져옴 + $oBlogModel = &getModel('blog'); + $category_info = $oBlogModel->getCategory($module_srl); + + Context::set('category_info', $category_info); + Context::addJsFile('./common/js/tree_menu.js'); + + $this->setTemplateFile('category_list'); + } + + /** + * @brief 권한 목록 출력 + **/ + function dispBlogAdminGrantInfo() { + // module_srl을 구함 + $module_srl = Context::get('module_srl'); + + // module.xml에서 권한 관련 목록을 구해옴 + $grant_list = $this->xml_info->grant; + Context::set('grant_list', $grant_list); + + // 권한 그룹의 목록을 가져온다 + $oMemberModel = &getModel('member'); + $group_list = $oMemberModel->getGroups(); + Context::set('group_list', $group_list); + + $this->setTemplateFile('grant_list'); + } + } +?>