XPressME Integration Kit

Trac

source: branches/Ver3.0/xpressme_integration_kit/include/oninstall.php @ 733

Last change on this file since 733 was 733, checked in by toemon, 13 years ago

XOOPS mainfile.phpからDB接続情報を取得する方法の変更

File size: 13.1 KB
Line 
1<?php
2$mydirpath = dirname(dirname(__FILE__));
3$mydirname = basename($mydirpath);
4$lang = @$GLOBALS["xoopsConfig"]['language'];
5global $wp_db_version,$wp_rewrite;
6include_once $mydirpath .'/wp-includes/version.php' ;
7
8// language file (modinfo.php)
9
10if( file_exists( $mydirpath .'/language/'.$lang.'/modinfo.php' ) ) {
11        include_once $mydirpath .'/language/'.$lang.'/modinfo.php' ;
12} else if( file_exists(  $mydirpath .'/language/english/modinfo.php' ) ) {
13        include_once $mydirpath .'/language/english/modinfo.php' ;
14}
15
16
17eval( ' function xoops_module_install_'.$mydirname.'( $module ) { return xpress_oninstall_base( $module , "'.$mydirname.'" ) ; } ' ) ;
18
19
20if( ! function_exists( 'xpress_oninstall_base' ) ) :
21function xpress_oninstall_base( $module , $mydirname )
22{
23        // transations on module install
24
25        global $ret ; // TODO :-D
26
27        // for Cube 2.1
28        if( defined( 'XOOPS_CUBE_LEGACY' ) ) {
29                $root =& XCube_Root::getSingleton();
30                $root->mDelegateManager->add( 'Legacy.Admin.Event.ModuleInstall.' . ucfirst($mydirname) . '.Success' , 'xpress_message_append_oninstall' ) ;
31                $root->mDelegateManager->add( 'Legacy.Admin.Event.ModuleInstall.' . ucfirst($mydirname) . '.Fail' , 'xpress_message_append_oninstall_err' ) ;
32                $ret = array() ;
33        } else {
34                if( ! is_array( $ret ) ) $ret = array() ;
35        }
36
37        $db =& Database::getInstance() ;
38        $mid = $module->getVar('mid') ;
39
40        if( defined( 'XOOPS_CUBE_LEGACY' ) ) {
41                $ret[] = "********************************* Install Log ********************************<br />";
42        } else {
43                $ret[] = '<h4 style="border-bottom: 1px dashed rgb(0, 0, 0); text-align: left; margin-bottom: 0px;">Install Log</h4>';
44    }
45
46//xpress
47        global $wpdb,$wp_rewrite, $wp_queries, $table_prefix, $wp_db_version, $wp_roles, $wp_query,$wp_embed;
48        global $xoops_config;
49               
50        define("WP_INSTALLING", true);
51       
52        $site_url= XOOPS_URL."/modules/".$mydirname;
53        $mydirpath = XOOPS_ROOT_PATH . '/modules/' . $mydirname;
54        $path = $mydirpath . '/';
55        $site_name = ucfirst($mydirname) . ' ' . _MI_XP2_NAME;
56       
57// permission and wordpress files check
58        require_once ($path . 'include/pre_check.php');
59        if(! xp_permission_check($mydirname, $mydirpath)){
60                if( ! defined( 'XOOPS_CUBE_LEGACY' ) ) {
61                        $ret = $GLOBALS["err_log"];
62                        $ret[] = "<br /><span style=\"color:#ff0000;\">The uninstallation of the module is executed now. </span><br />";
63                        $ret[] = xoops_module_uninstall($mydirname);
64                }
65                return false;
66        }
67       
68// install WordPress
69        if (file_exists($path . 'wp-load.php')) {
70                require_once $path . 'wp-load.php';
71        } else {
72                require_once $path . 'wp-config.php';
73        }
74        include_once($mydirpath . '/wp-admin/upgrade-functions.php');
75        wp_cache_flush();
76        make_db_current_silent();
77        $ret[] = "The data base of wordpress was made by prefix $table_prefix.<br />";
78       
79        $option_desc = __('WordPress web address');
80        $wpdb->query("INSERT INTO $wpdb->options (blog_id, option_name,option_value, autoload) VALUES ('0', 'siteurl','$site_url', 'yes')");   
81        $wpdb->query("INSERT INTO $wpdb->options (blog_id, option_name,option_value, autoload) VALUES ('0', 'home','$site_url', 'yes')");
82
83        populate_options();
84        populate_roles();
85       
86// create XPressME table
87        $xp_prefix = preg_replace('/wordpress/','wp',$mydirname);
88        $views_table = XOOPS_DB_PREFIX . '_' . $xp_prefix .'_views' ;
89
90        $charset_collate = '';
91        if ( version_compare(mysql_get_server_info(), '4.1.0', '>=') ) {
92                if ( ! empty($wpdb->charset) )
93                        $charset_collate = "DEFAULT CHARACTER SET $wpdb->charset";
94                if ( ! empty($wpdb->collate) )
95                        $charset_collate .= " COLLATE $wpdb->collate";
96        }
97        $views_queries ="CREATE TABLE $views_table (
98                blog_id bigint(20) unsigned NOT NULL default '0',
99                post_id bigint(20) unsigned NOT NULL default '0',
100                post_views bigint(20) unsigned NOT NULL default '0',
101                KEY post_id (post_id)
102                )$charset_collate;";
103        dbDelta($views_queries);
104        $ret[] = "$views_table table of XPressME was made.<br />";
105       
106        $d3forum_link = XOOPS_DB_PREFIX . '_' . $xp_prefix .'_d3forum_link' ;
107        $views_queries ="CREATE TABLE $d3forum_link (
108                comment_ID bigint(20) unsigned NOT NULL default '0',
109                post_id int(10) unsigned NOT NULL default '0' ,
110                wp_post_ID bigint(20) unsigned NOT NULL default '0',
111                forum_id bigint(20) unsigned NOT NULL default '0',
112                blog_id bigint(20) unsigned NOT NULL default '0',
113                KEY post_id (post_id)
114                )$charset_collate;";
115        dbDelta($views_queries);
116        $ret[] = "$d3forum_link table of XPressME was made.<br />";
117       
118        $group_role = XOOPS_DB_PREFIX . '_' . $xp_prefix .'_group_role' ;
119        $views_queries ="CREATE TABLE $group_role (
120                groupid smallint(5) unsigned NOT NULL default '0',
121                blog_id bigint(20) unsigned NOT NULL default '0',
122                name varchar(50)  NOT NULL default '' ,
123                description text  NOT NULL default '',
124                group_type varchar(50)  NOT NULL default '' ,
125                role varchar(20)  NOT NULL default '' ,
126                login_all smallint(5) unsigned NOT NULL default '0' ,
127                KEY groupid (groupid)
128                )$charset_collate;";
129        dbDelta($views_queries);
130        $ret[] = "$group_role table of XPressME was made.<br />";
131       
132        $notify_reserve = XOOPS_DB_PREFIX . '_' . $xp_prefix .'_notify_reserve' ;
133        $queries ="CREATE TABLE $notify_reserve (
134                notify_reserve_id bigint(20) NOT NULL AUTO_INCREMENT ,
135                notify_reserve_status varchar(20)  NOT NULL default '' ,
136                category text  NOT NULL default '',
137                item_id bigint(20) unsigned NOT NULL default '0',
138                event varchar(20) NOT NULL default '',
139                extra_tags_arry longtext NOT NULL default '' ,
140                user_list_arry longtext NOT NULL default '' ,
141                module_id smallint(5) unsigned NOT NULL default '0' ,
142                omit_user_id varchar(20) NOT NULL default '' ,
143                KEY notify_reserve_id (notify_reserve_id)
144                )TYPE=MyISAM";
145        dbDelta($queries);
146        $ret[] = "$notify_reserve table of XPressME was made.<br />";
147
148        $sql = "INSERT INTO $group_role (groupid, role) VALUES (1, 'administrator')";
149        $wpdb->query($sql);
150       
151// make templates
152        include_once XOOPS_ROOT_PATH . '/modules/' . $mydirname . '/include/xpress_templates_make.php' ;
153        $t_mess = xpress_templates_make($mid,$mydirname);
154       
155// Admin User Data write
156        // Change uid field
157        $wpdb->query("ALTER TABLE $wpdb->posts CHANGE `post_author` `post_author` mediumint(8) NOT NULL DEFAULT '0'");
158        $user_name = is_object($GLOBALS["xoopsUser"])?$GLOBALS["xoopsUser"]->getVar("uname"):'admin';
159        $email = is_object($GLOBALS["xoopsUser"])?$GLOBALS["xoopsUser"]->getVar("email"):'foo@exsample.com';
160        $pass_md5 = is_object($GLOBALS["xoopsUser"])?$GLOBALS["xoopsUser"]->getVar("pass"):'';
161       
162        if (!function_exists('username_exists')){
163                require_once($mydirpath . '/wp-includes/registration-functions.php');
164        }
165        $user_id = username_exists($user_name);
166        if ( !$user_id ) {
167                $random_password = 'admin';
168                $user_id = wp_create_user($user_name, $random_password, $email);
169        } else {
170                $random_password = __('User already exists.  Password inherited.');
171        }
172
173        $user = new WP_User($user_id);
174        $user->set_role('administrator');
175        'User ' . $user_name . ' of the administrator was made.';
176        // over write xoops md5 password
177        $sql = "UPDATE $wpdb->users SET user_pass ='$pass_md5' WHERE ID = $user_id";
178        $wpdb->query($sql);
179        $ret[] = 'The password of XOOPS was copied.<br />';
180       
181       
182// Set Default data
183        // make WordPress Default data 
184        if (function_exists('wp_install_defaults')){
185                wp_install_defaults($user_id);
186        } else {
187                wp_install_old_defaults($user_id);
188        }
189       
190        $ret[] = 'The first sample post & comment was written.<br />';
191       
192        // Rewrite Option for Xpress
193        $xoops_config_tbl = XOOPS_DB_PREFIX . '_config' ;
194        $sql = "SELECT conf_value FROM  $xoops_config_tbl WHERE `conf_name` = 'default_TZ'";
195        $xoops_default_TZ = $wpdb->get_var($sql);
196        update_option('gmt_offset', $xoops_default_TZ);
197
198        if (WPLANG == 'ja_EUC') {
199                $setup_charset = 'EUC-JP';
200        } elseif(WPLANG == 'ja_SJIS') {
201                $setup_charset = 'Shift_JIS';
202        } else {
203                $setup_charset = 'UTF-8';
204        }
205        update_option("blog_charset", $setup_charset);
206
207        update_option('blogname', $site_name );
208        update_option('blogdescription', 'WordPress for XOOPS');
209        update_option("admin_email", $GLOBALS["xoopsConfig"]['adminmail']);
210        update_option("ping_sites", "http://rpc.pingomatic.com/\nhttp://ping.xoopsforge.com/");
211        update_option("home", $site_url);
212        update_option("siteurl", $site_url);
213        update_option("what_to_show", "posts");
214        update_option('default_pingback_flag', 0);
215        $ret[] = 'The initial data was written in the data base of wordpress.<br />';
216       
217        update_option("template", "xpress_default");
218        update_option("stylesheet", "xpress_default");
219        $ret[] = 'The default theme of wordpress was set to xpress_default.<br />';
220//      update_option('uploads_use_yearmonth_folders', 1);
221        update_option('upload_path', 'wp-content/uploads');
222                       
223// activate the xpressme plugin
224        require_once dirname( __FILE__ ).'/xpress_active_plugin.php';
225        if (xpress_pulugin_activation('xpressme/xpressme.php')){
226                $ret[] = 'The xpressme plug-in was activated.<br />';
227        } else {
228                $GLOBALS["err_log"][] =  '<span style="color:#ff0000;">failed in the activation of xpressme plug-in.</span><br />';
229                return false;
230        }
231
232        $ret = array_merge($ret,$t_mess);
233
234        return true ;
235}
236endif;
237
238if( ! function_exists( 'xpress_message_append_oninstall' ) ) :
239function xpress_message_append_oninstall( &$module_obj , &$log )
240{
241        if( is_array( @$GLOBALS['ret'] ) ) {
242                foreach( $GLOBALS['ret'] as $message ) {
243                        $log->add( strip_tags( $message ) ) ;
244                }
245        }
246
247        // use mLog->addWarning() or mLog->addError() if necessary
248}
249endif;
250
251if( ! function_exists( 'xpress_message_append_oninstall_err' ) ) :
252function xpress_message_append_oninstall_err( &$module_obj , &$log )
253{
254        if( is_array( @$GLOBALS["err_log"] ) ) {
255                foreach( $GLOBALS["err_log"] as $message ) {
256                        $log->add( strip_tags($message)) ;
257                }
258        }
259
260        // use mLog->addWarning() or mLog->addError() if necessary
261}
262endif;
263
264
265if( ! function_exists( 'wp_install_old_defaults' ) ) :
266function wp_install_old_defaults($user_id) {
267        global $wpdb;
268
269        // Now drop in some default links
270        $wpdb->query("INSERT INTO $wpdb->linkcategories (cat_id, cat_name) VALUES (1, '".$wpdb->escape(__('Blogroll'))."')");
271        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://blogs.linux.ie/xeer/', 'Donncha', 1, 'http://blogs.linux.ie/xeer/feed/', '');");
272        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://zengun.org/weblog/', 'Michel', 1, 'http://zengun.org/weblog/feed/', '');");
273        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://boren.nu/', 'Ryan', 1, 'http://boren.nu/feed/', '');");
274        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://photomatt.net/', 'Matt', 1, 'http://xml.photomatt.net/feed/', '');");
275        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://zed1.com/journalized/', 'Mike', 1, 'http://zed1.com/journalized/feed/', '');");
276        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://www.alexking.org/', 'Alex', 1, 'http://www.alexking.org/blog/wp-rss2.php', '');");
277        $wpdb->query("INSERT INTO $wpdb->links (link_url, link_name, link_category, link_rss, link_notes) VALUES ('http://dougal.gunters.org/', 'Dougal', 1, 'http://dougal.gunters.org/feed/', '');");
278
279        // Default category
280        $wpdb->query("INSERT INTO $wpdb->categories (cat_ID, cat_name, category_nicename, category_count, category_description) VALUES ('0', '".$wpdb->escape(__('Uncategorized'))."', '".sanitize_title(__('Uncategorized'))."', '1', '')");
281
282        // First post
283        $now = date('Y-m-d H:i:s');
284        $now_gmt = gmdate('Y-m-d H:i:s');
285        $wpdb->query("INSERT INTO $wpdb->posts (post_author, post_date, post_date_gmt, post_content, post_excerpt, post_title, post_category, post_name, post_modified, post_modified_gmt, comment_count, to_ping, pinged, post_content_filtered) VALUES ('1', '$now', '$now_gmt', '".$wpdb->escape(__('Welcome to WordPress. This is your first post. Edit or delete it, then start blogging!'))."', '', '".$wpdb->escape(__('Hello world!'))."', '0', '".$wpdb->escape(__('hello-world'))."', '$now', '$now_gmt', '1', '', '', '')");
286
287        $wpdb->query( "INSERT INTO $wpdb->post2cat (`rel_id`, `post_id`, `category_id`) VALUES (1, 1, 1)" );
288
289        // Default comment
290        $wpdb->query("INSERT INTO $wpdb->comments (comment_post_ID, comment_author, comment_author_email, comment_author_url, comment_date, comment_date_gmt, comment_content) VALUES ('1', '".$wpdb->escape(__('Mr WordPress'))."', '', 'http://wordpress.org/', '$now', '$now_gmt', '".$wpdb->escape(__('Hi, this is a comment.<br />To delete a comment, just log in and view the post&#039;s comments. There you will have the option to edit or delete them.'))."')");
291
292        // First Page
293
294        $wpdb->query("INSERT INTO $wpdb->posts (post_author, post_date, post_date_gmt, post_content, post_excerpt, post_title, post_category, post_name, post_modified, post_modified_gmt, post_status, to_ping, pinged, post_content_filtered) VALUES ('1', '$now', '$now_gmt', '".$wpdb->escape(__('This is an example of a WordPress page, you could edit this to put information about yourself or your site so readers know where you are coming from. You can create as many pages like this one or sub-pages as you like and manage all of your content inside of WordPress.'))."', '', '".$wpdb->escape(__('About'))."', '0', '".$wpdb->escape(__('about'))."', '$now', '$now_gmt', 'static', '', '', '')");
295}
296endif;
297?>
Note: See TracBrowser for help on using the repository browser.