XPressME Integration Kit

Trac

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

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

Ver2.0.2 r285 修正マージ $154 マルチユーザモードで管理画面へ移行したときのバグ

File size: 10.4 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       
241        if (is_admin()) return $query_vars;
242       
243        $author_cookie = get_xpress_dir_name() . "_select_author" ;
244        if(xpress_is_multi_user()){
245                if (!empty($_GET)){
246                        $auth = intval( @$_GET["author"] );
247                        if ($auth > 0){
248                                setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
249                                $_COOKIE[$author_cookie] = $auth;
250                        }
251                } else {
252                        if(xpress_is_wp20()){
253                                if (!empty($wp->matched_query) ){
254                                        if (strpos($wp->matched_query,'author_name') !== false ){
255                                                $pattern = "author_name\s*=\s*(.*)\s*";
256                                                if ( preg_match ( "/".$pattern."/i", $wp->matched_query, $match ) ){
257                                                        $author_name = "$match[1]";
258                                                        $auth = $wpdb->get_var("SELECT ID FROM $wpdb->users WHERE user_login = '$author_name'");
259
260                                                        setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
261                                                        $_COOKIE[$author_cookie] = $auth;
262                                                }
263                                        }
264                                } else {
265                                        setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
266                                        $_COOKIE[$author_cookie] = 0;
267                                }
268                        } else {
269                                if (!empty($wp->query_vars) ){
270                                        if (!empty($wp->query_vars['author_name']) ){
271                                                $author_name = $wp->query_vars['author_name'];
272                                                $auth = $wpdb->get_var("SELECT ID FROM $wpdb->users WHERE user_login = '$author_name'");
273
274                                                setcookie($author_cookie, $auth, time()+3600, COOKIEPATH);
275                                                $_COOKIE[$author_cookie] = $auth;
276                                        }
277                                } else {
278                                        setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
279                                        $_COOKIE[$author_cookie] = 0;
280                                }
281                        }
282                }
283        }else{
284        //      $GLOBALS["wp_xoops_author"] = null;
285                setcookie($author_cookie, 0, time()+3600, COOKIEPATH);
286                $_COOKIE[$author_cookie] = 0;
287        }
288        return $query_vars;
289}
290
291function xpress_query_filter(&$query)
292{
293        if (is_admin()) return $query;
294
295        $author_cookie = get_xpress_dir_name() . "_select_author" ;
296       
297        if (strpos($query,'SELECT') === false)  return $query;
298
299        $select_pattern = "SELECT(.*)post_author(.*)FROM";
300        if (preg_match ( "/".$select_pattern."/i", $query, $select_match ))
301                return $query;
302
303        $query = preg_replace('/\s\s+/', ' ', $query);
304        if (!empty($_COOKIE[$author_cookie])){
305                if(xpress_is_wp20()){
306                        $pattern = "WHERE.*AND\s?\(*post_author\s*=";
307                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
308                                return $query;
309                        }
310                        $pattern = "WHERE\s?post_author\s*="; // get_usernumposts()
311                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
312                                return $query;
313                        }
314                        $pattern = "WHERE.*post_status\s*=\s*'publish'\s*\)?";
315                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
316                               
317                                $where_str = "$match[0]";
318                                $where_arry = split(' ',$where_str);
319                                $post_prefix = '';
320                                foreach ($where_arry as $p){
321                                        if ( preg_match ( "/post_status/", $p, $match3 ) ){
322                                                $post_prefix = preg_replace("/post_status/", "", $p);
323                                                $post_prefix = preg_replace("/\(/", "", $post_prefix);
324                                                break;
325                                        }
326                                }
327                                $patern = 'WHERE';                             
328                                $replace = "WHERE {$post_prefix}post_author = " . intval($_COOKIE[$author_cookie]) . " AND ";
329                                $query = preg_replace("/$patern/", $replace, $query);
330                        }
331                } else {
332                        $pattern = "WHERE.*post_type\s*=\s*'post'\s*\)?";                       
333                        if ( preg_match ( "/".$pattern."/i", $query, $match ) ){
334                                $where_str = "$match[0]";
335                                $where_arry = split(' ',$where_str);
336                                $post_prefix = '';
337                                foreach ($where_arry as $p){
338                                        if ( preg_match ( "/post_type/", $p, $match3 ) ){
339                                                $post_prefix = preg_replace("/post_type/", "", $p);
340                                                $post_prefix = preg_replace("/\(/", "", $post_prefix);
341                                                break;
342                                        }
343                                }
344                                preg_match ( "/post_type(.*)/", $where_str, $p_match );
345                                $patern_s = $p_match[0];
346                                $patern = preg_replace('/\)/', '\)', $patern_s);
347                               
348                                $replace = $patern_s . " AND {$post_prefix}post_author = " . intval($_COOKIE[$author_cookie]) . " ";
349
350                                $query = preg_replace("/$patern/", $replace, $query);
351                        }
352                }
353        }
354//      xpress_show_sql_quary($query);
355        return $query;
356}
357
358function safe_site_url_filter($site_url){
359        global $xoops_config;
360        if (!$xoops_config->is_wpmu){
361                if ($site_url != get_xpress_url()) $site_url = get_xpress_url();
362        }
363        return $site_url;
364}
365
366?>
Note: See TracBrowser for help on using the repository browser.