OSDN Git Service

translated
[nucleus-jp/nucleus-jp-ancient.git] / utf8 / nucleus / upgrades / upgrade2.5.php
1 <?php\r
2 function upgrade_do25() {\r
3 \r
4         if (upgrade_checkinstall(25))\r
5                 return 'already installed';\r
6 \r
7         // -------------------- 2.0 -> 2.2 (dev only) --------------------\r
8         // (avoid doing this twice :))\r
9         if (!upgrade_checkinstall(22))  {\r
10                 // 1. create nucleus_plugin_option_desc table\r
11                 // create new table: nucleus_plugin_option\r
12                 $query = 'CREATE TABLE IF NOT EXISTS '. sql_table('plugin_option_desc') . '('\r
13                            ." oid int(11) NOT NULL auto_increment UNIQUE,"\r
14                            ." opid int(11) NOT NULL,"\r
15                            ." oname varchar(20) NOT NULL,"\r
16                            ." ocontext varchar(20) NOT NULL,"\r
17                            ." odesc varchar(255),"\r
18                            ." otype varchar(20),"\r
19                            ." odef text,"\r
20                            ." oextra text,"\r
21                            ." PRIMARY KEY(opid, oname, ocontext)"\r
22                            .") TYPE=MyISAM;";\r
23                 upgrade_query('Creating ' . sql_table('plugin_option_desc') . ' table',$query);\r
24 \r
25                 // 2. move all data from plugin_option to plugin_option_desc\r
26                 $query = 'SELECT * FROM ' . sql_table('plugin_option') .' ORDER BY oid ASC';\r
27                 $res = sql_query($query);\r
28                 $aValues = array();\r
29                 while ($o = mysql_fetch_object($res)) {\r
30                         $query = 'INSERT INTO ' . sql_table('plugin_option_desc')\r
31                                    .' (opid, oname, ocontext, odesc, otype)'\r
32                                    ." VALUES ("\r
33                                                 ."'".addslashes($o->opid)."',"\r
34                                                 ."'".addslashes($o->oname) ."',"\r
35                                                 ."'global',"\r
36                                                 ."'".addslashes($o->odesc) ."',"\r
37                                                 ."'".addslashes($o->otype) ."')";\r
38                         upgrade_query('Moving option description for '.htmlspecialchars($o->oname).' to ' . sql_table('plugin_option_desc'), $query);\r
39 \r
40                         // store new id\r
41                         $aValues[] = array ( \r
42                                                         'id' => mysql_insert_id(),\r
43                                                         'value' => $o->ovalue\r
44                                                 );\r
45 \r
46                 }\r
47 \r
48                 // 3. alter plugin_options table \r
49                 $query = 'ALTER TABLE ' . sql_table('plugin_option')\r
50                            .' DROP PRIMARY KEY,'\r
51                            .' DROP KEY oid,'\r
52                            .' DROP COLUMN opid,'\r
53                            .' DROP COLUMN oname,'\r
54                            .' DROP COLUMN odesc,'\r
55                            .' DROP COLUMN otype,'               \r
56                            .' ADD ocontextid INT(11) NOT NULL,'\r
57                            .' ADD PRIMARY KEY (oid, ocontextid)';\r
58                 upgrade_query('Altering ' . sql_table('plugin_option') . ' table', $query);\r
59 \r
60                 // 4. delete from plugin_options\r
61                 $query = 'DELETE FROM ' . sql_table('plugin_option');\r
62                 upgrade_query('Cleaning ' . sql_table('plugin_option'), $query);\r
63 \r
64                 // 5. refill plugin_options\r
65                 foreach ($aValues as $aInfo) {\r
66                         $query = 'INSERT INTO ' . sql_table('plugin_option') \r
67                                    .' (oid, ocontextid, ovalue)'\r
68                                    ." VALUES (".$aInfo['id'].",'0','".addslashes($aInfo['value'])."')";\r
69                         upgrade_query('Re-filling ' . sql_table('plugin_option') . ' ('.$aInfo['id'].')', $query);\r
70                 }       \r
71         }               \r
72         \r
73         // -------------------- 2.0 -> 2.5 --------------------\r
74         \r
75         if (!upgrade_checkIfIndexExists('item', array('ibody', 'ititle', 'imore'))) {\r
76                 // add fulltext indices for search\r
77                 $query = 'ALTER TABLE ' . sql_table('item') . ' ADD FULLTEXT(ibody, ititle, imore)';\r
78                 upgrade_query('Adding fulltext index to item table', $query);\r
79                 // repair table is needed (build index)\r
80                 upgrade_query('Repairing item table', 'REPAIR TABLE ' . sql_table('item'));\r
81         }\r
82         \r
83         if (!upgrade_checkIfIndexExists('comment', array('cbody'))) {\r
84                 $query = 'ALTER TABLE ' . sql_table('comment') . ' ADD FULLTEXT(cbody)';\r
85                 upgrade_query('Adding fulltext index to comments table', $query);       \r
86                 upgrade_query('Repairing comment table', 'REPAIR TABLE ' . sql_table('comment'));       \r
87         }       \r
88         \r
89         if (!upgrade_checkinstall(24))  {\r
90             $query = ' ALTER TABLE ' . sql_table('blog') . ' ADD bincludesearch TINYINT(2) DEFAULT 0';\r
91                 upgrade_query('Adding bincludesearch column to blog', $query);\r
92         }\r
93         \r
94         // modify plugin option table value column type to TEXT\r
95         $query = 'ALTER TABLE ' . sql_table('plugin_option') . ' MODIFY ovalue TEXT NOT NULL default \'\'';\r
96         upgrade_query('Modifying plugin options column type', $query);\r
97         \r
98         // insert database version  (allows us to do better version checking in v3.0 upgrades)\r
99         $query = 'INSERT INTO ' . sql_table('config') . ' (name,value) VALUES (\'DatabaseVersion\',\'250\')';\r
100         upgrade_query('Adding DatabaseVersion to config table', $query);\r
101 \r
102         // insert External Authentication global option\r
103         $query = 'INSERT INTO ' . sql_table('config') . ' (name,value) VALUES (\'ExtAuth\',\'0\')';\r
104         upgrade_query('Adding External Authentication option to config table', $query); \r
105 }\r
106 \r
107 ?>\r