0byt3m1n1
Path:
/
data
/
applications
/
aps
/
geeklog
/
1.8.0-0
/
standard
/
htdocs
/
sql
/
updates
/
[
Home
]
File: mysql_1.3.11_to_1.4.0.php
<?php $_SQL[] = "CREATE TABLE {$_TABLES['trackback']} ( cid int(10) unsigned NOT NULL auto_increment, sid varchar(40) NOT NULL, url varchar(255) default NULL, title varchar(128) default NULL, blog varchar(80) default NULL, excerpt text, date datetime default NULL, type varchar(30) NOT NULL default 'article', ipaddress varchar(15) NOT NULL default '', PRIMARY KEY (cid), INDEX trackback_sid(sid), INDEX trackback_url(url), INDEX trackback_date(date), INDEX trackback_type(type) ) "; $_SQL[] = "CREATE TABLE {$_TABLES['pingservice']} ( pid smallint(5) unsigned NOT NULL auto_increment, name varchar(128) default NULL, ping_url varchar(255) default NULL, site_url varchar(255) default NULL, method varchar(80) default NULL, is_enabled tinyint(1) unsigned NOT NULL DEFAULT '1', PRIMARY KEY (pid), INDEX pingservice_is_enabled(is_enabled) ) "; $_SQL[] = "CREATE TABLE {$_TABLES['trackbackcodes']} ( code tinyint(4) NOT NULL default '0', name varchar(32) default NULL, PRIMARY KEY (code) ) "; // a weblog directory to ping (which, in turn, pings others) $_SQL[] = "INSERT INTO {$_TABLES['pingservice']} (pid, name, site_url, ping_url, method, is_enabled) VALUES (1, 'Ping-O-Matic', 'http://pingomatic.com/', 'http://rpc.pingomatic.com/', 'weblogUpdates.ping', 1)"; $_SQL[] = "INSERT INTO {$_TABLES['trackbackcodes']} (code, name) VALUES (0,'Trackback Enabled') "; $_SQL[] = "INSERT INTO {$_TABLES['trackbackcodes']} (code, name) VALUES (-1,'Trackback Disabled') "; // max. number of entries to import into a portal block $_SQL[] = "ALTER TABLE {$_TABLES['blocks']} ADD rdflimit smallint(5) unsigned NOT NULL default '0' AFTER rdfupdated"; // new story.ping feature (also see function upgrade_addFeature below) $_SQL[] = "INSERT INTO {$_TABLES['features']} (ft_name, ft_descr, ft_gl_core) VALUES ('story.ping', 'Ability to send pings, pingbacks, or trackbacks for stories', 1)"; // remote authentication fields $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD remoteusername varchar(60) NULL after username"; $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD remoteservice varchar(60) NULL after remoteusername"; // new user status, for ban etc. $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD status smallint(5) unsigned NOT NULL default '1'"; // Make all users WITH a password active. $_SQL[] = "UPDATE {$_TABLES['users']} SET status=3 WHERE (passwd IS NOT NULL) OR (passwd != '')"; // a few more indexes on the users table can' hurt ... $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD INDEX users_username(username)"; $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD INDEX users_fullname(fullname)"; $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD INDEX users_email(email)"; $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD INDEX users_passwd(passwd)"; $_SQL[] = "ALTER TABLE {$_TABLES['users']} ADD INDEX users_pwrequestid(pwrequestid)"; // Add the remote authenticated group: $_SQL[] = "INSERT INTO {$_TABLES['groups']} (grp_name, grp_descr, grp_gl_core) VALUES ('Remote Users', 'Users in this group can have authenticated against a remote server.',1) "; // for quicker access to large speedlimit tables $_SQL[] = "ALTER TABLE {$_TABLES['speedlimit']} ADD INDEX type_ipaddress(type,ipaddress)"; $_SQL[] = "ALTER TABLE {$_TABLES['speedlimit']} ADD INDEX date(date)"; // new 'in transit' status $_SQL[] = "ALTER TABLE {$_TABLES['stories']} ADD in_transit tinyint(1) unsigned default '0' AFTER frontpage"; $_SQL[] = "ALTER TABLE {$_TABLES['stories']} ADD INDEX stories_in_transit(in_transit)"; // trackback code - just like commentcode $_SQL[] = "ALTER TABLE {$_TABLES['stories']} ADD trackbackcode tinyint(4) NOT NULL default '0' AFTER commentcode"; // trackback counter $_SQL[] = "ALTER TABLE {$_TABLES['stories']} ADD trackbacks mediumint(8) unsigned NOT NULL default '0' AFTER comments"; // new header-link for feeds $_SQL[] = "ALTER TABLE {$_TABLES['syndication']} ADD header_tid varchar(48) NOT NULL default 'none' AFTER topic;"; // add logo $_SQL[] = "ALTER TABLE {$_TABLES['syndication']} ADD feedlogo varchar(255) AFTER description;"; // change default format to RSS-2.0 $_SQL[] = "ALTER TABLE {$_TABLES['syndication']} CHANGE format format varchar(20) NOT NULL default 'RSS-2.0';"; // Upgrade format values $_SQL[] = "UPDATE {$_TABLES['syndication']} SET format='Atom-0.3' WHERE format='atom'"; $_SQL[] = "UPDATE {$_TABLES['syndication']} SET format='RDF-1.0' WHERE format='rdf'"; $_SQL[] = "UPDATE {$_TABLES['syndication']} SET format='RSS-0.9x' WHERE format='rss'"; $_SQL[] = "UPDATE {$_TABLES['syndication']} SET format='RSS-2.0' WHERE format='rss2'"; // add links plugin $_SQL[] = "INSERT INTO {$_TABLES['plugins']} (pi_name, pi_version, pi_gl_version, pi_enabled, pi_homepage) VALUES ('links', '1.0', '1.4.0', 1, 'http://www.geeklog.net/')"; // update links feeds to links plugin $_SQL[] = "UPDATE {$_TABLES['syndication']} SET type = 'links', topic = 'all' WHERE topic = '::links';"; // add polls plugin $_SQL[] = "INSERT INTO {$_TABLES['plugins']} (pi_name, pi_version, pi_gl_version,pi_enabled, pi_homepage) VALUES ('polls', '1.0', '1.4.0', '1', 'http://www.geeklog.net/')"; // updates core -> plugin $_SQL[] = "UPDATE {$_TABLES['blocks']} SET type = 'phpblock', phpblockfn ='phpblock_polls' WHERE name = 'poll_block';"; $_SQL[] = "UPDATE {$_TABLES['features']} SET ft_gl_core = '0', ft_name='polls.edit' WHERE ft_name = 'poll.edit';"; $_SQL[] = "UPDATE {$_TABLES['groups']} SET grp_gl_core = '0', grp_name = 'Links Admin' WHERE grp_name = 'Link Admin';"; $_SQL[] = "UPDATE {$_TABLES['groups']} SET grp_gl_core = '0', grp_name = 'Polls Admin' WHERE grp_name = 'Poll Admin';"; // rename "link.*" features to "links.*" to match the plugin name $_SQL[] = "UPDATE {$_TABLES['features']} SET ft_name = 'links.moderate', ft_gl_core = '0' WHERE ft_name = 'link.moderate';"; $_SQL[] = "UPDATE {$_TABLES['features']} SET ft_name = 'links.edit', ft_gl_core = '0' WHERE ft_name = 'link.edit';"; $_SQL[] = "UPDATE {$_TABLES['features']} SET ft_name = 'links.submit', ft_gl_core = '0' WHERE ft_name = 'link.submit';"; // the included Spam-X requires Geeklog 1.4.0 now (for the MassDelete modules) $_SQL[] = "UPDATE {$_TABLES['plugins']} SET pi_version = '1.0.3', pi_gl_version = '1.4.0' WHERE pi_name = 'spamx'"; // Static Pages plugin is version 1.4.2 now $_SQL[] = "UPDATE {$_TABLES['plugins']} SET pi_version = '1.4.2', pi_gl_version = '1.4.0', pi_homepage = 'http://www.geeklog.net/' WHERE pi_name = 'staticpages'"; // update poll(s) comments $_SQL[] = "UPDATE {$_TABLES['comments']} SET type = 'polls' WHERE type = 'poll'"; // allow for more topic ids in the user's preferences (bug #490) $_SQL[] = "ALTER TABLE {$_TABLES['userindex']} CHANGE etids etids text"; // add a hits counter for events $_SQL[] = "ALTER TABLE {$_TABLES['events']} ADD hits mediumint(8) unsigned NOT NULL default '0' AFTER url"; $_SQL[] = "ALTER TABLE {$_TABLES['events']} ADD postmode varchar(10) NOT NULL default 'plaintext' AFTER description"; $_SQL[] = "ALTER TABLE {$_TABLES['personal_events']} ADD postmode varchar(10) NOT NULL default 'plaintext' AFTER description"; // allow up to 40 characters for a link id $_SQL[] = "ALTER TABLE {$_TABLES['links']} CHANGE lid lid varchar(40) NOT NULL default ''"; $_SQL[] = "ALTER TABLE {$_TABLES['linksubmission']} CHANGE lid lid varchar(40) NOT NULL default ''"; // add the new 'story.ping' feature to the Story Admin group function upgrade_addFeature () { global $_TABLES; $grp_id = DB_getItem ($_TABLES['groups'], 'grp_id', "grp_name = 'Story Admin'"); $ft_id = DB_getItem ($_TABLES['features'], 'ft_id', "ft_name = 'story.ping'"); if (($grp_id > 0) && ($ft_id > 0)) { DB_query ("INSERT INTO {$_TABLES['access']} (acc_ft_id, acc_grp_id) VALUES ($ft_id,$grp_id)"); } } function upgrade_uniqueGroupNames() { global $_TABLES; $groups = DB_count ($_TABLES['groups']); $result = DB_query ("SELECT DISTINCT grp_name FROM {$_TABLES['groups']} ORDER BY grp_gl_core ASC"); $numGroups = DB_numRows($result); if ($groups != $numGroups) { // find and delete the duplicates // first, prepare a list of all unique group names $names = array (); for ($i = 0; $i < $numGroups; $i++) { $A = DB_fetchArray ($result); $names[] = $A['grp_name']; } // then search for names that occur more than once foreach ($names as $name) { $result = DB_query ("SELECT grp_id FROM {$_TABLES['groups']} WHERE grp_name = '$name'"); $num = DB_numRows ($result); if ($num > 1) { // we're going to keep the first entry - fetch and discard $A = DB_fetchArray ($result); $num--; for ($i = 0; $i < $num; $i++) { list($grp_id) = DB_fetchArray ($result); DB_delete ($_TABLES['access'], 'acc_grp_id', $grp_id); DB_delete ($_TABLES['group_assignments'], 'ug_grp_id', $grp_id); DB_delete ($_TABLES['group_assignments'], 'ug_main_grp_id', $grp_id); DB_delete ($_TABLES['groups'], 'grp_id', $grp_id); } // check if we already found all the duplicates $groups -= $num; if ($groups == $numGroups) { break; } } } } // make 'grp_name' a unique index DB_query ("ALTER TABLE {$_TABLES['groups']} DROP INDEX grp_name"); DB_query ("ALTER TABLE {$_TABLES['groups']} ADD UNIQUE grp_name(grp_name)"); } ?>