content 클래스 참조

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

content에 대한 상속 다이어그램 :
Inheritance graph
content에 대한 협력 다이어그램:
Collaboration graph

모든 멤버 목록

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를 출력하는 위젯

작성자:
sol (sol@ngleader.com)
버전:
0.1

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('&amp;','&',Context::convertEncodingStr($rss_url));
00401             return FileHandler::getRemoteResource($rss_url, null, 3, 'GET', 'application/xml');
00402         }

이 함수 내부에서 호출하는 함수들에 대한 그래프입니다.:


이 클래스에 대한 문서화 페이지는 다음의 파일로부터 생성되었습니다.:

생성시간 : Wed Oct 28 22:59:51 2009, 프로젝트명 : XpressEngine, 생성자 :   doxygen 1.6.1