content를 출력하는 위젯 더 자세히 ...


Public 멤버 함수 | |
| proc ($args) | |
| 위젯의 실행 부분 | |
| _getCommentItems ($args) | |
| 댓글 목록을 추출하여 contentItem으로 return | |
| _getDocumentItems ($args) | |
| _getImageItems ($args) | |
| getRssItems ($args) | |
| _getRssBody ($value) | |
| requestFeedContents ($rss_url) | |
| rss 주소로 부터 내용을 받아오는 함수 tistory 의 경우 원본 주소가 location 헤더를 뿜는다. (내용은 없음)이를 해결하기 위한 수정 - rss_reader 위젯과 방식 동일 | |
| _getRssItems ($args) | |
| _getTrackbackItems ($args) | |
| _compile ($args, $content_items) | |
content를 출력하는 위젯
content.class.php 파일의 9 번째 라인에서 정의되었습니다.
| content::_compile | ( | $ | args, | |
| $ | content_items | |||
| ) |
content.class.php 파일의 598 번째 라인에서 정의되었습니다.
다음을 참조함 : TemplateHandler::getInstance(), getSiteUrl(), Context::set().
다음에 의해서 참조됨 : proc().
00598 { 00599 $oTemplate = &TemplateHandler::getInstance(); 00600 00601 // 위젯에 넘기기 위한 변수 설정 00602 $widget_info->modules_info = $args->modules_info; 00603 $widget_info->option_view_arr = $args->option_view_arr; 00604 $widget_info->list_count = $args->list_count; 00605 $widget_info->page_count = $args->page_count; 00606 $widget_info->subject_cut_size = $args->subject_cut_size; 00607 $widget_info->content_cut_size = $args->content_cut_size; 00608 00609 $widget_info->duration_new = $duration_new * 60*60; 00610 $widget_info->thumbnail_type = $args->thumbnail_type; 00611 $widget_info->thumbnail_width = $args->thumbnail_width; 00612 $widget_info->thumbnail_height = $args->thumbnail_height; 00613 $widget_info->cols_list_count = $args->cols_list_count; 00614 $widget_info->mid_lists = $args->mid_lists; 00615 00616 $widget_info->show_browser_title = $args->show_browser_title; 00617 $widget_info->show_category = $args->show_category; 00618 $widget_info->show_comment_count = $args->show_comment_count; 00619 $widget_info->show_trackback_count = $args->show_trackback_count; 00620 $widget_info->show_icon = $args->show_icon; 00621 00622 $widget_info->list_type = $args->list_type; 00623 $widget_info->tab_type = $args->tab_type; 00624 00625 $widget_info->markup_type = $args->markup_type; 00626 00627 // 탭형태일경우 탭에 대한 정보를 정리하고 module_srl로 되어 있는 key값을 index로 변경 00628 if($args->tab_type != 'none' && $args->tab_type) { 00629 $tab = array(); 00630 foreach($args->mid_lists as $module_srl => $mid){ 00631 if(!is_array($content_items[$module_srl]) || !count($content_items[$module_srl])) continue; 00632 00633 unset($tab_item); 00634 $tab_item->title = $content_items[$module_srl][0]->getBrowserTitle(); 00635 $tab_item->content_items = $content_items[$module_srl]; 00636 $tab_item->domain = $content_items[$module_srl][0]->getDomain(); 00637 $tab_item->url = $content_items[$module_srl][0]->getContentsLink(); 00638 if(!$tab_item->url) $tab_item->url = getSiteUrl($tab_item->domain, '','mid',$mid); 00639 $tab[] = $tab_item; 00640 } 00641 $widget_info->tab = $tab; 00642 } else { 00643 $widget_info->content_items = $content_items; 00644 } 00645 unset($args->option_view_arr); 00646 unset($args->modules_info); 00647 00648 Context::set('colorset', $args->colorset); 00649 Context::set('widget_info', $widget_info); 00650 00651 $tpl_path = sprintf('%sskins/%s', $this->widget_path, $args->skin); 00652 return $oTemplate->compile($tpl_path, "content"); 00653 }

| content::_getCommentItems | ( | $ | args | ) |
댓글 목록을 추출하여 contentItem으로 return
content.class.php 파일의 180 번째 라인에서 정의되었습니다.
다음을 참조함 : $output, getModel(), getUrl().
다음에 의해서 참조됨 : proc().
00180 { 00181 // CommentModel::getCommentList()를 이용하기 위한 변수 정리 00182 $obj->module_srl = $args->module_srl; 00183 $obj->sort_index = $args->order_target; 00184 $obj->list_count = $args->list_count * $args->page_count; 00185 00186 // comment 모듈의 model 객체를 받아서 getCommentList() method를 실행 00187 $oCommentModel = &getModel('comment'); 00188 $output = $oCommentModel->getNewestCommentList($obj); 00189 00190 $content_items = array(); 00191 00192 if(!count($output)) return; 00193 00194 foreach($output as $key => $oComment) { 00195 $attribute = $oComment->getObjectVars(); 00196 $title = $oComment->getSummary($args->content_cut_size); 00197 $thumbnail = $oComment->getThumbnail($args->thumbnail_width,$args->thumbnail_height,$args->thumbnail_type); 00198 $url = sprintf("%s#comment_%s",getUrl('','document_srl',$oComment->get('document_srl')),$oComment->get('comment_srl')); 00199 00200 $attribute->mid = $args->mid_lists[$attribute->module_srl]; 00201 $browser_title = $args->module_srls_info[$attribute->module_srl]->browser_title; 00202 $domain = $args->module_srls_info[$attribute->module_srl]->domain; 00203 00204 $content_item = new contentItem($browser_title); 00205 $content_item->adds($attribute); 00206 $content_item->setTitle($title); 00207 $content_item->setThumbnail($thumbnail); 00208 $content_item->setLink($url); 00209 $content_item->setDomain($domain); 00210 $content_item->add('mid', $args->mid_lists[$attribute->module_srl]); 00211 $content_items[] = $content_item; 00212 } 00213 return $content_items; 00214 }

| content::_getDocumentItems | ( | $ | args | ) |
content.class.php 파일의 216 번째 라인에서 정의되었습니다.
다음을 참조함 : $GLOBALS, $output, executeQueryArray(), getModel(), getSiteUrl().
다음에 의해서 참조됨 : proc().
00216 { 00217 // document 모듈의 model 객체를 받아서 결과를 객체화 시킴 00218 $oDocumentModel = &getModel('document'); 00219 00220 // 분류 구함 00221 $obj->module_srl = $args->module_srl; 00222 $output = executeQueryArray('widgets.content.getCategories',$obj); 00223 if($output->toBool() && $output->data) { 00224 foreach($output->data as $key => $val) { 00225 $category_lists[$val->module_srl][$val->category_srl] = $val; 00226 } 00227 } 00228 00229 // 글 목록을 구함 00230 $obj->module_srl = $args->module_srl; 00231 $obj->sort_index = $args->order_target; 00232 $obj->order_type = $args->order_type=="desc"?"asc":"desc"; 00233 $obj->list_count = $args->list_count * $args->page_count; 00234 $output = executeQueryArray('widgets.content.getNewestDocuments', $obj); 00235 if(!$output->toBool() || !$output->data) return; 00236 00237 // 결과가 있으면 각 문서 객체화를 시킴 00238 $content_items = array(); 00239 $first_thumbnail_idx = -1; 00240 if(count($output->data)) { 00241 foreach($output->data as $key => $attribute) { 00242 $oDocument = new documentItem(); 00243 $oDocument->setAttribute($attribute, false); 00244 $GLOBALS['XE_DOCUMENT_LIST'][$oDocument->document_srl] = $oDocument; 00245 $document_srls[] = $oDocument->document_srl; 00246 } 00247 $oDocumentModel->setToAllDocumentExtraVars(); 00248 00249 for($i=0,$c=count($document_srls);$i<$c;$i++) { 00250 $oDocument = $GLOBALS['XE_DOCUMENT_LIST'][$document_srls[$i]]; 00251 $document_srl = $oDocument->document_srl; 00252 $module_srl = $oDocument->get('module_srl'); 00253 $category_srl = $oDocument->get('category_srl'); 00254 $thumbnail = $oDocument->getThumbnail($args->thumbnail_width,$args->thumbnail_height,$args->thumbnail_type); 00255 00256 $content_item = new contentItem( $args->module_srls_info[$module_srl]->browser_title ); 00257 $content_item->adds($oDocument->getObjectVars()); 00258 $content_item->setTitle($oDocument->getTitle()); 00259 $content_item->setCategory( $category_lists[$module_srl][$category_srl]->title ); 00260 $content_item->setDomain( $args->module_srls_info[$module_srl]->domain ); 00261 $content_item->setContent($oDocument->getSummary($args->content_cut_size)); 00262 $content_item->setLink( getSiteUrl($domain,'','document_srl',$document_srl) ); 00263 $content_item->setThumbnail($thumbnail); 00264 $content_item->setExtraImages($oDocument->printExtraImages($args->duration_new * 60 * 60)); 00265 $content_item->add('mid', $args->mid_lists[$module_srl]); 00266 if($first_thumbnail_idx==-1 && $thumbnail) $first_thumbnail_idx = $i; 00267 $content_items[] = $content_item; 00268 } 00269 00270 $content_items[0]->setFirstThumbnailIdx($first_thumbnail_idx); 00271 } 00272 return $content_items; 00273 }

| content::_getImageItems | ( | $ | args | ) |
content.class.php 파일의 275 번째 라인에서 정의되었습니다.
다음을 참조함 : $output, executeQueryArray(), getModel().
다음에 의해서 참조됨 : proc().
00275 { 00276 $oDocumentModel = &getModel('document'); 00277 00278 $obj->module_srls = $obj->module_srl = $args->module_srl; 00279 $obj->direct_download = 'Y'; 00280 $obj->isvalid = 'Y'; 00281 00282 // 분류 구함 00283 $output = executeQueryArray('widgets.content.getCategories',$obj); 00284 if($output->toBool() && $output->data) { 00285 foreach($output->data as $key => $val) { 00286 $category_lists[$val->module_srl][$val->category_srl] = $val; 00287 } 00288 } 00289 00290 // 정해진 모듈에서 문서별 파일 목록을 구함 00291 $obj->list_count = $args->list_count * $args->page_count; 00292 $files_output = executeQueryArray("file.getOneFileInDocument", $obj); 00293 $files_count = count($files_output->data); 00294 if(!$files_count) return; 00295 00296 $content_items = array(); 00297 00298 for($i=0;$i<$files_count;$i++) $document_srl_list[] = $files_output->data[$i]->document_srl; 00299 00300 $tmp_document_list = $oDocumentModel->getDocuments($document_srl_list); 00301 00302 if(!count($tmp_document_list)) return; 00303 00304 foreach($tmp_document_list as $oDocument){ 00305 $attribute = $oDocument->getObjectVars(); 00306 $browser_title = $args->module_srls_info[$attribute->module_srl]->browser_title; 00307 $domain = $args->module_srls_info[$attribute->module_srl]->domain; 00308 $category = $category_lists[$attribute->module_srl]->text; 00309 $content = $oDocument->getSummary($args->content_cut_size); 00310 $url = sprintf("%s#%s",$oDocument->getPermanentUrl() ,$oDocument->getCommentCount()); 00311 $thumbnail = $oDocument->getThumbnail($args->thumbnail_width,$args->thumbnail_height,$args->thumbnail_type); 00312 $extra_images = $oDocument->printExtraImages($args->duration_new); 00313 00314 $content_item = new contentItem($browser_title); 00315 $content_item->adds($attribute); 00316 $content_item->setCategory($category); 00317 $content_item->setContent($content); 00318 $content_item->setLink($url); 00319 $content_item->setThumbnail($thumbnail); 00320 $content_item->setExtraImages($extra_images); 00321 $content_item->setDomain($domain); 00322 $content_item->add('mid', $args->mid_lists[$attribute->module_srl]); 00323 $content_items[] = $content_item; 00324 } 00325 00326 return $content_items; 00327 }

| content::_getRssBody | ( | $ | value | ) |
content.class.php 파일의 378 번째 라인에서 정의되었습니다.
다음을 참조함 : null.
다음에 의해서 참조됨 : _getRssItems().
00378 { 00379 if(!$value || is_string($value)) return $value; 00380 if(is_object($value)) $value = get_object_vars($value); 00381 $body = null; 00382 if(!count($value)) return; 00383 foreach($value as $key => $val) { 00384 if($key == 'body') { 00385 $body = $val; 00386 continue; 00387 } 00388 if(is_object($val)||is_array($val)) $body = $this->_getRssBody($val); 00389 if($body !== null) return $body; 00390 } 00391 return $body; 00392 }
| content::_getRssItems | ( | $ | args | ) |
content.class.php 파일의 404 번째 라인에서 정의되었습니다.
다음을 참조함 : $oXmlParser, _getRssBody(), Context::convertEncodingStr(), requestFeedContents().
다음에 의해서 참조됨 : getRssItems().
00404 { 00405 // 날짜 형태 00406 $DATE_FORMAT = $args->date_format ? $args->date_format : "Y-m-d H:i:s"; 00407 00408 $buff = $this->requestFeedContents($args->rss_url); 00409 00410 $encoding = preg_match("/<\?xml.*encoding=\"(.+)\".*\?>/i", $buff, $matches); 00411 if($encoding && !preg_match("/UTF-8/i", $matches[1])) $buff = Context::convertEncodingStr($buff); 00412 00413 $buff = preg_replace("/<\?xml.*\?>/i", "", $buff); 00414 00415 $oXmlParser = new XmlParser(); 00416 $xml_doc = $oXmlParser->parse($buff); 00417 if($xml_doc->rss) { 00418 $rss->title = $xml_doc->rss->channel->title->body; 00419 $rss->link = $xml_doc->rss->channel->link->body; 00420 00421 $items = $xml_doc->rss->channel->item; 00422 00423 if(!$items) return; 00424 if($items && !is_array($items)) $items = array($items); 00425 00426 $content_items = array(); 00427 00428 foreach ($items as $key => $value) { 00429 if($key >= $args->list_count * $args->page_count) break; 00430 unset($item); 00431 00432 foreach($value as $key2 => $value2) { 00433 if(is_array($value2)) $value2 = array_shift($value2); 00434 $item->{$key2} = $this->_getRssBody($value2); 00435 } 00436 00437 $content_item = new contentItem($rss->title); 00438 $content_item->setContentsLink($rss->link); 00439 $content_item->setTitle($item->title); 00440 $content_item->setNickName(max($item->author,$item->{'dc:creator'})); 00441 //$content_item->setCategory($item->category); 00442 $item->description = preg_replace('!<a href=!is','<a onclick="window.open(this.href);return false" href=', $item->description); 00443 $content_item->setContent($item->description); 00444 $content_item->setLink($item->link); 00445 $date = date('YmdHis', strtotime(max($item->pubdate,$item->pubDate,$item->{'dc:date'}))); 00446 $content_item->setRegdate($date); 00447 00448 $content_items[] = $content_item; 00449 } 00450 } elseif($xml_doc->{'rdf:rdf'}) { 00451 // rss1.0 지원 (Xml이 대소문자를 구분해야 하는데 XE의 XML파서가 전부 소문자로 바꾸는 바람에 생긴 case) by misol 00452 $rss->title = $xml_doc->{'rdf:rdf'}->channel->title->body; 00453 $rss->link = $xml_doc->{'rdf:rdf'}->channel->link->body; 00454 00455 $items = $xml_doc->{'rdf:rdf'}->item; 00456 00457 if(!$items) return; 00458 if($items && !is_array($items)) $items = array($items); 00459 00460 $content_items = array(); 00461 00462 foreach ($items as $key => $value) { 00463 if($key >= $args->list_count * $args->page_count) break; 00464 unset($item); 00465 00466 foreach($value as $key2 => $value2) { 00467 if(is_array($value2)) $value2 = array_shift($value2); 00468 $item->{$key2} = $this->_getRssBody($value2); 00469 } 00470 00471 $content_item = new contentItem($rss->title); 00472 $content_item->setContentsLink($rss->link); 00473 $content_item->setTitle($item->title); 00474 $content_item->setNickName(max($item->author,$item->{'dc:creator'})); 00475 //$content_item->setCategory($item->category); 00476 $item->description = preg_replace('!<a href=!is','<a onclick="window.open(this.href);return false" href=', $item->description); 00477 $content_item->setContent($item->description); 00478 $content_item->setLink($item->link); 00479 $date = date('YmdHis', strtotime(max($item->pubdate,$item->pubDate,$item->{'dc:date'}))); 00480 $content_item->setRegdate($date); 00481 00482 $content_items[] = $content_item; 00483 } 00484 } elseif($xml_doc->feed && $xml_doc->feed->attrs->xmlns == 'http://www.w3.org/2005/Atom') { 00485 // Atom 1.0 spec 지원 by misol 00486 $rss->title = $xml_doc->feed->title->body; 00487 $links = $xml_doc->feed->link; 00488 if(is_array($links)) { 00489 foreach ($links as $value) { 00490 if($value->attrs->rel == 'alternate') { 00491 $rss->link = $value->attrs->href; 00492 break; 00493 } 00494 } 00495 } 00496 elseif($links->attrs->rel == 'alternate') $rss->link = $links->attrs->href; 00497 00498 $items = $xml_doc->feed->entry; 00499 00500 if(!$items) return; 00501 if($items && !is_array($items)) $items = array($items); 00502 00503 $content_items = array(); 00504 00505 foreach ($items as $key => $value) { 00506 if($key >= $args->list_count * $args->page_count) break; 00507 unset($item); 00508 00509 foreach($value as $key2 => $value2) { 00510 if(is_array($value2)) $value2 = array_shift($value2); 00511 $item->{$key2} = $this->_getRssBody($value2); 00512 } 00513 00514 $content_item = new contentItem($rss->title); 00515 $links = $value->link; 00516 if(is_array($links)) { 00517 foreach ($links as $val) { 00518 if($val->attrs->rel == 'alternate') { 00519 $item->link = $val->attrs->href; 00520 break; 00521 } 00522 } 00523 } 00524 elseif($links->attrs->rel == 'alternate') $item->link = $links->attrs->href; 00525 00526 $content_item->setContentsLink($rss->link); 00527 if($item->title) { 00528 if(!preg_match("/html/i", $value->title->attrs->type)) $item->title = $value->title->body; 00529 } 00530 $content_item->setTitle($item->title); 00531 $content_item->setNickName(max($item->author,$item->{'dc:creator'})); 00532 $content_item->setAuthorSite($value->author->uri->body); 00533 //$content_item->setCategory($item->category); 00534 $item->description = preg_replace('!<a href=!is','<a onclick="window.open(this.href);return false" href=', $item->content); 00535 if($item->description) { 00536 if(!preg_match("/html/i", $value->content->attrs->type)) $item->description = htmlspecialchars($item->description); 00537 } 00538 if(!$item->description) { 00539 $item->description = $item->summary; 00540 if($item->description) { 00541 if(!preg_match("/html/i", $value->summary->attrs->type)) $item->description = htmlspecialchars($item->description); 00542 } 00543 } 00544 $content_item->setContent($item->description); 00545 $content_item->setLink($item->link); 00546 $date = date('YmdHis', strtotime(max($item->published,$item->updated,$item->{'dc:date'}))); 00547 $content_item->setRegdate($date); 00548 00549 $content_items[] = $content_item; 00550 } 00551 } 00552 return $content_items; 00553 }

| content::_getTrackbackItems | ( | $ | args | ) |
<<
<<
content.class.php 파일의 555 번째 라인에서 정의되었습니다.
다음을 참조함 : $output, executeQueryArray(), getModel(), getSiteUrl().
다음에 의해서 참조됨 : proc().
00555 { 00556 // 분류 구함 00557 $output = executeQueryArray('widgets.content.getCategories',$obj); 00558 if($output->toBool() && $output->data) { 00559 foreach($output->data as $key => $val) { 00560 $category_lists[$val->module_srl][$val->category_srl] = $val; 00561 } 00562 } 00563 00564 $obj->module_srl = $args->module_srl; 00565 $obj->sort_index = $args->order_target; 00566 $obj->list_count = $args->list_count * $args->page_count; 00567 00568 // trackback 모듈의 model 객체를 받아서 getTrackbackList() method를 실행 00569 $oTrackbackModel = &getModel('trackback'); 00570 $output = $oTrackbackModel->getNewestTrackbackList($obj); 00571 00572 // 오류가 생기면 그냥 무시 00573 if(!$output->toBool() || !$output->data) return; 00574 00575 // 결과가 있으면 각 문서 객체화를 시킴 00576 $content_items = array(); 00577 foreach($output->data as $key => $item) { 00578 $domain = $args->module_srls_info[$item->module_srl]->domain; 00579 $category = $category_lists[$item->module_srl]->text; 00580 $url = getSiteUrl($domain,'','document_srl',$item->document_srl); 00581 $browser_title = $args->module_srls_info[$item->module_srl]->browser_title; 00582 00583 $content_item = new contentItem($browser_title); 00584 $content_item->adds($item); 00585 $content_item->setTitle($item->title); 00586 $content_item->setCategory($category); 00587 $content_item->setNickName($item->blog_name); 00588 $content_item->setContent($item->excerpt); 00589 $content_item->setDomain($domain); 00590 $content_item->setLink($url); 00591 $content_item->add('mid', $args->mid_lists[$item->module_srl]); 00592 $content_item->setRegdate($item->regdate); 00593 $content_items[] = $content_item; 00594 } 00595 return $content_items; 00596 }

| content::getRssItems | ( | $ | args | ) |
content.class.php 파일의 329 번째 라인에서 정의되었습니다.
다음을 참조함 : _getRssItems().
다음에 의해서 참조됨 : proc().
00329 { 00330 00331 $content_items = array(); 00332 $args->mid_lists = array(); 00333 00334 foreach($args->rss_urls as $key => $rss){ 00335 $args->rss_url = $rss; 00336 $content_item = $this->_getRssItems($args); 00337 if(count($content_item) > 0){ 00338 $browser_title = $content_item[0]->getBrowserTitle(); 00339 $args->mid_lists[] = $browser_title; 00340 $content_items[] = $content_item; 00341 } 00342 } 00343 00344 // 탭 형태가 아닐 경우 00345 if($args->tab_type == 'none' || $args->tab_type == ''){ 00346 $items = array(); 00347 foreach($content_items as $key => $val){ 00348 foreach($val as $k => $v){ 00349 $date = $v->get('regdate'); 00350 $i=0; 00351 while(array_key_exists(sprintf('%s%02d',$date,$i), $items)) $i++; 00352 $items[sprintf('%s%02d',$date,$i)] = $v; 00353 } 00354 } 00355 if($args->order_type =='asc') ksort($items); 00356 else krsort($items); 00357 $content_items = array_slice(array_values($items),0,$args->list_count*$args->page_count); 00358 00359 // 탭 형태 00360 } else { 00361 foreach($content_items as $key=> $content_item_list){ 00362 $items = array(); 00363 foreach($content_item_list as $k => $content_item){ 00364 $date = $content_item->get('regdate'); 00365 $i=0; 00366 while(array_key_exists(sprintf('%s%02d',$date,$i), $items)) $i++; 00367 $items[sprintf('%s%02d',$date,$i)] = $content_item; 00368 } 00369 if($args->order_type =='asc') ksort($items); 00370 else krsort($items); 00371 00372 $content_items[$key] = array_values($items); 00373 } 00374 } 00375 return $content_items; 00376 }

| content::proc | ( | $ | args | ) |
위젯의 실행 부분
./widgets/위젯/conf/info.xml 에 선언한 extra_vars를 args로 받는다 결과를 만든후 print가 아니라 return 해주어야 한다
컨텐츠 추출, 게시글/댓글/엮인글/RSS등 다양한 요소가 있어서 각 method를 따로 만듬
content.class.php 파일의 18 번째 라인에서 정의되었습니다.
다음을 참조함 : $output, _compile(), _getCommentItems(), _getDocumentItems(), _getImageItems(), _getTrackbackItems(), executeQueryArray(), Context::get(), getModel(), getRssItems().
00018 { 00019 // 정렬 대상 00020 if(!in_array($args->order_target, array('list_order','update_order'))) $args->order_target = 'list_order'; 00021 00022 // 정렬 순서 00023 if(!in_array($args->order_type, array('asc','desc'))) $args->order_type = 'asc'; 00024 00025 // 페이지 수 00026 $args->page_count = (int)$args->page_count; 00027 if(!$args->page_count) $args->page_count = 1; 00028 00029 // 출력된 목록 수 00030 $args->list_count = (int)$args->list_count; 00031 if(!$args->list_count) $args->list_count = 5; 00032 00033 // 썸네일 컬럼 수 00034 $args->cols_list_count = (int)$args->cols_list_count; 00035 if(!$args->cols_list_count) $args->cols_list_count = 5; 00036 00037 // 제목 길이 자르기 00038 if(!$args->subject_cut_size) $args->subject_cut_size = 0; 00039 00040 // 내용 길이 자르기 00041 if(!$args->content_cut_size) $args->content_cut_size = 100; 00042 00043 // 최근 글 표시 시간 00044 if(!$args->duration_new) $args->duration_new = 12; 00045 00046 // 썸네일 생성 방법 00047 if(!$args->thumbnail_type) $args->thumbnail_type = 'crop'; 00048 00049 // 썸네일 가로 크기 00050 if(!$args->thumbnail_width) $args->thumbnail_width = 100; 00051 00052 // 썸네일 세로 크기 00053 if(!$args->thumbnail_height) $args->thumbnail_height = 75; 00054 00055 // 보기 옵션 00056 $args->option_view_arr = explode(',',$args->option_view); 00057 00058 // markup 옵션 00059 if(!$args->markup_type) $args->markup_type = 'table'; 00060 00061 // 내부적으로 쓰이는 변수 설정 00062 $oModuleModel = &getModel('module'); 00063 $module_srls = $args->modules_info = $args->module_srls_info = $args->mid_lists = array(); 00064 $site_module_info = Context::get('site_module_info'); 00065 00066 // rss 인 경우 URL정리 00067 if($args->content_type == 'rss'){ 00068 $args->rss_urls = array(); 00069 $rss_urls = array_unique(array($args->rss_url0,$args->rss_url1,$args->rss_url2,$args->rss_url3,$args->rss_url4)); 00070 for($i=0,$c=count($rss_urls);$i<$c;$i++) { 00071 if($rss_urls[$i]) $args->rss_urls[] = $rss_urls[$i]; 00072 } 00073 00074 // rss가 아닌 XE모듈일 경우 모듈 번호 정리 후 모듈 정보 구함 00075 } else { 00076 00077 // 대상 모듈이 선택되어 있지 않으면 해당 사이트의 전체 모듈을 대상으로 함 00078 if(!$args->module_srls){ 00079 unset($obj); 00080 $obj->site_srl = (int)$site_module_info->site_srl; 00081 $output = executeQueryArray('widgets.content.getMids', $obj); 00082 if($output->data) { 00083 foreach($output->data as $key => $val) { 00084 $args->modules_info[$val->mid] = $val; 00085 $args->module_srls_info[$val->module_srl] = $val; 00086 $args->mid_lists[$val->module_srl] = $val->mid; 00087 $module_srls[] = $val->module_srl; 00088 } 00089 } 00090 00091 $args->modules_info = $oModuleModel->getMidList($obj); 00092 // 대상 모듈이 선택되어 있으면 해당 모듈만 추출 00093 } else { 00094 $obj->module_srls = $args->module_srls; 00095 $output = executeQueryArray('widgets.content.getMids', $obj); 00096 if($output->data) { 00097 foreach($output->data as $key => $val) { 00098 $args->modules_info[$val->mid] = $val; 00099 $args->module_srls_info[$val->module_srl] = $val; 00100 $module_srls[] = $val->module_srl; 00101 } 00102 $idx = explode(',',$args->module_srls); 00103 for($i=0,$c=count($idx);$i<$c;$i++) { 00104 $srl = $idx[$i]; 00105 if(!$args->module_srls_info[$srl]) continue; 00106 $args->mid_lists[$srl] = $args->module_srls_info[$srl]->mid; 00107 } 00108 } 00109 } 00110 00111 // 아무런 모듈도 검색되지 않았다면 종료 00112 if(!count($args->modules_info)) return Context::get('msg_not_founded'); 00113 $args->module_srl = implode(',',$module_srls); 00114 } 00115 00119 // tab 형태 00120 if($args->tab_type == 'none' || $args->tab_type == '') { 00121 switch($args->content_type){ 00122 case 'comment': 00123 $content_items = $this->_getCommentItems($args); 00124 break; 00125 case 'image': 00126 $content_items = $this->_getImageItems($args); 00127 break; 00128 case 'rss': 00129 $content_items = $this->getRssItems($args); 00130 break; 00131 case 'trackback': 00132 $content_items = $this->_getTrackbackItems($args); 00133 break; 00134 default: 00135 $content_items = $this->_getDocumentItems($args); 00136 break; 00137 } 00138 // tab 형태가 아닐 경우 00139 } else { 00140 $content_items = array(); 00141 00142 switch($args->content_type){ 00143 case 'comment': 00144 foreach($args->mid_lists as $module_srl => $mid){ 00145 $args->module_srl = $module_srl; 00146 $content_items[$module_srl] = $this->_getCommentItems($args); 00147 } 00148 break; 00149 case 'image': 00150 foreach($args->mid_lists as $module_srl => $mid){ 00151 $args->module_srl = $module_srl; 00152 $content_items[$module_srl] = $this->_getImageItems($args); 00153 } 00154 break; 00155 case 'rss': 00156 $content_items = $this->getRssItems($args); 00157 break; 00158 case 'trackback': 00159 foreach($args->mid_lists as $module_srl => $mid){ 00160 $args->module_srl = $module_srl; 00161 $content_items[$module_srl] = $this->_getTrackbackItems($args); 00162 } 00163 break; 00164 default: 00165 foreach($args->mid_lists as $module_srl => $mid){ 00166 $args->module_srl = $module_srl; 00167 $content_items[$module_srl] = $this->_getDocumentItems($args); 00168 } 00169 break; 00170 } 00171 } 00172 00173 $output = $this->_compile($args,$content_items); 00174 return $output; 00175 }

| content::requestFeedContents | ( | $ | rss_url | ) |
rss 주소로 부터 내용을 받아오는 함수 tistory 의 경우 원본 주소가 location 헤더를 뿜는다. (내용은 없음)이를 해결하기 위한 수정 - rss_reader 위젯과 방식 동일
content.class.php 파일의 399 번째 라인에서 정의되었습니다.
다음을 참조함 : Context::convertEncodingStr(), FileHandler::getRemoteResource(), null.
다음에 의해서 참조됨 : _getRssItems().
00399 { 00400 $rss_url = str_replace('&','&',Context::convertEncodingStr($rss_url)); 00401 return FileHandler::getRemoteResource($rss_url, null, 3, 'GET', 'application/xml'); 00402 }

1.6.1