* @desc : 기본 모듈중의 하나인 board module * Module class에서 상속을 받아서 사용 * action 의 경우 disp/proc 2가지만 존재하며 이는 action명세서에 * 미리 기록을 하여야 함 **/ class board extends Module { /** * 기본 action 지정 * $act값이 없거나 잘못된 값이 들어올 경우 $default_act 값으로 진행 **/ var $default_act = 'dispContent'; // 검색 옵션 var $search_option = array('title','content','title_content','user_name'); // 모듈에서 사용할 변수들 var $skin = "default"; var $list_count = 3; var $page_count = 10; var $category_list = NULL; // 권한의 종류를 미리 설정 var $grant_list = array( 'list', 'view', 'write_document', 'write_comment', 'fileupload', ); // 에디터 var $editor = 'default'; /** * 현재 모듈의 초기화를 위한 작업을 지정해 놓은 method * css/js파일의 load라든지 lang파일 load등을 미리 선언 * * Init() => 공통 * dispInit() => disp시에 * procInit() => proc시에 * * $this->module_path는 현재 이 모듈파일의 위치를 나타낸다 * (ex: $this->module_path = "./modules/system_install/"; **/ // 초기화 function init() {/*{{{*/ // lang Context::loadLang($this->template_path.'lang/'); }/*}}}*/ // disp 초기화 function dispInit() {/*{{{*/ // 카테고리를 사용한다면 카테고리 목록을 구해옴 if($this->module_info->use_category=='Y') { $oDocument = getModule('document'); $this->category_list = $oDocument->getCategoryList($this->module_srl); Context::set('category_list', $this->category_list); } // 에디터 세팅 Context::set('editor', $this->editor); $editor_path = sprintf("./editor/%s/", $this->editor); Context::set('editor_path', $editor_path); Context::loadLang($editor_path); return true; }/*}}}*/ // proc 초기화 function procInit() {/*{{{*/ // 파일 업로드일 경우 $act값을 procUploadFile() 로 변경 if(Context::isUploaded() && $this->grant->fileupload) $this->act = 'procUploadFile'; return true; }/*}}}*/ /** * 여기서부터는 action의 구현 * request parameter의 경우 각 method의 첫번째 인자로 넘어온다 * * dispXXXX : 출력을 위한 method, output에 tpl file이 지정되어야 한다 * procXXXX : 처리를 위한 method, output에는 error, message가 지정되어야 한다 **/ // 출력 부분 function dispContent() {/*{{{*/ // 권한 체크 if(!$this->grant->list) return $this->dispMessage('msg_not_permitted'); // 목록 구현에 필요한 변수들을 가져온다 $document_srl = Context::get('document_srl'); $page = Context::get('page'); // document 객체를 생성. 기본 데이터 구조의 경우 document모듈만 쓰면 만사 해결.. -_-; $oDocument = getModule('document'); // document_srl이 있다면 해당 글을 구해오자 if($this->grant->view && $document_srl) { $document = $oDocument->getDocument($document_srl); // 글이 찾아지지 않으면 무효화 if(!$document) { Context::set('document_srl',''); $document_srl = NULL; unset($document); } } // 글이 찾아지면 조회수 업데이트 및 기타 등등 if($document) { // 비밀글이고 권한이 없을 경우 인증페이지로 if($document->is_secret=='Y' && !$document->is_granted) return $this->setTemplateFile('input_password_form'); // 조회수 업데이트 if($oDocument->updateReadedCount($document_srl)) $document->readed_count++; // 댓글 가져오기 if($document->comment_count && $document->allow_comment == 'Y') { $oComment = getModule('comment'); $comment_list = $oComment->getCommentList($document_srl); Context::set('comment_list', $comment_list); } // 트랙백 가져오기 if($document->trackback_count && $document->allow_trackback == 'Y') { $oTrackback = getModule('trackback'); $trackback_list = $oTrackback->getTrackbackList($document_srl); Context::set('trackback_list', $trackback_list); } // 첨부파일 가져오기 if($document->uploaded_count) { $file_list = $oDocument->getFiles($document_srl); $document->uploaded_list = $file_list; } Context::set('document', $document); } // 만약 document_srl은 있는데 page가 없다면 글만 호출된 경우, // 그럼 page를 구해서 세팅해주자.. if($document_srl && !$page) { $page = $oDocument->getDocumentPage($document_srl, $this->module_srl, $this->list_count); Context::set('page', $page); } // 검색옵션 $search_target = Context::get('search_target'); $keyword = Context::get('keyword'); if($search_target && $keyword) { $keyword = str_replace(' ','%',$keyword); switch($search_target) { case 'title' : $search_obj->s_title = $keyword; break; case 'content' : $search_obj->s_content = $keyword; break; case 'title_content' : $search_obj->s_title = $keyword; $search_obj->s_content = $keyword; break; case 'user_name' : $search_obj->s_user_name = $keyword; break; } } // 카테고리 $category = Context::get('category'); if($category) $search_obj->category_srl = $category; // 목록의 경우 document->getDocumentList 에서 걍 알아서 다 해버리는 구조이다... (아.. 이거 나쁜 버릇인데.. ㅡ.ㅜ 어쩔수 없다) $output = $oDocument->getDocumentList($this->module_srl, 'list_order', $page, $this->list_count, $this->page_count, $search_obj); // 템플릿에 쓰기 위해서 context::set 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); $this->setTemplateFile('list'); }/*}}}*/ function dispWriteForm() {/*{{{*/ // 권한 체크 if(!$this->grant->write_document) return $this->dispMessage('msg_not_permitted'); // 목록 구현에 필요한 변수들을 가져온다 $document_srl = Context::get('document_srl'); // document 모듈 객체 생성 $oDocument = getModule('document'); // 지정된 글이 없다면 (신규) 새로운 번호를 만든다 if(!$document_srl) { $oDB = &DB::getInstance(); $document_srl = $oDB->getNextSequence(); // 글의 수정일 경우 원본 글을 가져와서 확인을 한다 } else { $document = $oDocument->getDocument($document_srl); if(!$document) { $oDB = &DB::getInstance(); $document_srl = $oDB->getNextSequence(); } } // 글을 수정하려고 할 경우 권한이 없는 경우 비밀번호 입력화면으로 if($document&&!$document->is_granted) return $this->setTemplateFile('input_password_form'); Context::set('document_srl',$document_srl); Context::set('document', $document); $this->setTemplateFile('write_form'); }/*}}}*/ function dispDeleteForm() {/*{{{*/ // 권한 체크 if(!$this->grant->write_document) return $this->dispMessage('msg_not_permitted'); // 삭제할 문서번호를 가져온다 $document_srl = Context::get('document_srl'); // 지정된 글이 있는지 확인 if($document_srl) { $oDocument = getModule('document'); $document = $oDocument->getDocument($document_srl); } // 삭제하려는 글이 없으면 에러 if(!$document) return $this->dispContent(); // 권한이 없는 경우 비밀번호 입력화면으로 if($document&&!$document->is_granted) return $this->setTemplateFile('input_password_form'); Context::set('document',$document); $this->setTemplateFile('delete_form'); }/*}}}*/ function dispCommentModifyForm() {/*{{{*/ // 권한 체크 if(!$this->grant->write_comment) return $this->dispMessage('msg_not_permitted'); // 목록 구현에 필요한 변수들을 가져온다 $document_srl = Context::get('document_srl'); $comment_srl = Context::get('comment_srl'); // 지정된 댓글이 없다면 오류 if(!$comment_srl) return new Output(-1, 'msg_invalid_request'); // 해당 댓글를 찾아본다 $oComment = getModule('comment'); $comment = $oComment->getComment($comment_srl); // 댓글이 없다면 오류 if(!$comment) return new Output(-1, 'msg_invalid_request'); // 글을 수정하려고 할 경우 권한이 없는 경우 비밀번호 입력화면으로 if($comment_srl&&$comment&&!$_SESSION['own_comment'][$comment_srl]) return $this->setTemplateFile('input_password_form'); // 필요한 정보들 세팅 Context::set('document_srl',$document_srl); Context::set('comment_srl',$comment_srl); Context::set('comment', $comment); $this->setTemplateFile('comment_form'); }/*}}}*/ function dispCommentDeleteForm() {/*{{{*/ // 권한 체크 if(!$this->grant->write_comment) return $this->dispMessage('msg_not_permitted'); // 삭제할 댓글번호를 가져온다 $comment_srl = Context::get('comment_srl'); // 삭제하려는 댓글가 있는지 확인 if($comment_srl) { $oComment = getModule('comment'); $comment = $oComment->getComment($comment_srl); } // 삭제하려는 글이 없으면 에러 if(!$comment) return $this->dispContent(); // 권한이 없는 경우 비밀번호 입력화면으로 if($comment_srl&&$comment&&!$_SESSION['own_comment'][$comment_srl]) return $this->setTemplateFile('input_password_form'); Context::set('comment',$comment); $this->setTemplateFile('delete_comment_form'); }/*}}}*/ function dispCommentReplyForm() {/*{{{*/ // 권한 체크 if(!$this->grant->write_comment) return $this->dispMessage('msg_not_permitted'); // 목록 구현에 필요한 변수들을 가져온다 $document_srl = Context::get('document_srl'); $parent_srl = Context::get('comment_srl'); // 지정된 원 댓글이 없다면 오류 if(!$parent_srl) return new Output(-1, 'msg_invalid_request'); // 해당 댓글를 찾아본다 $oComment = getModule('comment'); $source_comment = $oComment->getComment($parent_srl); // 댓글이 없다면 오류 if(!$source_comment) return new Output(-1, '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->setTemplateFile('comment_form'); }/*}}}*/ function dispTrackbackDeleteForm() {/*{{{*/ // 삭제할 댓글번호를 가져온다 $trackback_srl = Context::get('trackback_srl'); // 삭제하려는 댓글가 있는지 확인 $oTrackback = getModule('trackback'); $output = $oTrackback->getTrackback($trackback_srl); $trackback = $output->data; // 삭제하려는 글이 없으면 에러 if(!$trackback) return $this->dispContent(); Context::set('trackback',$trackback); $this->setTemplateFile('delete_trackback_form'); }/*}}}*/ function dispLogin() {/*{{{*/ if(Context::get('is_logged')) return $this->dispContent(); $this->setTemplateFile('login_form'); }/*}}}*/ function dispLogout() {/*{{{*/ if(!Context::get('is_logged')) return $this->dispContent(); $this->setTemplateFile('logout'); }/*}}}*/ function dispMessage($msg_code) {/*{{{*/ $msg = Context::getLang($msg_code); if(!$msg) $msg = $msg_code; Context::set('message', $msg); $this->setTemplateFile('message'); }/*}}}*/ function dispRss() {/*{{{*/ // 권한 체크 if(!$this->grant->list) return $this->dispMessage('msg_not_permitted'); $page = Context::get('page'); // rss 제목 및 정보등을 추출 $info->title = Context::getBrowserTitle(); $info->description = $this->module_info->description; $info->language = Context::getLangType(); $info->date = gmdate("D, d M Y H:i:s"); $info->link = sprintf("%s?mid=%s", Context::getRequestUri(), Context::get('mid')); // 컨텐츠 추출 $oDocument = getModule('document'); $output = $oDocument->getDocumentList($this->module_srl, 'update_order', $page, 20, 20, NULL); $document_list = $output->data; // 출력하고 끝내기 $oRss = getModule('rss'); $oRss->printRssDocument($info, $document_list); exit(); }/*}}}*/ // 실행 부분 function procInsertDocument() {/*{{{*/ // 글작성시 필요한 변수를 가져옴 $obj = Context::getRequestVars(); //$obj = Context::gets('document_srl','user_name','email_address','homepage','tags','title','content','password','allow_comment','lock_comment','allow_trackback','category_srl','is_notice','is_secret'); $obj->module_srl = $this->module_srl; if($obj->is_notice!='Y') $obj->is_notice = 'N'; if($obj->is_secret!='Y') $obj->is_secret = 'N'; if($obj->allow_comment!='Y') $obj->allow_comment = 'N'; if($obj->lock_comment!='Y') $obj->lock_comment = 'N'; if($obj->allow_trackback!='Y') $obj->allow_trackback = 'N'; // document module 객체 생성 $oDocument = getModule('document'); // 첨부 파일의 갯수를 구함 $obj->uploaded_count = $oDocument->getFilesCount($obj->document_srl); // 이미 존재하는 글인지 체크 $document = $oDocument->getDocument($obj->document_srl); // 이미 존재하는 경우 수정 if($document->document_srl == $obj->document_srl) { $output = $oDocument->updateDocument($document, $obj); $msg_code = 'success_updated'; // 그렇지 않으면 신규 등록 } else { $output = $oDocument->insertDocument($obj); $msg_code = 'success_registed'; $obj->document_srl = $output->get('document_srl'); } // 트랙백 발송 $trackback_url = Context::get('trackback_url'); $trackback_charset = Context::get('trackback_charset'); if($trackback_url) { $oTrackback = getModule('trackback'); $oTrackback->sendTrackback($obj, $trackback_url, $trackback_charset); } if(!$output->toBool()) return $output; $this->setMessage($msg_code); $this->add('mid', Context::get('mid')); $this->add('document_srl', $output->get('document_srl')); }/*}}}*/ function procDeleteDocument() {/*{{{*/ // 문서 번호 확인 $document_srl = Context::get('document_srl'); if(!$document_srl) return $this->doError('msg_invalid_document'); // 문서 있는지 확인 $oDocument = getModule('document'); $document = $oDocument->getDocument($document_srl); if($document->document_srl!=$document_srl) return $this->doError('msg_invalid_document'); // 글 삭제 $output = $oDocument->deleteDocument($document); if(!$output->toBool()) return $output; $this->add('mid', Context::get('mid')); $this->add('page', $output->get('page')); $this->setMessage('success_deleted'); }/*}}}*/ function procVoteDocument() {/*{{{*/ $oDocument = getModule('document'); $document_srl = Context::get('document_srl'); return $oDocument->updateVotedCount($document_srl); }/*}}}*/ function procInsertComment() {/*{{{*/ // 댓글 입력에 필요한 데이터 추출 $obj = Context::gets('document_srl','comment_srl','parent_srl','content','password','nick_name','user_name','member_srl','email_address','homepage'); $obj->module_srl = $this->module_srl; // comment 객체 생성 $oComment = getModule('comment'); // comment_srl이 없을 경우 신규 입력 if(!$obj->comment_srl) { // parent_srl이 있으면 답변으로 if($obj->parent_srl) { $comment = $oComment->getComment($obj->parent_srl); if(!$comment) return new Output(-1, 'msg_invalid_request'); $output = $oComment->insertComment($obj); $comment_srl = $output->get('comment_srl'); // 없으면 신규 } else { $output = $oComment->insertComment($obj); } // comment_srl이 있으면 수정으로 } else { $comment = $oComment->getComment($obj->comment_srl); if(!$comment) return new Output(-1, 'msg_invalid_request'); $obj->parent_srl = $comment->parent_srl; $output = $oComment->updateComment($obj); $comment_srl = $obj->comment_srl; } if(!$output->toBool()) return $output; $this->setMessage('success_registed'); $this->add('mid', Context::get('mid')); $this->add('document_srl', $obj->document_srl); $this->add('comment_srl', $comment_srl); }/*}}}*/ function procDeleteComment() {/*{{{*/ // 댓글 번호 확인 $comment_srl = Context::get('comment_srl'); if(!$comment_srl) return $this->doError('msg_invalid_request'); // 삭제 $oComment = getModule('comment'); $output = $oComment->deleteComment($comment_srl); if(!$output->toBool()) return $output; $this->add('mid', Context::get('mid')); $this->add('page', Context::get('page')); $this->add('document_srl', $output->get('document_srl')); $this->setMessage('success_deleted'); }/*}}}*/ function procReceiveTrackback() {/*{{{*/ $obj = Context::gets('document_srl','url','title','excerpt'); $oTrackback = getModule('trackback'); $oTrackback->insertTrackback($obj); }/*}}}*/ function procDeleteTrackback() {/*{{{*/ $trackback_srl = Context::get('trackback_srl'); $oTrackback = getModule('trackback'); $output = $oTrackback->deleteTrackback($trackback_srl); $this->add('mid', Context::get('mid')); $this->add('page', Context::get('page')); $this->add('document_srl', $output->get('document_srl')); $this->setMessage('success_deleted'); }/*}}}*/ function procLogin() {/*{{{*/ // 아이디, 비밀번호를 받음 $user_id = Context::get('user_id'); $password = Context::get('password'); // member모듈 객체 생성 $oMember = getModule('member'); return $oMember->doLogin($user_id, $password); }/*}}}*/ function procLogout() {/*{{{*/ // member모듈 객체 생성 $oMember = getModule('member'); return $oMember->doLogout(); }/*}}}*/ function procVerificationPassword() {/*{{{*/ // 비밀번호와 문서 번호를 받음 $password = md5(Context::get('password')); $document_srl = Context::get('document_srl'); $comment_srl = Context::get('comment_srl'); // comment_srl이 있을 경우 댓글이 대상 if($comment_srl) { // 문서번호에 해당하는 글이 있는지 확인 $oComment = getModule('comment'); $data = $oComment->getComment($comment_srl); // comment_srl이 없으면 문서가 대상 } else { // 문서번호에 해당하는 글이 있는지 확인 $oDocument = getModule('document'); $data = $oDocument->getDocument($document_srl); } // 글이 없을 경우 에러 if(!$data) return $this->doError('msg_invalid_request'); // 문서의 비밀번호와 입력한 비밀번호의 비교 if($data->password != $password) return $this->doError('msg_invalid_password'); // 해당 글에 대한 권한 부여 if($comment_srl) $_SESSION['own_comment'][$comment_srl] = true; else $_SESSION['own_document'][$document_srl] = true; }/*}}}*/ function procUploadFile() {/*{{{*/ // 기본적으로 필요한 변수인 document_srl, module_srl을 설정 $document_srl = Context::get('document_srl'); $module_srl = $this->module_srl; // document모듈 객체 생성후 걍 넘겨버림 $oDocument = getModule('document'); $output = $oDocument->insertFile($module_srl, $document_srl); print $this->printUploadedFileList($document_srl); exit(); }/*}}}*/ function procDeleteFile() {/*{{{*/ // 기본적으로 필요한 변수인 document_srl, module_srl을 설정 $document_srl = Context::get('document_srl'); $module_srl = $this->module_srl; $file_srl = Context::get('file_srl'); // document모듈 객체 생성후 걍 넘겨버림 $oDocument = getModule('document'); $output = $oDocument->deleteFile($file_srl); print $this->printUploadedFileList($document_srl); exit(); }/*}}}*/ function procDownload() {/*{{{*/ // 다운로드에 필요한 변수 체크 $file_srl = Context::get('file_srl'); $sid = Context::get('sid'); // document module 객체 생성후 해당 파일의 정보를 체크 $oDocument = getModule('document'); $file_obj = $oDocument->getFile($file_srl); if($file_obj->file_srl!=$file_srl||$file_obj->sid!=$sid) exit(); // 이상이 없으면 download_count 증가 $args->file_srl = $file_srl; $oDB = &DB::getInstance(); $oDB->executeQuery('document.updateFileDownloadCount', $args); // 파일 출력 $filename = $file_obj->source_filename; if(strstr($_SERVER['HTTP_USER_AGENT'], "MSIE")) { $filename = urlencode($filename); $filename = preg_replace('/\./', '%2e', $filename, substr_count($filename, '.') - 1); } $uploaded_filename = $file_obj->uploaded_filename; if(!file_exists($uploaded_filename)) exit(); $fp = fopen($uploaded_filename, 'rb'); if(!$fp) exit(); header("Cache-Control: "); header("Pragma: "); header("Content-Type: application/octet-stream"); header("Content-Length: " .(string)($file_obj->file_size)); header('Content-Disposition: attachment; filename="'.$filename.'"'); header("Content-Transfer-Encoding: binary\n"); fpassthru($fp); exit(); }/*}}}*/ function procClearFile() {/*{{{*/ $document_srl = Context::get('document_srl'); // document_srl의 글이 등록되어 있다면 pass $oDocument = getModule('document'); $data = $oDocument->getDocument($document_srl); if($data) exit(); // 등록되어 있지 않다면 첨부파일 삭제 $oDocument->deleteFiles($this->module_srl, $document_srl); }/*}}}*/ /** * 여기부터는 이 모듈과 관련된 라이브러리 개념의 method들 **/ function printUploadedFileList($document_srl) {/*{{{*/ // 첨부파일들의 정보를 취합해서 return $oDocument = getModule('document'); $file_list = $oDocument->getFiles($document_srl); $file_count = count($file_list); $buff = ""; for($i=0;$i<$file_count;$i++) { $file_info = $file_list[$i]; if(!$file_info->file_srl) continue; $buff .= sprintf("parent.editor_insert_uploaded_file(\"%d\", \"%d\",\"%s\", \"%d\", \"%s\", \"%s\", \"%s\");\n", $document_srl, $file_info->file_srl, $file_info->source_filename, $file_info->file_size, FileHandler::filesize($file_info->file_size), $file_info->direct_download=='Y'?$file_info->uploaded_filename:'', $file_info->sid); } $buff = sprintf("", $document_srl, $buff); return $buff; }/*}}}*/ } ?>