XPressME Integration Kit

Trac

source: trunk/xpressme_integration_kit/include/search.php @ 716

Last change on this file since 716 was 689, checked in by toemon, 14 years ago

検索時、最初のリスト項目のタイトルが表示されないバグを修正 Fixed#392

File size: 4.2 KB
RevLine 
[30]1<?php
2$mydirname = basename( dirname(dirname( __FILE__ ) ) );
3
4eval( '
5
6function  '.$mydirname.'_global_search( $keywords , $andor , $limit , $offset , $userid )
7{
8        return xpress_global_search_base( "'.$mydirname.'" , $keywords , $andor , $limit , $offset , $userid ) ;
9}
10
11' ) ;
12
13
14if( ! function_exists( 'xpress_global_search_base' ) ) {
[415]15        function xpress_global_search_base( $mydirname , $queryarray , $andor , $limit , $offset , $userid ){
16                global $xoopsDB, $myts;
17               
18                require_once (XOOPS_ROOT_PATH . '/modules/'.$mydirname . '/include/general_functions.php');
[30]19
[415]20                $myts =& MyTextSanitizer::getInstance();
21               
[583]22                $xp_prefix = preg_replace('/wordpress/','wp',$mydirname);
[415]23                if ($userid) {
[496]24                        $wp_uid = xoops_uid_to_wp_uid(intval($userid),$mydirname);
[415]25                }
[30]26
[415]27                $prefix= XOOPS_DB_PREFIX . '_' . $xp_prefix  ;
28                $posts_tables = get_table_list($prefix,'posts');
29                $i = 0;
30                $ret = array();
31                foreach( $posts_tables as $views_table){
32                        $mid_prefix = get_multi_mid_prefix($prefix,'posts' , $views_table);
33                        $option_table = $prefix . $mid_prefix . 'options';
34                        $time_difference = get_blog_option($option_table ,'gmt_offset');
35                        $blog_url = get_blog_option($option_table , 'siteurl');
36                        $pattern = '/.*' . $mydirname . '/';
37                        $mid_url = preg_replace($pattern, '' , $blog_url);
38                        $mid_url = preg_replace('/\//' , '' , $mid_url);
39                        if (!empty($mid_url)) $mid_url = $mid_url . '/' ;
40                       
41                        $blog_name = get_blog_option($option_table , 'blogname');
42                        if (empty($mid_url)) $blog_name = ''; else $blog_name = $blog_name . ':: ';
43                       
44                        $now = date('Y-m-d H:i:s',(time() + ($time_difference * 3600)));
[609]45                        $where = "(post_status = 'publish') AND (post_date <= '".$now."') AND (post_type <> 'revision') AND (post_type <> 'nav_menu_item') ";
[30]46
[415]47                        if ( is_array($queryarray) && $count = count($queryarray) ) {
48                                $str_query = array();
[689]49                                for($j=0;$j<$count;$j++){
50                                        $str_query[] = "(post_title LIKE '%".$queryarray[$j]."%' OR post_content LIKE '%".$queryarray[$j]."%')";
[415]51                                }
52                                $where .= " AND ".implode(" $andor ", $str_query);
53                        }
54                        if ($userid) {
[496]55                                if ($wp_uid){
56                                        $where  .= " AND (post_author=".$wp_uid.")";
57                                } else {
58                                        $where  .= " AND 0 ";
59                                }
[415]60                        }
[30]61
[415]62                        $request = "SELECT * FROM " . $views_table ." WHERE ".$where;
63                        $request .= " ORDER BY post_date DESC";
64                        $result = $xoopsDB->query($request,$limit,$offset);
65                        while($myrow = $xoopsDB->fetchArray($result)){
[609]66                                if ($myrow['post_type'] !=='revision' && $myrow['post_type'] !=='nav_menu_item')
[415]67                                switch ($myrow['post_type']) {
68                                case 'page':
69                                        $ret[$i]['link'] = $mid_url . '?page_id=' . $myrow['ID'];
70                                        break;
71                                case 'post':
72                                case '':
73                                        $ret[$i]['link'] = $mid_url . '?p=' . $myrow['ID'];
[607]74                                        break;
75                                default:
[609]76                                        $ret[$i]['link'] = $mid_url . '?'.$myrow['post_type'].'=' .$myrow['post_name'];
[415]77                                }
78                                $ret[$i]['title'] = $blog_name . $myts->htmlSpecialChars($myrow['post_title']);
79                                $date_str = $myrow['post_date'];
80                                $yyyy = substr($date_str,0,4);
81                                $mm   = substr($date_str,5,2);
82                                $dd   = substr($date_str,8,2);
83                                $hh   = substr($date_str,11,2);
84                                $nn   = substr($date_str,14,2);
85                                $ss   = substr($date_str,17,2);
86                                $ret[$i]['time'] = mktime( $hh,$nn,$ss,$mm,$dd,$yyyy);
87                                $ret[$i]['uid'] = wp_uid_to_xoops_uid($myrow['post_author'],$mydirname);
[30]88
[415]89                                $context = '' ;
90                                $text =$myrow['post_content'];
91                                // get context for module "search"
92                                $showcontext = empty( $_GET['showcontext'] ) ? 0 : 1 ;
93                                if( function_exists( 'search_make_context' ) && $showcontext ) {
94                                        if( function_exists( 'easiestml' ) ) $text = easiestml( $text ) ;
95                                        $full_context = strip_tags($text) ;
96                                        $context = search_make_context( $full_context , $queryarray ) ;
97                                }
98                                $ret[$i]['context']=$context;
99                                $i++;
100                        }
[30]101                }
[415]102                return $ret;
[30]103
104        }
105}
106
[415]107if( ! function_exists( 'get_blog_option' ) ) {
108        function get_blog_option($option_table,$option_name){
109                $xoopsDB =& Database::getInstance();
[30]110
[415]111                $sql = "SELECT option_value FROM $option_table WHERE option_name = '" . $option_name . "'";
112               
113                $result =  $xoopsDB->query($sql, 0, 0);
114                if ($xoopsDB->getRowsNum($result)  > 0){
115                        $row = $xoopsDB->fetchArray($result);
116                        return $row['option_value'];
117                }
118                return 0;
[30]119        }
120}
121
122?>
Note: See TracBrowser for help on using the repository browser.