XPressME Integration Kit

Trac

source: trunk/xpressme_integration_kit/wp-content/plugins/xpressme/include/xpress_common_functions.php @ 283

Last change on this file since 283 was 283, checked in by toemon, 15 years ago

WP2011のマルチユーザモード時、ユーザ選択を行うと投稿者ブロックにもフィルターがかかってしまうバグ修正 fixes #155

File size: 10.3 KB
Line 
1<?php
2global $xoops_config;
3if (!is_object($xoops_config)){ // is call other modules
4        require_once dirname(dirname(dirname(dirname(dirname( __FILE__ ))))) .'/class/config_from_xoops.class.php' ;
5        $xoops_config = new ConfigFromXoops;
6}
7
8function get_xoops_config($config_name,$module_dir){
9        global $xoops_db;
10       
11        $modules_db = get_xoops_prefix() . 'modules';
12        $config_db = get_xoops_prefix() . 'config';
13
14        $moduleID = $xoops_db->get_var("SELECT mid FROM $modules_db WHERE dirname = '$module_dir'");
15        if (empty($moduleID)) return null;
16        $conf_value = $xoops_db->get_var("SELECT conf_value FROM $config_db WHERE (conf_modid = $moduleID) AND (conf_name = '$config_name')");
17        if (empty($conf_value)) return null;
18        return  $conf_value;
19}
20
21// xoops db
22function get_xpress_dir_path()
23{
24        return ABSPATH;
25}
26
27function get_xpress_dir_name()
28{
29        return basename(ABSPATH);
30}
31
32function get_wp_prefix_only()
33{
34        $dir_name = get_xpress_dir_name();
35        $prefix = $dir_name;
36        if ($prefix == 'wordpress') $prefix = 'wp';
37       
38        $prefix = $prefix . '_';
39        return $prefix;
40}
41
42function get_xoops_prefix()
43{
44        global $xoops_config;
45        $ret =$xoops_config->xoops_db_prefix . '_';
46        return $ret;
47}
48
49function get_xoops_trust_path()
50{
51        global $xoops_config;
52        $ret =$xoops_config->xoops_trust_path;
53        return $ret;
54}
55
56function get_xoops_root_path()
57{
58        global $xoops_config;
59        $ret =$xoops_config->xoops_root_path;
60        return $ret;
61}
62
63function get_wp_prefix()
64{
65        $prefix = get_xoops_prefix() . get_wp_prefix_only();
66        return $prefix;
67}
68function get_xoops_url()
69{
70        global $xoops_config;
71        $ret =$xoops_config->xoops_url ;
72        return $ret;
73}
74
75function get_xpress_url()
76{
77        global $xoops_config;
78        $ret =$xoops_config->module_url ;
79        return $ret;
80}
81
82function get_xpress_modid()
83{
84        global $xoops_db;
85       
86        $modulename = get_xpress_dir_name();   
87        $sql = "SELECT mid FROM " . get_xoops_prefix() . "modules WHERE dirname = '$modulename'";
88        $mid = $xoops_db->get_var($sql);
89        return $mid;   
90}
91
92function get_xpress_db_version()
93{
94        include get_xpress_dir_path() . '/wp-includes/version.php';
95        return $wp_db_version;
96}
97
98function is_xpress_mobile()
99{
100        //ktai_style
101        if (function_exists('is_ktai')){
102                if (is_ktai()) {
103 //                     $file_path = $GLOBALS['xoopsModuleConfig']["ktai_style_tmpdir"] . '/comments.php';
104                        return true;
105                }
106        }
107       
108        //mobg
109        if (function_exists('is_mobile')) {
110                if (is_mobile()){
111                        return true;
112                }
113        }
114        if (
115          preg_match("/DoCoMo/", $_SERVER['HTTP_USER_AGENT']) ||
116          preg_match("/softbank/", $_SERVER['HTTP_USER_AGENT']) ||
117          preg_match("/vodafone/", $_SERVER['HTTP_USER_AGENT']) ||
118          preg_match("/J-PHONE/", $_SERVER['HTTP_USER_AGENT']) ||
119          preg_match("/UP\.Browser/", $_SERVER['HTTP_USER_AGENT']) ||
120          preg_match("/ASTEL/", $_SERVER['HTTP_USER_AGENT']) ||
121          preg_match("/PDXGW/", $_SERVER['HTTP_USER_AGENT'])
122        )
123        {
124                return true;
125        } else {
126                return false;
127        }
128}
129
130function block_cache_refresh()
131{
132        global $xoops_db;
133        $mid = get_xpress_modid();
134        $sql = "SELECT bid,options,func_file FROM " . get_xoops_prefix() . "newblocks WHERE mid = $mid";
135        $blocks = $xoops_db->get_results($sql);
136        $mydirname = get_xpress_dir_name();
137        require_once get_xpress_dir_path() . '/include/xpress_block_render.php';
138
139
140        foreach($blocks as $block){
141                $func_file = $block->func_file;
142                $call_theme_function_name = str_replace(".php", "", $func_file);
143                $inc_theme_file_name = str_replace(".php", "", $func_file) . '_theme.php';
144                $cache_title = str_replace(".php", "", $func_file);
145                $blockID = $block->bid;
146                $options = explode("|", $block->options);
147
148                $block_theme_file = get_block_file_path($mydirname,$inc_theme_file_name);
149                require_once $block_theme_file;
150                $block_render = $call_theme_function_name($options);            //The block name and the called function name should be assumed to be the same name.                     
151                $xml['block'] = $block_render;
152                $xml['block']['options'] = $block->options;
153                xpress_block_cache_write($mydirname,$cache_title. $blockID, $xml);
154        }
155}
156function is_wordpress_style()
157{
158        global $xpress_config;
159       
160        if ($xpress_config->viewer_type == 'wordpress') return true;
161        if ($xpress_config->viewer_type == 'xoops') return false;
162       
163        // user select
164        $get_style = isset($_GET["style"]) ? $_GET["style"] : '';
165        $cookie_style = isset($_COOKIE["xpress_style"]) ? $_COOKIE["xpress_style"] : '';
166       
167        // set style
168        if (!empty($get_style)){
169                $style = $get_style;
170        } else {
171                if (!empty($cookie_style)){
172                        $style = $cookie_style;
173                } else {
174                        $style = 'x';
175                }
176        }
177       
178        // set cookie
179        if (empty($cookie_style)){
180                setcookie("xpress_style", $style);
181                $_COOKIE["xpress_style"] = $style;
182        } else {
183                if ($style != $cookie_style) {
184                        setcookie("xpress_style", $style);
185                        $_COOKIE["xpress_style"] = $style;
186                }
187        }
188        if ($style == 'w') {
189                return true;
190        } else {
191                return false;
192        }
193}
194
195function wp_meta_add_xpress_menu()
196{
197        global $xpress_config;
198        if ($xpress_config->viewer_type == 'user_select'){
199                echo disp_mode_set();
200        }
201        if (function_exists('wp_theme_switcher') ) {   
202                echo '<li>' . __('Themes') . ':';
203                wp_theme_switcher('dropdown');
204                echo '</li>';
205        }
206}
207
208function disp_mode_set(){
209        global $xpress_config;
210       
211        $select ="";
212        if ($xpress_config->viewer_type == 'user_select'){
213                $style = isset($_GET["style"]) ? $_GET["style"] : (isset($_COOKIE["xpress_style"]) ? $_COOKIE["xpress_style"] : "");
214
215                switch($style) {
216                case 'w':
217                        $select ='<li><a href="'.get_settings('siteurl').'/?style=x" title="'. __('Switch to XOOPS mode','xpressme').'">'.__('Switch to XOOPS mode','xpressme').'</a></li>';
218//                      $select.='<img src="'. get_settings('siteurl').'/images/external.png" alt="'.__('Switch to XOOPS mode','xpressme') . '"></a></li>';
219                        break;
220                case 'x':
221                        $select='<li><a href="'.get_settings('siteurl').'/?style=w" title="'.__('Switch to WordPress mode','xpressme').'">'.__('Switch to WordPress mode','xpressme').'</a></li>';
222                        break;
223                default:
224                        $select='<li><a href="'.get_settings('siteurl').'/?style=w" title="'.__('Switch to WordPress mode','xpressme').'">'.__('Switch to WordPress mode','xpressme').'</a></li>';
225                        break;
226                }
227        }
228        return $select;
229}
230
231function xpress_comment_count( $count ) {
232        global $id;
233        $comments_by_type = &separate_comments(get_comments('status=approve&post_id=' . $id));
234        return count($comments_by_type['comment']);
235}
236
237function xpress_set_author_cookie($query_vars)
238{
239        global $wp , $wpdb;
240        $author_cookie = get_xpress_dir_name() . "_select_author" ;
241        if(xpress_is_multi_user()){
242                if (!empty($_GET)){
243                        $auth = intval( @$_GET["author"] );
244                        if ($auth > 0){
245                                setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
246                                $_COOKIE[$author_cookie] = $auth;
247                        }
248                } else {
249                        if(xpress_is_wp20()){
250                                if (!empty($wp->matched_query) ){
251                                        if (strpos($wp->matched_query,'author_name') !== false ){
252                                                $pattern = "author_name\s*=\s*(.*)\s*";
253                                                if ( preg_match ( "/".$pattern."/i", $wp->matched_query, $match ) ){
254                                                        $author_name = "$match[1]";
255                                                        $auth = $wpdb->get_var("SELECT ID FROM $wpdb->users WHERE user_login = '$author_name'");
256
257                                                        setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
258                                                        $_COOKIE[$author_cookie] = $auth;
259                                                }
260                                        }
261                                } else {
262                                        setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
263                                        $_COOKIE[$author_cookie] = 0;
264                                }
265                        } else {
266                                if (!empty($wp->query_vars) ){
267                                        if (!empty($wp->query_vars['author_name']) ){
268                                                $author_name = $wp->query_vars['author_name'];
269                                                $auth = $wpdb->get_var("SELECT ID FROM $wpdb->users WHERE user_login = '$author_name'");
270
271                                                setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
272                                                $_COOKIE[$author_cookie] = $auth;
273                                        }
274                                } else {
275                                        setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
276                                        $_COOKIE[$author_cookie] = 0;
277                                }
278                        }
279                }
280        }else{
281        //      $GLOBALS["wp_xoops_author"] = null;
282                setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
283                $_COOKIE[$author_cookie] = 0;
284        }
285        return $query_vars;
286}
287
288function xpress_query_filter(&$query)
289{
290        $author_cookie = get_xpress_dir_name() . "_select_author" ;
291       
292        if (strpos($query,'SELECT') === false)  return $query;
293
294        $select_pattern = "SELECT(.*)post_author(.*)FROM";
295        if (preg_match ( "/".$select_pattern."/i", $query, $select_match ))
296                return $query;
297
298        $query = preg_replace('/\s\s+/', ' ', $query);
299        if (!empty($_COOKIE[$author_cookie])){
300                if(xpress_is_wp20()){
301                        $pattern = "WHERE.*AND\s?\(*post_author\s*=";
302                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
303                                return $query;
304                        }
305                        $pattern = "WHERE\s?post_author\s*="; // get_usernumposts()
306                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
307                                return $query;
308                        }
309                        $pattern = "WHERE.*post_status\s*=\s*'publish'\s*\)?";
310                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
311                               
312                                $where_str = "$match[0]";
313                                $where_arry = split(' ',$where_str);
314                                $post_prefix = '';
315                                foreach ($where_arry as $p){
316                                        if ( preg_match ( "/post_status/", $p, $match3 ) ){
317                                                $post_prefix = preg_replace("/post_status/", "", $p);
318                                                $post_prefix = preg_replace("/\(/", "", $post_prefix);
319                                                break;
320                                        }
321                                }
322                                $patern = 'WHERE';                             
323                                $replace = "WHERE {$post_prefix}post_author = " . intval($_COOKIE[$author_cookie]) . " AND ";
324                                $query = preg_replace("/$patern/", $replace, $query);
325                        }
326                } else {
327                        $pattern = "WHERE.*post_type\s*=\s*'post'\s*\)?";                       
328                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
329                                $where_str = "$match[0]";
330                                $where_arry = split(' ',$where_str);
331                                $post_prefix = '';
332                                foreach ($where_arry as $p){
333                                        if ( preg_match ( "/post_type/", $p, $match3 ) ){
334                                                $post_prefix = preg_replace("/post_type/", "", $p);
335                                                $post_prefix = preg_replace("/\(/", "", $post_prefix);
336                                                break;
337                                        }
338                                }
339                                preg_match ( "/post_type(.*)/", $where_str, $p_match );
340                                $patern_s = $p_match[0];
341                                $patern = preg_replace('/\)/', '\)', $patern_s);
342                               
343                                $replace = $patern_s . " AND {$post_prefix}post_author = " . intval($_COOKIE[$author_cookie]) . " ";
344
345                                $query = preg_replace("/$patern/", $replace, $query);
346                        }
347                }
348        }
349//      xpress_show_sql_quary($query);
350        return $query;
351}
352
353function safe_site_url_filter($site_url){
354        global $xoops_config;
355        if (!$xoops_config->is_wpmu){
356                if ($site_url != get_xpress_url()) $site_url = get_xpress_url();
357        }
358        return $site_url;
359}
360
361?>
Note: See TracBrowser for help on using the repository browser.