|
Server : Apache/2.2.17 (Unix) mod_ssl/2.2.17 OpenSSL/0.9.8e-fips-rhel5 DAV/2 PHP/5.2.17 System : Linux localhost 2.6.18-419.el5 #1 SMP Fri Feb 24 22:47:42 UTC 2017 x86_64 User : nobody ( 99) PHP Version : 5.2.17 Disable Function : NONE Directory : /home/queenjbs/xe/modules/trackback/ |
Upload File : |
<?php
/**
* @class trackbackController
* @author zero (zero@nzeo.com)
* @brief trackback모듈의 Controller class
**/
class trackbackController extends trackback {
/**
* @brief 초기화
**/
function init() {
}
/**
* @brief 트랙백 발송
**/
function procTrackbackSend() {
// 게시물 번호와 발송하려는 엮인글 주소를 구함
$document_srl = Context::get('target_srl');
$trackback_url = Context::get('trackback_url');
$charset = Context::get('charset');
if(!$document_srl || !$trackback_url || !$charset) return new Object(-1, 'msg_invalid_request');
// 로그인 정보 구함
$logged_info = Context::get('logged_info');
if(!$logged_info->member_srl) return new Object(-1, 'msg_not_permitted');
// 게시물의 정보를 구해와서 있는지 여부와 권한을 체크
$oDocumentModel = &getModel('document');
$oDocument = $oDocumentModel->getDocument($document_srl);
if(!$oDocument->isExists()) return new Object(-1, 'msg_invalid_request');
if($oDocument->getMemberSrl() != $logged_info->member_srl) return new Object(-1, 'msg_not_permitted');
// 현재 글이 있는 모듈의 타이틀 지정
$oModuleModel = &getModel('module');
$module_info = $oModuleModel->getModuleInfoByModuleSrl($oDocument->get('module_srl'));
Context::setBrowserTitle($module_info->browser_title);
// 엮인글 발송
return $this->sendTrackback($oDocument, $trackback_url, $charset);
}
/**
* @brief 문서 팝업메뉴에서 엮인글을 발송하는 메뉴 추가
**/
function triggerSendTrackback(&$menu_list) {
$logged_info = Context::get('logged_info');
if(!$logged_info->member_srl) return new Object();
// 요청된 게시물 번호와 현재 로그인 정보 구함
$document_srl = Context::get('target_srl');
$oDocumentModel = &getModel('document');
$oDocument = $oDocumentModel->getDocument($document_srl);
if(!$oDocument->isExists()) return new Object();
if($oDocument->getMemberSrl() != $logged_info->member_srl) return new Object();
// 엮인글 발송 링크 추가
$oDocumentController = &getController('document');
$url = getUrl('','module','trackback','act','dispTrackbackSend','document_srl', $document_srl);
$oDocumentController->addDocumentPopupMenu($url,'cmd_send_trackback','./modules/document/tpl/icons/send_trackback.gif','popup');
return new Object();
}
/**
* @brief document삭제시 해당 document의 엮인글을 삭제하는 trigger
**/
function triggerDeleteDocumentTrackbacks(&$obj) {
$document_srl = $obj->document_srl;
if(!$document_srl) return new Object();
return $this->deleteTrackbacks($document_srl, true);
}
/**
* @brief module 삭제시 해당 엮인글 모두 삭제하는 trigger
**/
function triggerDeleteModuleTrackbacks(&$obj) {
$module_srl = $obj->module_srl;
if(!$module_srl) return new Object();
$oTrackbackController = &getAdminController('trackback');
return $oTrackbackController->deleteModuleTrackbacks($module_srl);
}
/**
* @brief 엮인글 입력
**/
function trackback() {
// 출력을 XMLRPC로 설정
Context::setRequestMethod("XMLRPC");
// 엮인글 받을때 필요한 변수를 구함
$obj = Context::gets('document_srl','blog_name','url','title','excerpt');
if(!$obj->document_srl || !$obj->url || !$obj->title || !$obj->excerpt) return $this->stop('fail');
// 올바른 trackback url인지 검사
$given_key = Context::get('key');
$oTrackbackModel = &getModel('trackback');
$key = $oTrackbackModel->getTrackbackKey($obj->document_srl);
if($key != $given_key) return $this->stop('fail');
// 엮인글 모듈의 기본 설정을 받음
$module_srl = Context::get('module_srl');
$oModuleModel = &getModel('module');
$config = $oModuleModel->getModulePartConfig('trackback', $module_srl);
$enable_trackback = $config->enable_trackback;
if(!$enable_trackback) {
$config = $oModuleModel->getModuleConfig('trackback');
$enable_trackback = $config->enable_trackback;
}
// 관리자가 금지하였을 경우에는 엮인글을 받지 않음
if($enable_trackback == 'N') return $this->stop('fail');
return $this->insertTrackback($obj);
}
function insertTrackback($obj, $manual_inserted = false) {
// 엮인글 정리
$obj = Context::convertEncoding($obj);
if(!$obj->blog_name) $obj->blog_name = $obj->title;
$obj->excerpt = strip_tags($obj->excerpt);
// trigger 호출 (before)
$output = ModuleHandler::triggerCall('trackback.insertTrackback', 'before', $obj);
if(!$output->toBool()) return $output;
// GET으로 넘어온 document_srl을 참조, 없으면 오류~
$document_srl = $obj->document_srl;
if(!$manual_inserted) {
// document model 객체 생성후 원본글을 가져옴
$oDocumentModel = &getModel('document');
$oDocument = $oDocumentModel->getDocument($document_srl);
// 원본글이 없거나 트랙백 허용을 하지 않으면 오류 표시
if(!$oDocument->isExists()) return $this->stop('fail');
if(!$oDocument->allowTrackback()) return new Object(-1,'fail');
$obj->module_srl = $oDocument->get('module_srl');
}
// 엮인글을 입력
$obj->trackback_srl = getNextSequence();
$obj->list_order = $obj->trackback_srl*-1;
$output = executeQuery('trackback.insertTrackback', $obj);
if(!$output->toBool()) return $output;
// 입력에 이상이 없으면 해당 글의 엮인글 수를 올림
if(!$manual_inserted) {
// trackback model 객체 생성
$oTrackbackModel = &getModel('trackback');
// 해당 글의 전체 엮인글 수를 구해옴
$trackback_count = $oTrackbackModel->getTrackbackCount($document_srl);
// document controller 객체 생성
$oDocumentController = &getController('document');
// 해당글의 엮인글 수를 업데이트
$output = $oDocumentController->updateTrackbackCount($document_srl, $trackback_count);
// 결과 return
if(!$output->toBool()) return $output;
}
// 원본글에 알림(notify_message)가 설정되어 있으면 메세지 보냄
if(!$manual_inserted) $oDocument->notify(Context::getLang('trackback'), $obj->excerpt);
// trigger 호출 (after)
$output = ModuleHandler::triggerCall('trackback.insertTrackback', 'after', $obj);
if(!$output->toBool()) return $output;
return new Object();
}
/**
* @brief 단일 엮인글 삭제
**/
function deleteTrackback($trackback_srl, $is_admin = false) {
// trackback model 객체 생성
$oTrackbackModel = &getModel('trackback');
// 삭제하려는 엮인글이 있는지 확인
$trackback = $oTrackbackModel->getTrackback($trackback_srl);
if($trackback->data->trackback_srl != $trackback_srl) return new Object(-1, 'msg_invalid_request');
$document_srl = $trackback->data->document_srl;
// trigger 호출 (before)
$output = ModuleHandler::triggerCall('trackback.deleteTrackback', 'before', $trackback);
if(!$output->toBool()) return $output;
// document model 객체 생성
$oDocumentModel = &getModel('document');
// 권한이 있는지 확인
if(!$is_admin && !$oDocumentModel->isGranted($document_srl)) return new Object(-1, 'msg_not_permitted');
$args->trackback_srl = $trackback_srl;
$output = executeQuery('trackback.deleteTrackback', $args);
if(!$output->toBool()) return new Object(-1, 'msg_error_occured');
// 엮인글 수를 구해서 업데이트
$trackback_count = $oTrackbackModel->getTrackbackCount($document_srl);
// document controller 객체 생성
$oDocumentController = &getController('document','controller');
// 해당글의 엮인글 수를 업데이트
$output = $oDocumentController->updateTrackbackCount($document_srl, $trackback_count);
$output->add('document_srl', $document_srl);
// trigger 호출 (before)
$output = ModuleHandler::triggerCall('trackback.deleteTrackback', 'after', $trackback);
if(!$output->toBool()) return $output;
return $output;
}
/**
* @brief 글에 속한 모든 트랙백 삭제
**/
function deleteTrackbacks($document_srl) {
// 삭제
$args->document_srl = $document_srl;
$output = executeQuery('trackback.deleteTrackbacks', $args);
return $output;
}
/**
* @brief 엮인글을 발송
*
* 발송 후 결과처리는 하지 않는 구조임
**/
function sendTrackback($oDocument, $trackback_url, $charset) {
$oModuleController = &getController('module');
// 발송할 정보를 정리
$http = parse_url($trackback_url);
$obj->blog_name = str_replace(array('<','>','&','"'), array('<','>','&','"'), Context::getBrowserTitle());
$oModuleController->replaceDefinedLangCode($obj->blog_name);
$obj->title = $oDocument->getTitleText();
$obj->excerpt = $oDocument->getSummary(200);
$obj->url = getFullUrl('','document_srl',$oDocument->document_srl);
// blog_name, title, excerpt, url의 문자열을 요청된 charset으로 변경
if($charset && function_exists('iconv')) {
foreach($obj as $key=>$val) {
$obj->{$key} = iconv('UTF-8',$charset,$val);
}
}
// socket으로 발송할 내용 작성
if($http['query']) $http['query'].="&";
if(!$http['port']) $http['port'] = 80;
$content =
sprintf(
"title=%s&".
"url=%s&".
"blog_name=%s&".
"excerpt=%s",
urlencode($obj->title),
urlencode($obj->url),
urlencode($obj->blog_name),
urlencode($obj->excerpt)
);
if($http['query']) $content .= '&'.$http['query'];
$content_length = strlen($content);
// header 정리
$header =
sprintf(
"POST %s HTTP/1.1\r\n".
"Host: %s\r\n".
"Content-Type: %s\r\n".
"Content-Length: %s\r\n\r\n".
"%s\r\n",
$http['path'],
$http['host'],
"application/x-www-form-urlencoded",
$content_length,
$content
);
if(!$http['host']||!$http['port']) return new Object(-1,'msg_trackback_url_is_invalid');
// 발송하려는 대상 서버의 socket을 연다
$fp = @fsockopen($http['host'], $http['port'], $errno, $errstr, 5);
if(!$fp) return new Object(-1,'msg_trackback_url_is_invalid');
// 작성한 헤더 정보를 발송
fputs($fp, $header);
// 결과를 기다림 (특정 서버의 경우 EOF가 떨어지지 않을 수가 있음
while(!feof($fp)) {
$line = trim(fgets($fp, 4096));
if(preg_match("/^<error>/i",$line)) break;
}
// socket 닫음
fclose($fp);
return new Object(0, 'msg_trackback_send_success');
}
/**
* @brief 특정 ipaddress의 특정 시간대 내의 엮인글을 모두 삭제
**/
function deleteTrackbackSender($time, $ipaddress, $url, $blog_name, $title, $excerpt) {
$obj->regdate = date("YmdHis",time()-$time);
$obj->ipaddress = $ipaddress;
$obj->url = $url;
$obj->blog_name = $blog_name;
$obj->title = $title;
$obj->excerpt = $excerpt;
$output = executeQueryArray('trackback.getRegistedTrackbacks', $obj);
if(!$output->data || !count($output->data)) return;
foreach($output->data as $trackback) {
$trackback_srl = $trackback->trackback_srl;
$this->deleteTrackback($trackback_srl, true);
}
}
}
?>