rhymix/modules/document/document.model.php

300 lines
12 KiB
PHP

<?php
/**
* @class documentModel
* @author zero (zero@nzeo.com)
* @brief document 모듈의 model 클래스
**/
class documentModel extends document {
/**
* @brief 초기화
**/
function init() {
}
/**
* @brief document에 대한 권한을 세션값으로 체크
**/
function isGranted($document_srl) {
return $_SESSION['own_document'][$document_srl];
}
/**
* @brief 문서 가져오기
**/
function getDocument($document_srl, $is_admin=false, $get_extra_info=false) {
// DB에서 가져옴
$oDB = &DB::getInstance();
$args->document_srl = $document_srl;
$output = $oDB->executeQuery('document.getDocument', $args);
$document = $output->data;
// 이 문서에 대한 권한이 있는지 확인
if($this->isGranted($document->document_srl) || $is_admin) {
$document->is_granted = true;
} elseif($document->member_srl) {
$oMemberModel = &getMemberModel('member');
$member_srl = $oMemberModel->getLoggedMemberSrl();
if($member_srl && $member_srl ==$document->member_srl) $document->is_granted = true;
}
// 비밀글이고 권한이 없을 경우 제목과 내용을 숨김
if($document->is_secret=='Y' && !$document->is_granted) {
$document->title = $document->content = Context::getLang('msg_is_secret');
}
// 내용 변경
$document->content = $this->transContent($document->content);
// 확장 정보(코멘트나 기타 등등) 플래그가 false이면 기본 문서 정보만 return
if(!$get_extra_info) return $document;
// document controller 객체 생성
$oDocumentController = &getController('document');
// 조회수 업데이트
if($buff = $oDocumentController->updateReadedCount($document)) $document->readed_count++;
// 댓글 가져오기
if($document->comment_count && $document->allow_comment == 'Y') {
$oCommentModel = &getModel('comment');
$document->comment_list = $oCommentModel->getCommentList($document_srl);
}
// 트랙백 가져오기
if($document->trackback_count && $document->allow_trackback == 'Y') {
$oTrackbackModel = &getModel('trackback');
$document->trackback_list = $oTrackbackModel->getTrackbackList($document_srl);
}
// 첨부파일 가져오기
if($document->uploaded_count) {
$oFileModel = &getModel('file');
$file_list = $oFileModel->getFiles($document_srl);
$document->uploaded_list = $file_list;
}
return $document;
}
/**
* @brief 여러개의 문서들을 가져옴 (페이징 아님)
**/
function getDocuments($document_srl_list, $is_admin=false) {
if(is_array($document_srl_list)) $document_srls = implode(',',$document_srl_list);
// DB에서 가져옴
$oDB = &DB::getInstance();
$args->document_srls = $document_srls;
$output = $oDB->executeQuery('document.getDocuments', $args);
$document_list = $output->data;
if(!$document_list) return;
// 권한 체크
$oMemberModel = &getModel('member');
$member_srl = $oMemberModel->getLoggedMemberSrl();
$document_count = count($document_list);
for($i=0;$i<$document_count;$i++) {
$document = $document_list[$i];
$is_granted = false;
if($this->isGranted($document->document_srl) || $is_admin) {
$is_granted = true;
} elseif($member_srl && $member_srl == $document->member_srl) {
$is_granted = true;
}
$document_list[$i]->is_granted = $is_granted;
}
return $document_list;
}
/**
* @brief module_srl값을 가지는 문서의 목록을 가져옴
**/
function getDocumentList($obj) {
// 검색 키워드가 있으면 공백을 % 로 변경하여 키워드 or 연산이 되도록 수정
if($obj->search_keyword) $obj->search_keyword = str_replace(' ','%',$obj->search_keyword);
if($obj->search_target && $obj->search_keyword) {
switch($obj->search_target) {
case 'title' :
$search_obj->s_title = $obj->search_keyword;
break;
case 'content' :
$search_obj->s_content = $obj->search_keyword;
break;
case 'title_content' :
$search_obj->s_title = $obj->search_keyword;
$search_obj->s_content = $obj->search_keyword;
break;
case 'user_name' :
$search_obj->s_user_name = $obj->search_keyword;
break;
}
}
// DB 객체 생성
$oDB = &DB::getInstance();
// 변수 설정
$args->module_srl = $obj->module_srl;
$args->s_title = $obj->search_target=='title'?$obj->search_keyword:'';
$args->s_content = $obj->search_target=='content'?$obj->search_keyword:'';
$args->s_user_name = $obj->search_target=='user_name'?$obj->search_keyword:'';
$args->s_member_srl = $obj->search_target=='member'?$obj->search_keyword:'';
$args->s_ipaddress = $obj->search_target=='ipaddress'?$obj->search_keyword:'';
$args->s_regdate = $obj->search_target=='regdate'?$obj->search_keyword:'';
$args->category_srl = $obj->category_srl?$obj->category_srl:'';
$args->sort_index = $obj->sort_index;
$args->page = $obj->page?$obj->page:1;
$args->list_count = $obj->list_count?$obj->list_count:20;
$args->page_count = $obj->page_count?$obj->page_count:10;
// document.getDocumentList 쿼리 실행
$output = $oDB->executeQuery('document.getDocumentList', $args);
// 결과가 없거나 오류 발생시 그냥 return
if(!$output->toBool()||!count($output->data)) return $output;
// 권한 체크
$oMemberModel = &getModel('member');
$member_srl = $oMemberModel->getLoggedMemberSrl();
foreach($output->data as $key => $document) {
$is_granted = false;
if($this->isGranted($document->document_srl) || $is_admin) $is_granted = true;
elseif($member_srl && $member_srl == $document->member_srl) $is_granted = true;
$output->data[$key]->is_granted = $is_granted;
}
return $output;
}
/**
* @brief module_srl에 해당하는 문서의 전체 갯수를 가져옴
**/
function getDocumentCount($module_srl, $search_obj = NULL) {
// DB 객체 생성
$oDB = &DB::getInstance();
// 검색 옵션 추가
$args->module_srl = $module_srl;
$args->s_title = $search_obj->s_title;
$args->s_content = $search_obj->s_content;
$args->s_user_name = $search_obj->s_user_name;
$args->s_member_srl = $search_obj->s_member_srl;
$args->s_ipaddress = $search_obj->s_ipaddress;
$args->s_regdate = $search_obj->s_regdate;
$args->category_srl = $search_obj->category_srl;
$output = $oDB->executeQuery('document.getDocumentCount', $args);
// 전체 갯수를 return
$total_count = $output->data->count;
return (int)$total_count;
}
/**
* @brief 해당 document의 page 가져오기, module_srl이 없으면 전체에서..
**/
function getDocumentPage($document_srl, $module_srl=0, $list_count) {
// DB 객체 생성
$oDB = &DB::getInstance();
// 변수 설정
$args->document_srl = $document_srl;
$args->module_srl = $module_srl;
// 전체 갯수를 구한후 해당 글의 페이지를 검색
$output = $oDB->executeQuery('document.getDocumentPage', $args);
$count = $output->data->count;
$page = (int)(($count-1)/$list_count)+1;
return $page;
}
/**
* @brief 카테고리의 정보를 가져옴
**/
function getCategory($category_srl) {
$oDB = &DB::getInstance();
$args->category_srl = $category_srl;
$output = $oDB->executeQuery('document.getCategory', $args);
return $output->data;
}
/**
* @brief 특정 모듈의 카테고리 목록을 가져옴
**/
function getCategoryList($module_srl) {
$oDB = &DB::getInstance();
$args->module_srl = $module_srl;
$args->sort_index = 'list_order';
$output = $oDB->executeQuery('document.getCategoryList', $args);
$category_list = $output->data;
if(!$category_list) return NULL;
if(!is_array($category_list)) $category_list = array($category_list);
$category_count = count($category_list);
for($i=0;$i<$category_count;$i++) {
$category_srl = $category_list[$i]->category_srl;
$list[$category_srl] = $category_list[$i];
}
return $list;
}
/**
* @brief 카테고리에 속한 문서의 갯수를 구함
**/
function getCategoryDocumentCount($category_srl) {
$oDB = &DB::getInstance();
$args->category_srl = $category_srl;
$output = $oDB->executeQuery('document.getCategoryDocumentCount', $args);
return (int)$output->data->count;
}
/**
* @brief 내용의 플러그인이나 기타 기능에 대한 code를 실제 code로 변경
**/
function transContent($content) {
// 멀티미디어 코드의 변환
$content = preg_replace_callback('!<img([^\>]*)editor_multimedia([^\>]*?)>!is', array($this,'_transMultimedia'), $content);
// <br> 코드 변환
$content = str_replace(array("<BR>","<br>","<Br>"),"<br />", $content);
// <img ...> 코드를 <img ... /> 코드로 변환
$content = preg_replace('!<img(.*?)(\/){0,1}>!is','<img\\1 />', $content);
return $content;
}
/**
* @brief 내용의 멀티미디어 태그를 html 태그로 변경
* <img ... class="multimedia" ..> 로 되어 있는 코드를 변경
**/
function _transMultimedia($matches) {
preg_match("/style\=(\"|'){0,1}([^\"\']+)(\"|'){0,1}/i",$matches[0], $buff);
$style = str_replace("\"","'",$buff[0]);
preg_match("/alt\=\"{0,1}([^\"]+)\"{0,1}/i",$matches[0], $buff);
$opt = explode('|@|',$buff[1]);
if(count($opt)<1) return $matches[0];
for($i=0;$i<count($opt);$i++) {
$pos = strpos($opt[$i],"=");
$cmd = substr($opt[$i],0,$pos);
$val = substr($opt[$i],$pos+1);
$obj->{$cmd} = $val;
}
return sprintf("<script type=\"text/javascript\">displayMultimedia(\"%s\", \"%s\", \"%s\");</script>", $obj->type, $obj->src, $style);
}
}
?>