3 define( 'UPDATE_VERSION' , 1170 );
7 * update.php - automatic system update
9 * Automatically update database schemas and any other development changes such that
10 * copying the latest files from the source code repository will always perform a clean
11 * and painless upgrade.
13 * Each function in this file is named update_nnnn() where nnnn is an increasing number
14 * which began counting at 1000.
16 * At the top of the file "boot.php" is a define for DB_UPDATE_VERSION. Any time there is a change
17 * to the database schema or one which requires an upgrade path from the existing application,
18 * the DB_UPDATE_VERSION and the UPDATE_VERSION at the top of this file are incremented.
20 * The current DB_UPDATE_VERSION is stored in the config area of the database. If the application starts up
21 * and DB_UPDATE_VERSION is greater than the last stored build number, we will process every update function
22 * in order from the currently stored value to the new DB_UPDATE_VERSION. This is expected to bring the system
23 * up to current without requiring re-installation or manual intervention.
25 * Once the upgrade functions have completed, the current DB_UPDATE_VERSION is stored as the current value.
26 * The DB_UPDATE_VERSION will always be one greater than the last numbered script in this file.
28 * If you change the database schema, the following are required:
29 * 1. Update the file include/dbstructure.php to match the new schema.
30 * 2. If there is a need for a post procession, update this file by adding a new function at the end with the number of the current DB_UPDATE_VERSION.
31 * This function should perform some post procession steps but no database updates.
32 * 3. Increment the DB_UPDATE_VERSION in boot.php *AND* the UPDATE_VERSION in this file to match it
33 * 4. TEST the upgrade prior to checkin and filing a pull request.
39 function update_1000() {
41 q("ALTER TABLE `item` DROP `like`, DROP `dislike` ");
43 q("ALTER TABLE `item` ADD `verb` CHAR( 255 ) NOT NULL AFTER `body` ,
44 ADD `object-type` CHAR( 255 ) NOT NULL AFTER `verb` ,
45 ADD `object` TEXT NOT NULL AFTER `object-type` ");
47 q("ALTER TABLE `intro` ADD `duplex` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `knowyou` ");
48 q("ALTER TABLE `contact` ADD `duplex` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `rel` ");
49 q("ALTER TABLE `contact` CHANGE `issued-pubkey` `issued-pubkey` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL");
50 q("ALTER TABLE `contact` ADD `term-date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `avatar-date`");
53 function update_1001() {
54 q("ALTER TABLE `item` ADD `wall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `type` ");
55 q("ALTER TABLE `item` ADD INDEX ( `wall` )");
58 function update_1002() {
59 q("ALTER TABLE `item` ADD `gravity` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `wall` ");
62 function update_1003() {
63 q("ALTER TABLE `contact` DROP `issued-pubkey` , DROP `ret-id` , DROP `ret-pubkey` ");
64 q("ALTER TABLE `contact` ADD `usehub` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `ret-aes`");
65 q("ALTER TABLE `contact` ADD `hub-verify` CHAR( 255 ) NOT NULL AFTER `usehub`");
66 q("ALTER TABLE `contact` ADD INDEX ( `uid` ) , ADD INDEX ( `self` ), ADD INDEX ( `issued-id` ), ADD INDEX ( `dfrn-id` )");
67 q("ALTER TABLE `contact` ADD INDEX ( `blocked` ), ADD INDEX ( `readonly` )");
70 function update_1004() {
71 q("ALTER TABLE `contact` ADD `subhub` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `usehub`");
74 function update_1005() {
76 q("ALTER TABLE `user` ADD `spubkey` TEXT NOT NULL AFTER `prvkey` ,
77 ADD `sprvkey` TEXT NOT NULL AFTER `spubkey`");
81 function update_1006() {
83 // create 's' keys for everybody that does not have one
85 $r = q("SELECT * FROM `user` WHERE `spubkey` = '' ");
88 $sres=openssl_pkey_new(array('encrypt_key' => false ));
90 openssl_pkey_export($sres, $sprvkey);
91 $spkey = openssl_pkey_get_details($sres);
92 $spubkey = $spkey["key"];
93 $r = q("UPDATE `user` SET `spubkey` = '%s', `sprvkey` = '%s'
103 function update_1007() {
104 q("ALTER TABLE `user` ADD `page-flags` INT NOT NULL DEFAULT '0' AFTER `notify-flags`");
105 q("ALTER TABLE `user` ADD INDEX ( `nickname` )");
108 function update_1008() {
109 q("ALTER TABLE `profile` ADD `with` TEXT NOT NULL AFTER `marital` ");
112 function update_1009() {
113 q("ALTER TABLE `user` ADD `allow_location` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `default-location` ");
116 function update_1010() {
117 q("ALTER TABLE `contact` ADD `lrdd` CHAR( 255 ) NOT NULL AFTER `url` ");
120 function update_1011() {
121 q("ALTER TABLE `contact` ADD `nick` CHAR( 255 ) NOT NULL AFTER `name` ");
122 $r = q("SELECT * FROM `contact` WHERE 1");
125 q("UPDATE `contact` SET `nick` = '%s' WHERE `id` = %d",
126 dbesc(basename($rr['url'])),
133 function update_1012() {
134 q("ALTER TABLE `item` ADD `inform` MEDIUMTEXT NOT NULL AFTER `tag` ");
137 function update_1013() {
138 q("ALTER TABLE `item` ADD `target-type` CHAR( 255 ) NOT NULL
139 AFTER `object` , ADD `target` TEXT NOT NULL AFTER `target-type`");
142 function update_1014() {
143 require_once('include/Photo.php');
144 q("ALTER TABLE `contact` ADD `micro` TEXT NOT NULL AFTER `thumb` ");
145 $r = q("SELECT * FROM `photo` WHERE `scale` = 4");
148 $ph = new Photo($rr['data']);
149 if($ph->is_valid()) {
151 $ph->store($rr['uid'],$rr['contact-id'],$rr['resource-id'],$rr['filename'],$rr['album'],6,(($rr['profile']) ? 1 : 0));
155 $r = q("SELECT * FROM `contact` WHERE 1");
158 if(stristr($rr['thumb'],'avatar'))
159 q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d",
160 dbesc(str_replace('avatar','micro',$rr['thumb'])),
163 q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d",
164 dbesc(str_replace('5.jpg','6.jpg',$rr['thumb'])),
170 function update_1015() {
171 q("ALTER TABLE `item` CHANGE `body` `body` mediumtext NOT NULL");
174 function update_1016() {
175 q("ALTER TABLE `user` ADD `openid` CHAR( 255 ) NOT NULL AFTER `email` ");
178 function update_1017() {
180 q(" CREATE TABLE IF NOT EXISTS `clients` (
181 `client_id` VARCHAR( 20 ) NOT NULL ,
182 `pw` VARCHAR( 20 ) NOT NULL ,
183 `redirect_uri` VARCHAR( 200 ) NOT NULL ,
184 PRIMARY KEY ( `client_id` )
185 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
187 q(" CREATE TABLE IF NOT EXISTS `tokens` (
188 `id` VARCHAR( 40 ) NOT NULL ,
189 `client_id` VARCHAR( 20 ) NOT NULL ,
190 `expires` INT NOT NULL ,
191 `scope` VARCHAR( 200 ) NOT NULL ,
193 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
195 q("CREATE TABLE IF NOT EXISTS `auth_codes` (
196 `id` VARCHAR( 40 ) NOT NULL ,
197 `client_id` VARCHAR( 20 ) NOT NULL ,
198 `redirect_uri` VARCHAR( 200 ) NOT NULL ,
199 `expires` INT NOT NULL ,
200 `scope` VARCHAR( 250 ) NOT NULL ,
202 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
206 function update_1018() {
207 q("CREATE TABLE IF NOT EXISTS `queue` (
208 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
210 `created` DATETIME NOT NULL ,
211 `last` DATETIME NOT NULL ,
212 `content` MEDIUMTEXT NOT NULL
213 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
216 function update_1019() {
217 q("ALTER TABLE `mail` DROP `delivered`");
218 q("ALTER TABLE `profile` ADD `showwith` TINYINT(1) NOT NULL DEFAULT '0' AFTER `marital` ");
221 function update_1020() {
222 q("ALTER TABLE `profile` DROP `showwith`");
223 q("ALTER TABLE `item` ADD `thr-parent` CHAR( 255 ) NOT NULL AFTER `parent-uri` ");
226 function update_1021() {
227 q("ALTER TABLE `profile_check` ADD `sec` CHAR( 255 ) NOT NULL AFTER `dfrn_id` ");
228 q("ALTER TABLE `profile_check` ADD `cid` INT(10) unsigned NOT NULL DEFAULT '0' AFTER `uid`");
229 q("ALTER TABLE `item` ADD `private` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `deny_gid` ");
232 function update_1022() {
233 q("CREATE TABLE `pconfig` (
234 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
235 `uid` INT NOT NULL DEFAULT '0',
236 `cat` CHAR( 255 ) NOT NULL ,
237 `k` CHAR( 255 ) NOT NULL ,
238 `v` MEDIUMTEXT NOT NULL
239 ) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci ");
242 function update_1023() {
243 q("ALTER TABLE `user` ADD `register_date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `timezone` ,
244 ADD `login_date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `register_date` ");
247 function update_1024() {
248 q("ALTER TABLE `profile` ADD `keywords` TEXT NOT NULL AFTER `religion` ");
251 function update_1025() {
252 q("ALTER TABLE `user` ADD `maxreq` int(11) NOT NULL DEFAULT '10' AFTER `pwdreset` ");
255 function update_1026() {
256 q("CREATE TABLE IF NOT EXISTS `hook` (
257 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
258 `hook` CHAR( 255 ) NOT NULL ,
259 `file` CHAR( 255 ) NOT NULL ,
260 `function` CHAR( 255 ) NOT NULL
261 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
265 function update_1027() {
266 q("CREATE TABLE IF NOT EXISTS `addon` (
267 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
268 `name` CHAR( 255 ) NOT NULL ,
269 `version` CHAR( 255 ) NOT NULL ,
270 `installed` TINYINT( 1 ) NOT NULL DEFAULT '0'
271 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
274 function update_1028() {
275 q("ALTER TABLE `user` ADD `openidserver` text NOT NULL AFTER `deny_gid` ");
278 function update_1029() {
279 q("ALTER TABLE `contact` ADD `info` MEDIUMTEXT NOT NULL AFTER `reason` ");
282 function update_1030() {
283 q("ALTER TABLE `contact` ADD `bdyear` CHAR( 4 ) NOT NULL COMMENT 'birthday notify flag' AFTER `profile-id` ");
285 q("CREATE TABLE IF NOT EXISTS `event` (
286 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
289 `created` DATETIME NOT NULL ,
290 `edited` DATETIME NOT NULL ,
291 `start` DATETIME NOT NULL ,
292 `finish` DATETIME NOT NULL ,
293 `desc` TEXT NOT NULL ,
294 `location` TEXT NOT NULL ,
295 `type` CHAR( 255 ) NOT NULL ,
296 `adjust` TINYINT( 1 ) NOT NULL DEFAULT '1',
297 `allow_cid` MEDIUMTEXT NOT NULL ,
298 `allow_gid` MEDIUMTEXT NOT NULL ,
299 `deny_cid` MEDIUMTEXT NOT NULL ,
300 `deny_gid` MEDIUMTEXT NOT NULL
301 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
306 function update_1031() {
307 // Repair any bad links that slipped into the item table
308 $r = q("SELECT `id`, `object` FROM `item` WHERE `object` != '' ");
309 if($r && count($r)) {
311 if(strstr($rr['object'],'type="http')) {
312 q("UPDATE `item` SET `object` = '%s' WHERE `id` = %d",
313 dbesc(str_replace('type="http','href="http',$rr['object'])),
321 function update_1032() {
322 q("ALTER TABLE `profile` ADD `pdesc` CHAR( 255 ) NOT NULL AFTER `name` ");
325 function update_1033() {
326 q("CREATE TABLE IF NOT EXISTS `cache` (
327 `k` CHAR( 255 ) NOT NULL PRIMARY KEY ,
329 `updated` DATETIME NOT NULL
330 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
334 function update_1034() {
336 // If you have any of these parent-less posts they can cause problems, and
337 // we need to delete them. You can't see them anyway.
338 // Legitimate items will usually get re-created on the next
339 // pull from the hub.
340 // But don't get rid of a post that may have just come in
341 // and may not yet have the parent id set.
343 q("DELETE FROM `item` WHERE `parent` = 0 AND `created` < UTC_TIMESTAMP() - INTERVAL 2 MINUTE");
348 function update_1035() {
350 q("ALTER TABLE `contact` ADD `success_update` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `last-update` ");
354 function update_1036() {
356 $r = dbq("SELECT * FROM `contact` WHERE `network` = 'dfrn' && `photo` LIKE '%include/photo%' ");
359 q("UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s' WHERE `id` = %d",
360 dbesc(str_replace('include/photo','photo',$rr['photo'])),
361 dbesc(str_replace('include/photo','photo',$rr['thumb'])),
362 dbesc(str_replace('include/photo','photo',$rr['micro'])),
368 function update_1037() {
370 q("ALTER TABLE `contact` CHANGE `lrdd` `alias` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
374 function update_1038() {
375 q("ALTER TABLE `item` ADD `plink` CHAR( 255 ) NOT NULL AFTER `target` ");
378 function update_1039() {
379 q("ALTER TABLE `addon` ADD `timestamp` BIGINT NOT NULL DEFAULT '0'");
383 function update_1040() {
385 q("CREATE TABLE IF NOT EXISTS `fcontact` (
386 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
387 `url` CHAR( 255 ) NOT NULL ,
388 `name` CHAR( 255 ) NOT NULL ,
389 `photo` CHAR( 255 ) NOT NULL
390 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
392 q("CREATE TABLE IF NOT EXISTS `ffinder` (
393 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
394 `uid` INT UNSIGNED NOT NULL ,
395 `cid` INT UNSIGNED NOT NULL ,
396 `fid` INT UNSIGNED NOT NULL
397 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
401 function update_1041() {
402 q("ALTER TABLE `profile` CHANGE `keywords` `prv_keywords` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
403 q("ALTER TABLE `profile` ADD `pub_keywords` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `religion` ");
406 function update_1042() {
407 q("ALTER TABLE `user` ADD `expire` INT UNSIGNED NOT NULL DEFAULT '0' AFTER `maxreq` ");
411 function update_1043() {
412 q("ALTER TABLE `user` ADD `blockwall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `blocked` ");
415 function update_1044() {
416 q("ALTER TABLE `profile` ADD FULLTEXT ( `pub_keywords` ) ");
417 q("ALTER TABLE `profile` ADD FULLTEXT ( `prv_keywords` ) ");
420 function update_1045() {
421 q("ALTER TABLE `user` ADD `language` CHAR( 16 ) NOT NULL DEFAULT 'en' AFTER `timezone` ");
424 function update_1046() {
425 q("ALTER TABLE `item` ADD `attach` MEDIUMTEXT NOT NULL AFTER `tag` ");
428 function update_1047() {
429 q("ALTER TABLE `contact` ADD `writable` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `readonly` ");
432 function update_1048() {
433 q("UPDATE `contact` SET `writable` = 1 WHERE `network` = 'stat' AND `notify` != '' ");
436 function update_1049() {
437 q("CREATE TABLE `mailacct` (
438 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
440 `server` CHAR( 255 ) NOT NULL ,
441 `user` CHAR( 255 ) NOT NULL ,
442 `pass` CHAR( 255 ) NOT NULL ,
443 `reply_to` CHAR( 255 ) NOT NULL ,
444 `last_check` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00'
445 ) ENGINE = MYISAM ");
448 function update_1050() {
449 q("CREATE TABLE `attach` (
450 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
452 `filetype` CHAR( 64 ) NOT NULL ,
453 `filesize` INT NOT NULL ,
454 `data` LONGBLOB NOT NULL ,
455 `created` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
456 `edited` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
457 `allow_cid` MEDIUMTEXT NOT NULL ,
458 `allow_gid` MEDIUMTEXT NOT NULL ,
459 `deny_cid` MEDIUMTEXT NOT NULL ,
460 `deny_gid` MEDIUMTEXT NOT NULL
461 ) ENGINE = MYISAM ");
465 function update_1051() {
466 q("ALTER TABLE `mailacct` ADD `port` INT NOT NULL AFTER `server` ,
467 ADD `ssltype` CHAR( 16 ) NOT NULL AFTER `port` ,
468 ADD `mailbox` CHAR( 255 ) NOT NULL AFTER `ssltype` ");
470 q("ALTER TABLE `contact` ADD `addr` CHAR( 255 ) NOT NULL AFTER `url` ");
473 function update_1052() {
474 q("ALTER TABLE `mailacct` CHANGE `pass` `pass` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL");
475 q("ALTER TABLE `mailacct` ADD `pubmail` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `reply_to` ");
476 q("ALTER TABLE `item` ADD `pubmail` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `private` ");
480 function update_1053() {
481 q("ALTER TABLE `item` ADD `extid` CHAR( 255 ) NOT NULL AFTER `parent-uri` , ADD INDEX ( `extid` ) ");
484 function update_1054() {
485 q("ALTER TABLE `register` ADD `language` CHAR( 16 ) NOT NULL AFTER `password` ");
488 function update_1055() {
489 q("ALTER TABLE `profile` ADD `hidewall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `hide-friends` ");
492 function update_1056() {
493 q("ALTER TABLE `attach` ADD `hash` CHAR( 64 ) NOT NULL AFTER `uid` ");
496 function update_1057() {
497 q("ALTER TABLE `attach` ADD `filename` CHAR( 255 ) NOT NULL AFTER `hash` ");
500 function update_1058() {
501 q("ALTER TABLE `item` ADD `event-id` INT NOT NULL AFTER `resource-id` ");
504 function update_1059() {
505 q("ALTER TABLE `queue` ADD `network` CHAR( 32 ) NOT NULL AFTER `cid` ");
508 function update_1060() {
509 q("ALTER TABLE `event` ADD `uri` CHAR( 255 ) NOT NULL AFTER `cid` ");
512 function update_1061() {
513 q("ALTER TABLE `event` ADD `nofinish` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `type` ");
516 function update_1062() {
517 q("ALTER TABLE `user` ADD `prvnets` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `page-flags` ");
519 function update_1063() {
520 q("ALTER TABLE `addon` ADD `plugin_admin` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `timestamp` ");
523 function update_1064() {
524 q("ALTER TABLE `item` ADD `app` CHAR( 255 ) NOT NULL AFTER `body` ");
527 function update_1065() {
528 q("ALTER TABLE `intro` ADD `fid` INT NOT NULL DEFAULT '0' AFTER `uid`");
531 function update_1066() {
532 $r = q("ALTER TABLE `item` ADD `received` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `edited` ");
534 q("ALTER TABLE `item` ADD INDEX ( `received` ) ");
536 $r = q("UPDATE `item` SET `received` = `edited` WHERE 1");
539 function update_1067() {
540 q("ALTER TABLE `ffinder` ADD `type` CHAR( 16 ) NOT NULL AFTER `id` ,
541 ADD `note` TEXT NOT NULL AFTER `type` ");
544 function update_1068() {
545 // 1067 was short-sighted. Undo it.
546 q("ALTER TABLE `ffinder` DROP `type` , DROP `note` ");
548 // and do this instead.
550 q("CREATE TABLE IF NOT EXISTS `fsuggest` (
551 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
554 `name` CHAR( 255 ) NOT NULL ,
555 `url` CHAR( 255 ) NOT NULL ,
556 `photo` CHAR( 255 ) NOT NULL ,
557 `note` TEXT NOT NULL ,
558 `created` DATETIME NOT NULL
559 ) ENGINE = MYISAM DEFAULT CHARSET=utf8");
563 function update_1069() {
564 q("ALTER TABLE `fsuggest` ADD `request` CHAR( 255 ) NOT NULL AFTER `url` ");
565 q("ALTER TABLE `fcontact` ADD `request` CHAR( 255 ) NOT NULL AFTER `photo` ");
568 // mail body needs to accomodate private photos
570 function update_1070() {
571 q("ALTER TABLE `mail` CHANGE `body` `body` MEDIUMTEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
574 function update_1071() {
575 q("ALTER TABLE `photo` ADD INDEX ( `uid` ) ");
576 q("ALTER TABLE `photo` ADD INDEX ( `resource-id` ) ");
577 q("ALTER TABLE `photo` ADD INDEX ( `album` ) ");
578 q("ALTER TABLE `photo` ADD INDEX ( `scale` ) ");
579 q("ALTER TABLE `photo` ADD INDEX ( `profile` ) ");
583 function update_1072() {
584 q("ALTER TABLE `item` ADD `starred` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` ");
585 q("ALTER TABLE `item` ADD INDEX ( `starred` ) ");
588 function update_1073() {
589 q("ALTER TABLE `contact` ADD `remote_self` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `self` ");
592 function update_1074() {
593 q("ALTER TABLE `user` ADD `hidewall` TINYINT( 1) NOT NULL DEFAULT '0' AFTER `blockwall` ");
594 $r = q("SELECT `uid` FROM `profile` WHERE `is-default` = 1 AND `hidewall` = 1");
597 q("UPDATE `user` SET `hidewall` = 1 WHERE `uid` = %d",
601 q("ALTER TABLE `profile` DROP `hidewall`");
604 function update_1075() {
605 q("ALTER TABLE `user` ADD `guid` CHAR( 16 ) NOT NULL AFTER `uid` ");
606 $r = q("SELECT `uid` FROM `user` WHERE 1");
611 $guid = substr(random_string(),0,16);
612 $x = q("SELECT `uid` FROM `user` WHERE `guid` = '%s' LIMIT 1",
617 } while ($found == true );
619 q("UPDATE `user` SET `guid` = '%s' WHERE `uid` = %d",
627 function update_1076() {
628 q("CREATE TABLE `guid` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
629 `guid` CHAR( 16 ) NOT NULL , INDEX ( `guid` ) ) ENGINE = MYISAM ");
633 // There was a typo in 1076 so we'll try again in 1077 to make sure
634 // We'll also make it big enough to allow for future growth, I seriously
635 // doubt Diaspora will be able to leave guids at 16 bytes,
636 // and we can also use the same structure for our own larger guids
638 function update_1077() {
639 q("CREATE TABLE IF NOT EXISTS `guid` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
640 `guid` CHAR( 16 ) NOT NULL , INDEX ( `guid` ) ) ENGINE = MYISAM ");
642 q("ALTER TABLE `guid` CHANGE `guid` `guid` CHAR( 64 ) NOT NULL");
645 function update_1078() {
646 q("ALTER TABLE `item` ADD `guid` CHAR( 64 ) NOT NULL AFTER `id` , ADD INDEX ( `guid` ) ");
649 function update_1079() {
650 q("CREATE TABLE IF NOT EXISTS `sign` (
651 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
652 `iid` INT UNSIGNED NOT NULL ,
653 `signed_text` MEDIUMTEXT NOT NULL ,
654 `signature` TEXT NOT NULL ,
655 `signer` CHAR( 255 ) NOT NULL ,
657 ) ENGINE = MYISAM ");
659 q("ALTER TABLE `fcontact` ADD `nick` CHAR( 255 ) NOT NULL ,
660 ADD `addr` CHAR( 255 ) NOT NULL ,
661 ADD `notify` CHAR( 255 ) NOT NULL ,
662 ADD `poll` CHAR( 255 ) NOT NULL ,
663 ADD `confirm` CHAR( 255 ) NOT NULL ,
664 ADD `priority` TINYINT( 1 ) NOT NULL ,
665 ADD `network` CHAR( 32 ) NOT NULL ,
666 ADD `alias` CHAR( 255 ) NOT NULL ,
667 ADD `pubkey` TEXT NOT NULL ,
668 ADD INDEX ( `addr` ) ,
669 ADD INDEX ( `network` ) ");
673 function update_1080() {
674 q("ALTER TABLE `fcontact` ADD `updated` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00'");
677 function update_1081() {
678 // there was a typo in update 1081 so it was corrected and moved up to 1082
681 function update_1082() {
682 q("ALTER TABLE `photo` ADD `guid` CHAR( 64 ) NOT NULL AFTER `contact-id`,
683 ADD INDEX ( `guid` ) ");
684 // make certain the following code is only executed once
685 $r = q("select `id` from `photo` where `guid` != '' limit 1");
688 $r = q("SELECT distinct(`resource-id`) FROM `photo` WHERE 1 group by `id`");
692 q("update `photo` set `guid` = '%s' where `resource-id` = '%s'",
694 dbesc($rr['resource-id'])
700 function update_1083() {
701 q("CREATE TABLE IF NOT EXISTS `deliverq` (
702 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
703 `cmd` CHAR( 32 ) NOT NULL ,
704 `item` INT NOT NULL ,
705 `contact` INT NOT NULL
706 ) ENGINE = MYISAM ");
710 function update_1084() {
711 q("ALTER TABLE `contact` ADD `attag` CHAR( 255 ) NOT NULL AFTER `nick` ");
714 function update_1085() {
715 q("CREATE TABLE IF NOT EXISTS `search` (
716 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
718 `term` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
721 ) ENGINE = MYISAM ");
724 function update_1086() {
725 q("ALTER TABLE `item` ADD `bookmark` tinyint(1) NOT NULL DEFAULT '0' AFTER `starred` ");
728 function update_1087() {
729 q("ALTER TABLE `item` ADD `commented` datetime NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `edited` ");
731 $r = q("SELECT `id` FROM `item` WHERE `parent` = `id` ");
734 $x = q("SELECT max(`created`) AS `cdate` FROM `item` WHERE `parent` = %d LIMIT 1",
738 q("UPDATE `item` SET `commented` = '%s' WHERE `id` = %d",
739 dbesc($x[0]['cdate']),
746 function update_1088() {
747 q("ALTER TABLE `user` ADD `account_expired` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `expire` ,
748 ADD `account_expires_on` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `account_expired` ,
749 ADD `expire_notification_sent` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `account_expires_on` ");
752 function update_1089() {
753 q("ALTER TABLE `user` ADD `blocktags` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `hidewall` ");
756 function update_1090() {
757 q("ALTER TABLE `contact` ADD `batch` char(255) NOT NULL AFTER `prvkey` ");
759 q("UPDATE `contact` SET `batch` = concat(substring_index(`url`,'/',3),'/receive/public') WHERE `network` = 'dspr' ");
763 function update_1091() {
765 // catch a few stragglers that may have crept in before we added this on remote connects
766 q("UPDATE `contact` SET `batch` = concat(substring_index(`url`,'/',3),'/receive/public') WHERE `network` = 'dspr' AND `batch` = '' ");
767 q("ALTER TABLE `queue` ADD `batch` TINYINT( 1 ) NOT NULL DEFAULT '0' ");
768 q("ALTER TABLE `fcontact` ADD `batch` char(255) NOT NULL AFTER `addr` ");
772 function update_1092() {
773 q("ALTER TABLE `user` ADD INDEX ( `login_date` ) ");
774 q("ALTER TABLE `user` ADD INDEX ( `account_expired` ) ");
777 function update_1093() {
778 q("CREATE TABLE IF NOT EXISTS `fserver` (
779 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
780 `server` CHAR( 255 ) NOT NULL ,
781 `posturl` CHAR( 255 ) NOT NULL ,
784 ) ENGINE = MYISAM ");
786 q("ALTER TABLE `group` ADD `visible` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `uid` ");
790 function update_1094() {
791 q("ALTER TABLE `item` ADD `postopts` TEXT NOT NULL AFTER `target` ");
794 function update_1095() {
795 q("ALTER TABLE `contact` ADD `bd` DATE NOT NULL AFTER `bdyear` ");
798 function update_1096() {
799 q("ALTER TABLE `item` ADD `origin` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `deleted` , ADD INDEX ( `origin` ) ");
802 function update_1097() {
803 q("ALTER TABLE `queue`
805 ADD INDEX (`created`),
807 ADD INDEX (`network`),
812 function update_1098() {
813 q("ALTER TABLE `contact`
814 ADD INDEX (`network`),
824 function update_1099() {
825 q("CREATE TABLE IF NOT EXISTS `gcontact` (
826 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
827 `name` CHAR( 255 ) NOT NULL ,
828 `url` CHAR( 255 ) NOT NULL ,
829 `nurl` CHAR( 255 ) NOT NULL ,
830 `photo` CHAR( 255 ) NOT NULL
831 ) ENGINE = MYISAM ");
833 q("CREATE TABLE IF NOT EXISTS `glink` (
834 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
838 `updated` DATETIME NOT NULL
839 ) ENGINE = MYISAM ");
841 q("ALTER TABLE `gcontact` ADD INDEX (`nurl`) ");
842 q("ALTER TABLE `glink` ADD INDEX (`cid`), ADD INDEX (`uid`), ADD INDEX (`gcid`), ADD INDEX (`updated`) ");
844 q("ALTER TABLE `contact` ADD `poco` TEXT NOT NULL AFTER `confirm` ");
848 function update_1100() {
849 q("ALTER TABLE `contact` ADD `nurl` CHAR( 255 ) NOT NULL AFTER `url` ");
850 q("alter table contact add index (`nurl`) ");
852 require_once('include/text.php');
854 $r = q("select id, url from contact where url != '' and nurl = '' ");
857 q("update contact set nurl = '%s' where id = %d",
858 dbesc(normalise_link($rr['url'])),
866 function update_1101() {
867 q("CREATE TABLE IF NOT EXISTS `gcign` (
868 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
871 ) ENGINE = MYISAM ");
873 q("ALTER TABLE `gcign` ADD INDEX (`uid`), ADD INDEX (`gcid`) ");
876 function update_1102() {
877 q("ALTER TABLE `clients` ADD `name` TEXT NULL DEFAULT NULL AFTER `redirect_uri` ");
878 q("ALTER TABLE `clients` ADD `icon` TEXT NULL DEFAULT NULL AFTER `name` ");
879 q("ALTER TABLE `clients` ADD `uid` INT NOT NULL DEFAULT 0 AFTER `icon` ");
881 q("ALTER TABLE `tokens` ADD `secret` TEXT NOT NULL AFTER `id` ");
882 q("ALTER TABLE `tokens` ADD `uid` INT NOT NULL AFTER `scope` ");
886 function update_1103() {
887 // q("ALTER TABLE `item` ADD INDEX ( `wall` ) ");
888 q("ALTER TABLE `item` ADD FULLTEXT ( `tag` ) ");
889 q("ALTER TABLE `contact` ADD INDEX ( `pending` ) ");
890 q("ALTER TABLE `user` ADD INDEX ( `hidewall` ) ");
891 q("ALTER TABLE `user` ADD INDEX ( `blockwall` ) ");
892 q("ALTER TABLE `user` ADD INDEX ( `blocked` ) ");
893 q("ALTER TABLE `user` ADD INDEX ( `verified` ) ");
897 function update_1104() {
898 q("ALTER TABLE `item` ADD `forum_mode` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `origin` , ADD INDEX ( `forum_mode` ) ");
902 function update_1105() {
903 q("ALTER TABLE `mail` ADD `convid` INT NOT NULL AFTER `contact-id` ");
904 q("ALTER TABLE `mail` ADD `guid` CHAR( 64 ) NOT NULL AFTER `uid` ");
906 q("CREATE TABLE IF NOT EXISTS `conv` (
907 `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
908 `guid` CHAR( 64 ) NOT NULL ,
909 `recips` MEDIUMTEXT NOT NULL ,
911 ) ENGINE = MYISAM ");
915 function update_1106() {
916 q("ALTER TABLE `item` ADD INDEX ( `author-link` ) ");
920 function update_1107() {
921 q("ALTER TABLE `item` ADD INDEX ( `bookmark` ) ");
925 function update_1108() {
926 q("ALTER TABLE `contact` ADD `hidden` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `writable` ,
927 ADD INDEX ( `hidden` ) ");
931 function update_1109() {
932 q("ALTER TABLE `conv` ADD `creator` CHAR( 255 ) NOT NULL ,
933 ADD `created` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
934 ADD `updated` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
935 ADD `subject` MEDIUMTEXT NOT NULL,
936 ADD INDEX ( `created` ), ADD INDEX ( `updated` ) ");
939 function update_1110() {
940 q("ALTER TABLE `mail` ADD `reply` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `seen`,
941 ADD INDEX ( `reply` ), ADD INDEX ( `uid` ), ADD INDEX ( `guid` ), ADD INDEX ( `seen` ),
942 ADD INDEX ( `uri` ), ADD INDEX ( `parent-uri`), ADD INDEX ( `created` ), ADD INDEX ( `convid` ) ");
946 function update_1111() {
947 q("ALTER TABLE `gcontact` ADD `connect` CHAR( 255 ) NOT NULL ");
951 function update_1112() {
953 q("CREATE TABLE IF NOT EXISTS `notify` (
954 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
955 `type` INT( 11 ) NOT NULL ,
956 `name` CHAR( 255 ) NOT NULL ,
957 `url` CHAR( 255 ) NOT NULL ,
958 `photo` CHAR( 255 ) NOT NULL ,
959 `date` DATETIME NOT NULL ,
960 `msg` MEDIUMTEXT NOT NULL ,
962 `link` CHAR( 255 ) NOT NULL ,
963 `seen` TINYINT( 1 ) NOT NULL DEFAULT '0'
964 ) ENGINE = MYISAM ");
966 q("ALTER TABLE `notify` ADD INDEX ( `type` ), ADD INDEX ( `uid`), ADD INDEX (`seen`), ADD INDEX (`date`) ");
970 function update_1113() {
971 q("ALTER TABLE `notify` ADD `verb` CHAR( 255 ) NOT NULL ,
972 ADD `otype` CHAR( 16 ) NOT NULL");
975 function update_1114() {
976 q("CREATE TABLE IF NOT EXISTS `item_id` (
979 `face` CHAR( 255 ) NOT NULL ,
980 `dspr` CHAR( 255 ) NOT NULL ,
981 `twit` CHAR( 255 ) NOT NULL ,
982 `stat` CHAR( 255 ) NOT NULL ,
983 PRIMARY KEY ( `iid` ),
989 ) ENGINE = MYISAM ");
993 function update_1115() {
994 q("ALTER TABLE `item` ADD `moderated`
995 TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `pubmail`,
996 ADD INDEX (`moderated`) ");
999 function update_1116() {
1000 //typo! corrected update was rolled forward
1003 function update_1117() {
1004 q("create table if not exists `manage` (
1005 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1006 `uid` INT NOT NULL ,
1010 ) ENGINE = MYISAM ");
1014 function update_1118() {
1018 function update_1119() {
1019 q("ALTER TABLE `contact` ADD `closeness` TINYINT( 2 ) NOT NULL DEFAULT '99' AFTER `reason` , ADD INDEX (`closeness`) ");
1020 q("update contact set closeness = 0 where self = 1");
1021 q("ALTER TABLE `item` ADD `spam` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` , ADD INDEX (`spam`) ");
1025 function update_1120() {
1027 // item table update from 1119 did not get into database.sql file.
1028 // might be missing on new installs. We'll check.
1030 $r = q("describe item");
1031 if($r && count($r)) {
1033 if($rr['Field'] == 'spam')
1036 q("ALTER TABLE `item` ADD `spam` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` , ADD INDEX (`spam`) ");
1040 function update_1121() {
1041 q("CREATE TABLE IF NOT EXISTS `poll_result` (
1042 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1043 `poll_id` INT NOT NULL ,
1044 `choice` INT NOT NULL ,
1045 INDEX ( `poll_id` ),
1047 ) ENGINE = MYISAM ");
1049 q("CREATE TABLE IF NOT EXISTS `poll` (
1050 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1051 `uid` INT NOT NULL ,
1052 `q0` MEDIUMTEXT NOT NULL ,
1053 `q1` MEDIUMTEXT NOT NULL ,
1054 `q2` MEDIUMTEXT NOT NULL ,
1055 `q3` MEDIUMTEXT NOT NULL ,
1056 `q4` MEDIUMTEXT NOT NULL ,
1057 `q5` MEDIUMTEXT NOT NULL ,
1058 `q6` MEDIUMTEXT NOT NULL ,
1059 `q7` MEDIUMTEXT NOT NULL ,
1060 `q8` MEDIUMTEXT NOT NULL ,
1061 `q9` MEDIUMTEXT NOT NULL ,
1063 ) ENGINE = MYISAM ");
1067 function update_1122() {
1068 q("ALTER TABLE `notify` ADD `hash` CHAR( 64 ) NOT NULL AFTER `id` ,
1069 ADD INDEX ( `hash` ) ");
1072 function update_1123() {
1073 set_config('system','allowed_themes','dispy,quattro,testbubble,vier,darkbubble,darkzero,duepuntozero,greenzero,purplezero,quattro-green,slackr');
1076 function update_1124() {
1077 q("alter table item add index (`author-name`) ");
1080 function update_1125() {
1081 q("CREATE TABLE IF NOT EXISTS `notify-threads` (
1082 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1083 `notify-id` INT NOT NULL,
1084 `master-parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
1085 `parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
1086 `receiver-uid` INT NOT NULL,
1087 INDEX ( `master-parent-item` ),
1088 INDEX ( `receiver-uid` )
1089 ) ENGINE = MyISAM DEFAULT CHARSET=utf8");
1092 function update_1126() {
1093 q("ALTER TABLE `mailacct` ADD `action` INT NOT NULL AFTER `pass`,
1094 ADD `movetofolder` CHAR(255) NOT NULL AFTER `action`");
1097 function update_1127() {
1098 q("CREATE TABLE IF NOT EXISTS `spam` (
1099 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1101 `spam` INT NOT NULL DEFAULT '0',
1102 `ham` INT NOT NULL DEFAULT '0',
1103 `term` CHAR(255) NOT NULL,
1108 ) ENGINE = MyISAM DEFAULT CHARSET=utf8");
1112 function update_1128() {
1113 q("alter table spam add `date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `term` ");
1116 function update_1129() {
1117 q("ALTER TABLE `notify` ADD `parent` INT NOT NULL AFTER `link` , ADD INDEX ( `parent` ), ADD INDEX ( `link` ), ADD INDEX ( `otype` ) ");
1120 function update_1130() {
1121 q("ALTER TABLE `item` ADD `file` MEDIUMTEXT NOT NULL AFTER `inform`, ADD FULLTEXT KEY (`file`) ");
1124 function update_1131() {
1125 q("ALTER TABLE `contact` ADD `forum` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `writable` , ADD INDEX ( `forum` ) ");
1129 function update_1132() {
1130 q("CREATE TABLE IF NOT EXISTS `userd` (
1131 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1132 `username` CHAR( 255 ) NOT NULL,
1133 INDEX ( `username` )
1134 ) ENGINE = MYISAM ");
1138 function update_1133() {
1139 q("ALTER TABLE `user` ADD `unkmail` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `blocktags` , ADD INDEX ( `unkmail` ) ");
1140 q("ALTER TABLE `user` ADD `cntunkmail` INT NOT NULL DEFAULT '10' AFTER `unkmail` , ADD INDEX ( `cntunkmail` ) ");
1141 q("ALTER TABLE `mail` ADD `unknown` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `replied` , ADD INDEX ( `unknown` ) ");
1144 function update_1134() {
1145 // faulty update merged forward
1146 // had a hardwired tablename of 'friendica' which isn't the right name on most systems
1149 function update_1135() {
1150 //there can't be indexes with more than 1000 bytes in mysql,
1151 //so change charset to be smaller
1152 q("ALTER TABLE `config` CHANGE `cat` `cat` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL ,
1153 CHANGE `k` `k` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL");
1155 //same thing for pconfig
1156 q("ALTER TABLE `pconfig` CHANGE `cat` `cat` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL ,
1157 CHANGE `k` `k` CHAR( 255 ) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL");
1158 // faulty update merged forward. Bad update in 1134 caused duplicate k,cat pairs
1159 // these have to be cleared before the unique keys can be added.
1162 function update_1136() {
1166 // order in reverse so that we save the newest entry
1168 $r = q("select * from config where 1 order by id desc");
1170 foreach($r as $rr) {
1172 foreach($arr as $x) {
1173 if($x['cat'] == $rr['cat'] && $x['k'] == $rr['k']) {
1175 q("delete from config where id = %d",
1187 $r = q("select * from pconfig where 1 order by id desc");
1189 foreach($r as $rr) {
1191 foreach($arr as $x) {
1192 if($x['uid'] == $rr['uid'] && $x['cat'] == $rr['cat'] && $x['k'] == $rr['k']) {
1194 q("delete from pconfig where id = %d",
1204 q("ALTER TABLE `config` ADD UNIQUE `access` ( `cat` , `k` ) ");
1205 q("ALTER TABLE `pconfig` ADD UNIQUE `access` ( `uid` , `cat` , `k` )");
1210 function update_1137() {
1211 q("alter table item_id DROP `face` , DROP `dspr` , DROP `twit` , DROP `stat` ");
1212 q("ALTER TABLE `item_id` ADD `sid` CHAR( 255 ) NOT NULL AFTER `uid` , ADD `service` CHAR( 255 ) NOT NULL AFTER `sid` , add index (`sid`), add index ( `service`) ");
1215 function update_1138() {
1216 q("alter table contact add archive tinyint(1) not null default '0' after hidden, add index (archive)");
1219 function update_1139() {
1220 $r = q("alter table user add account_removed tinyint(1) not null default '0' after expire, add index(account_removed) ");
1222 return UPDATE_FAILED ;
1223 return UPDATE_SUCCESS ;
1226 function update_1140() {
1227 $r = q("alter table addon add hidden tinyint(1) not null default '0' after installed, add index(hidden) ");
1229 return UPDATE_FAILED ;
1230 return UPDATE_SUCCESS ;
1233 function update_1141() {
1234 $r = q("alter table glink add zcid int(11) not null after gcid, add index(zcid) ");
1236 return UPDATE_FAILED ;
1237 return UPDATE_SUCCESS ;
1241 function update_1142() {
1242 $r = q("alter table user add service_class char(32) not null after expire_notification_sent, add index(service_class) ");
1244 return UPDATE_FAILED ;
1245 return UPDATE_SUCCESS ;
1248 function update_1143() {
1249 $r = q("alter table user add def_gid int(11) not null default '0' after service_class");
1251 return UPDATE_FAILED ;
1252 return UPDATE_SUCCESS ;
1255 function update_1144() {
1256 $r = q("alter table contact add prv tinyint(1) not null default '0' after forum");
1258 return UPDATE_FAILED ;
1259 return UPDATE_SUCCESS ;
1262 function update_1145() {
1263 $r = q("alter table profile add howlong datetime not null default '0000-00-00 00:00:00' after `with`");
1265 return UPDATE_FAILED ;
1266 return UPDATE_SUCCESS ;
1269 function update_1146() {
1270 $r = q("alter table profile add hometown char(255) not null after `country-name`, add index ( `hometown` ) ");
1272 return UPDATE_FAILED ;
1273 return UPDATE_SUCCESS ;
1276 function update_1147() {
1277 $r1 = q("ALTER TABLE `sign` ALTER `iid` SET DEFAULT '0'");
1278 $r2 = q("ALTER TABLE `sign` ADD `retract_iid` INT(10) UNSIGNED NOT NULL DEFAULT '0' AFTER `iid`");
1279 $r3 = q("ALTER TABLE `sign` ADD INDEX ( `retract_iid` )");
1280 if((! $r1) || (! $r2) || (! $r3))
1281 return UPDATE_FAILED ;
1282 return UPDATE_SUCCESS ;
1285 function update_1148() {
1286 $r = q("ALTER TABLE photo ADD type CHAR(128) NOT NULL DEFAULT 'image/jpeg' AFTER filename");
1288 return UPDATE_FAILED;
1289 return UPDATE_SUCCESS;
1293 function update_1149() {
1294 $r1 = q("ALTER TABLE profile ADD likes text NOT NULL after prv_keywords");
1295 $r2 = q("ALTER TABLE profile ADD dislikes text NOT NULL after likes");
1297 return UPDATE_FAILED;
1298 return UPDATE_SUCCESS;
1302 function update_1150() {
1303 $r = q("ALTER TABLE event ADD summary text NOT NULL after finish, add index ( uid ), add index ( cid ), add index ( uri ), add index ( `start` ), add index ( finish ), add index ( `type` ), add index ( adjust ) ");
1305 return UPDATE_FAILED;
1306 return UPDATE_SUCCESS;
1310 function update_1151() {
1311 $r = q("CREATE TABLE IF NOT EXISTS locks (
1312 id INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1313 name CHAR( 128 ) NOT NULL ,
1314 locked TINYINT( 1 ) NOT NULL DEFAULT '0'
1315 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
1317 return UPDATE_FAILED;
1318 return UPDATE_SUCCESS;
1321 function update_1152() {
1322 $r = q("CREATE TABLE IF NOT EXISTS `term` (
1323 `tid` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1324 `oid` INT UNSIGNED NOT NULL ,
1325 `otype` TINYINT( 3 ) UNSIGNED NOT NULL ,
1326 `type` TINYINT( 3 ) UNSIGNED NOT NULL ,
1327 `term` CHAR( 255 ) NOT NULL ,
1328 `url` CHAR( 255 ) NOT NULL,
1329 KEY `oid` ( `oid` ),
1330 KEY `otype` ( `otype` ),
1331 KEY `type` ( `type` ),
1332 KEY `term` ( `term` )
1333 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
1335 return UPDATE_FAILED;
1336 return UPDATE_SUCCESS;
1339 function update_1153() {
1340 $r = q("ALTER TABLE `hook` ADD `priority` INT(11) UNSIGNED NOT NULL DEFAULT '0'");
1342 if(!$r) return UPDATE_FAILED;
1343 return UPDATE_SUCCESS;
1346 function update_1154() {
1347 $r = q("ALTER TABLE `event` ADD `ignore` TINYINT( 1 ) UNSIGNED NOT NULL DEFAULT '0' AFTER `adjust` , ADD INDEX ( `ignore` )");
1349 if(!$r) return UPDATE_FAILED;
1350 return UPDATE_SUCCESS;
1353 function update_1155() {
1354 $r1 = q("ALTER TABLE `item_id` DROP PRIMARY KEY");
1355 $r2 = q("ALTER TABLE `item_id` ADD `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST");
1356 $r3 = q("ALTER TABLE `item_id` ADD INDEX ( `iid` ) ");
1358 if($r1 && $r2 && $r3)
1359 return UPDATE_SUCCESS;
1361 return UPDATE_FAILED;
1364 function update_1156() {
1365 $r = q("ALTER TABLE `photo` ADD `datasize` INT UNSIGNED NOT NULL DEFAULT '0' AFTER `width` ,
1366 ADD INDEX ( `datasize` ) ");
1368 if(!$r) return UPDATE_FAILED;
1369 return UPDATE_SUCCESS;
1372 function update_1157() {
1373 $r = q("CREATE TABLE IF NOT EXISTS `dsprphotoq` (
1374 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
1375 `uid` int(11) NOT NULL,
1376 `msg` mediumtext NOT NULL,
1377 `attempt` tinyint(4) NOT NULL,
1379 ) ENGINE=MyISAM DEFAULT CHARSET=utf8"
1383 return UPDATE_SUCCESS;
1386 function update_1158() {
1387 set_config('system', 'maintenance', 1);
1389 // Wait for 15 seconds for current requests to
1390 // clear before locking up the database
1393 $r = q("CREATE INDEX event_id ON item(`event-id`)");
1394 set_config('system', 'maintenance', 0);
1397 return UPDATE_SUCCESS;
1399 return UPDATE_FAILED;
1402 function update_1159() {
1403 $r = q("ALTER TABLE `term` ADD `aid` int(10) unsigned NOT NULL DEFAULT '0',
1404 ADD `uid` int(10) unsigned NOT NULL DEFAULT '0',
1406 ADD INDEX (`aid`)");
1409 return UPDATE_FAILED;
1411 return UPDATE_SUCCESS;
1414 function update_1160() {
1415 set_config('system', 'maintenance', 1);
1417 // Wait for 15 seconds for current requests to
1418 // clear before locking up the database
1421 $r = q("ALTER TABLE `item` ADD `mention` TINYINT(1) NOT NULL DEFAULT '0', ADD INDEX (`mention`)");
1422 set_config('system', 'maintenance', 0);
1425 return UPDATE_FAILED;
1427 return UPDATE_SUCCESS;
1430 function update_1161() {
1431 $r = q("ALTER TABLE `pconfig` ADD INDEX (`cat`)");
1434 return UPDATE_FAILED;
1436 return UPDATE_SUCCESS;
1439 function update_1162() {
1440 require_once('include/tags.php');
1443 return UPDATE_SUCCESS;
1446 function update_1163() {
1447 set_config('system', 'maintenance', 1);
1449 $r = q("ALTER TABLE `item` ADD `network` char(32) NOT NULL,
1450 ADD INDEX (`network`)");
1452 set_config('system', 'maintenance', 0);
1455 return UPDATE_FAILED;
1457 return UPDATE_SUCCESS;
1459 function update_1164() {
1460 set_config('system', 'maintenance', 1);
1462 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '' AND `contact`.`uid` = `item`.`uid`)",
1465 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1466 NETWORK_DFRN, NETWORK_DFRN);
1468 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1469 NETWORK_ZOT, NETWORK_ZOT);
1471 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1472 NETWORK_OSTATUS, NETWORK_OSTATUS);
1474 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1475 NETWORK_FEED, NETWORK_FEED);
1477 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1478 NETWORK_DIASPORA, NETWORK_DIASPORA);
1480 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1481 NETWORK_MAIL, NETWORK_MAIL);
1483 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1484 NETWORK_MAIL2, NETWORK_MAIL2);
1486 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1487 NETWORK_FACEBOOK, NETWORK_FACEBOOK);
1489 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1490 NETWORK_LINKEDIN, NETWORK_LINKEDIN);
1492 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1493 NETWORK_XMPP, NETWORK_XMPP);
1495 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1496 NETWORK_MYSPACE, NETWORK_MYSPACE);
1498 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1499 NETWORK_GPLUS, NETWORK_GPLUS);
1501 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1502 NETWORK_PUMPIO, NETWORK_PUMPIO);
1504 $r = q("UPDATE `item` SET `network`='%s' WHERE `contact-id` IN (SELECT `id` FROM`contact` WHERE `network` = '%s' AND `contact`.`uid` = `item`.`uid`)",
1505 NETWORK_TWITTER, NETWORK_TWITTER);
1507 set_config('system', 'maintenance', 0);
1509 return UPDATE_SUCCESS;
1512 function update_1165() {
1513 $r = q("CREATE TABLE IF NOT EXISTS `push_subscriber` (
1514 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
1516 `callback_url` CHAR( 255 ) NOT NULL,
1517 `topic` CHAR( 255 ) NOT NULL,
1518 `nickname` CHAR( 255 ) NOT NULL,
1519 `push` INT NOT NULL,
1520 `last_update` DATETIME NOT NULL,
1521 `secret` CHAR( 255 ) NOT NULL
1522 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
1524 return UPDATE_FAILED;
1526 return UPDATE_SUCCESS;
1529 function update_1166() {
1530 $r = q("CREATE TABLE IF NOT EXISTS `unique_contacts` (
1531 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
1532 `url` CHAR(255) NOT NULL,
1533 `nick` CHAR(255) NOT NULL,
1534 `name` CHAR(255) NOT NULL,
1535 `avatar` CHAR(255) NOT NULL,
1537 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
1539 return UPDATE_FAILED;
1541 return UPDATE_SUCCESS;
1544 function update_1167() {
1545 $r = q("ALTER TABLE `contact` ADD `notify_new_posts` TINYINT(1) NOT NULL DEFAULT '0'");
1547 return UPDATE_FAILED;
1549 return UPDATE_SUCCESS;
1552 function update_1168() {
1553 $r = q("ALTER TABLE `contact` ADD `fetch_further_information` TINYINT(1) NOT NULL DEFAULT '0'");
1555 return UPDATE_FAILED;
1557 return UPDATE_SUCCESS;
1560 function update_1169() {
1561 $r = q("CREATE TABLE IF NOT EXISTS `thread` (
1562 `iid` int(10) unsigned NOT NULL DEFAULT '0',
1563 `uid` int(10) unsigned NOT NULL DEFAULT '0',
1564 `contact-id` int(11) unsigned NOT NULL DEFAULT '0',
1565 `created` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
1566 `edited` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
1567 `commented` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
1568 `received` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
1569 `changed` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
1570 `wall` tinyint(1) NOT NULL DEFAULT '0',
1571 `private` tinyint(1) NOT NULL DEFAULT '0',
1572 `pubmail` tinyint(1) NOT NULL DEFAULT '0',
1573 `moderated` tinyint(1) NOT NULL DEFAULT '0',
1574 `visible` tinyint(1) NOT NULL DEFAULT '0',
1575 `spam` tinyint(1) NOT NULL DEFAULT '0',
1576 `starred` tinyint(1) NOT NULL DEFAULT '0',
1577 `bookmark` tinyint(1) NOT NULL DEFAULT '0',
1578 `unseen` tinyint(1) NOT NULL DEFAULT '1',
1579 `deleted` tinyint(1) NOT NULL DEFAULT '0',
1580 `origin` tinyint(1) NOT NULL DEFAULT '0',
1581 `forum_mode` tinyint(1) NOT NULL DEFAULT '0',
1582 `mention` tinyint(1) NOT NULL DEFAULT '0',
1583 `network` char(32) NOT NULL,
1584 PRIMARY KEY (`iid`),
1585 KEY `created` (`created`),
1586 KEY `commented` (`commented`),
1587 KEY `uid_network_commented` (`uid`,`network`,`commented`),
1588 KEY `uid_network_created` (`uid`,`network`,`created`),
1589 KEY `uid_contactid_commented` (`uid`,`contact-id`,`commented`),
1590 KEY `uid_contactid_created` (`uid`,`contact-id`,`created`),
1591 KEY `wall_private_received` (`wall`,`private`,`received`),
1592 KEY `uid_created` (`uid`,`created`),
1593 KEY `uid_commented` (`uid`,`commented`)
1594 ) ENGINE=MyISAM DEFAULT CHARSET=utf8;");
1596 return UPDATE_FAILED;
1598 proc_run('php',"include/threadupdate.php");
1600 return UPDATE_SUCCESS;