]> git.mxchange.org Git - friendica.git/blob - update.php
Merge branch 'master' of git://github.com/friendica/friendica
[friendica.git] / update.php
1 <?php
2
3
4 define( 'UPDATE_VERSION' , 1133 );
5
6 /**
7  *
8  * update.php - automatic system update
9  *
10  * Automatically update database schemas and any other development changes such that
11  * copying the latest files from the source code repository will always perform a clean
12  * and painless upgrade.
13  *
14  * Each function in this file is named update_nnnn() where nnnn is an increasing number 
15  * which began counting at 1000.
16  * 
17  * At the top of the file "boot.php" is a define for DB_UPDATE_VERSION. Any time there is a change
18  * to the database schema or one which requires an upgrade path from the existing application,
19  * the DB_UPDATE_VERSION and the UPDATE_VERSION at the top of this file are incremented.
20  *
21  * The current DB_UPDATE_VERSION is stored in the config area of the database. If the application starts up
22  * and DB_UPDATE_VERSION is greater than the last stored build number, we will process every update function 
23  * in order from the currently stored value to the new DB_UPDATE_VERSION. This is expected to bring the system 
24  * up to current without requiring re-installation or manual intervention.
25  *
26  * Once the upgrade functions have completed, the current DB_UPDATE_VERSION is stored as the current value.
27  * The DB_UPDATE_VERSION will always be one greater than the last numbered script in this file. 
28  *
29  * If you change the database schema, the following are required:
30  *    1. Update the file database.sql to match the new schema.
31  *    2. Update this file by adding a new function at the end with the number of the current DB_UPDATE_VERSION.
32  *       This function should modify the current database schema and perform any other steps necessary
33  *       to ensure that upgrade is silent and free from requiring interaction.
34  *    3. Increment the DB_UPDATE_VERSION in boot.php *AND* the UPDATE_VERSION in this file to match it
35  *    4. TEST the upgrade prior to checkin and filing a pull request.
36  *
37  */
38
39
40
41 function update_1000() {
42
43         q("ALTER TABLE `item` DROP `like`, DROP `dislike` ");
44
45         q("ALTER TABLE `item` ADD `verb` CHAR( 255 ) NOT NULL AFTER `body` ,
46                 ADD `object-type` CHAR( 255 ) NOT NULL AFTER `verb` ,
47                 ADD `object` TEXT NOT NULL AFTER `object-type` ");
48
49         q("ALTER TABLE `intro` ADD `duplex` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `knowyou` ");
50         q("ALTER TABLE `contact` ADD `duplex` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `rel` ");
51         q("ALTER TABLE `contact` CHANGE `issued-pubkey` `issued-pubkey` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL");  
52         q("ALTER TABLE `contact` ADD `term-date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `avatar-date`");
53 }
54
55 function update_1001() {
56         q("ALTER TABLE `item` ADD `wall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `type` ");
57         q("ALTER TABLE `item` ADD INDEX ( `wall` )");  
58 }
59
60 function update_1002() {
61         q("ALTER TABLE `item` ADD `gravity` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `wall` ");
62 }
63
64 function update_1003() {
65         q("ALTER TABLE `contact` DROP `issued-pubkey` , DROP `ret-id` , DROP `ret-pubkey` ");
66         q("ALTER TABLE `contact` ADD `usehub` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `ret-aes`");
67         q("ALTER TABLE `contact` ADD `hub-verify` CHAR( 255 ) NOT NULL AFTER `usehub`");
68         q("ALTER TABLE `contact` ADD INDEX ( `uid` ) ,  ADD INDEX ( `self` ),  ADD INDEX ( `issued-id` ),  ADD INDEX ( `dfrn-id` )"); 
69         q("ALTER TABLE `contact` ADD INDEX ( `blocked` ),   ADD INDEX ( `readonly` )");
70 }
71
72 function update_1004() {
73         q("ALTER TABLE `contact` ADD `subhub` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `usehub`");
74 }
75
76 function update_1005() {
77
78         q("ALTER TABLE `user` ADD `spubkey` TEXT NOT NULL AFTER `prvkey` ,
79                 ADD `sprvkey` TEXT NOT NULL AFTER `spubkey`");
80
81 }
82
83 function update_1006() {
84
85         // create 's' keys for everybody that does not have one
86
87         $r = q("SELECT * FROM `user` WHERE `spubkey` = '' ");
88         if(count($r)) {
89                 foreach($r as $rr) {
90                         $sres=openssl_pkey_new(array('encrypt_key' => false ));
91                         $sprvkey = '';
92                         openssl_pkey_export($sres, $sprvkey);
93                         $spkey = openssl_pkey_get_details($sres);
94                         $spubkey = $spkey["key"];
95                         $r = q("UPDATE `user` SET `spubkey` = '%s', `sprvkey` = '%s'
96                                 WHERE `uid` = %d LIMIT 1",
97                                 dbesc($spubkey),
98                                 dbesc($sprvkey),
99                                 intval($rr['uid'])
100                         );
101                 }
102         }
103 }
104
105 function update_1007() {
106         q("ALTER TABLE `user` ADD `page-flags` INT NOT NULL DEFAULT '0' AFTER `notify-flags`");
107         q("ALTER TABLE `user` ADD INDEX ( `nickname` )");  
108 }
109
110 function update_1008() {
111         q("ALTER TABLE `profile` ADD `with` TEXT NOT NULL AFTER `marital` ");
112 }
113
114 function update_1009() {
115         q("ALTER TABLE `user` ADD `allow_location` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `default-location` ");
116 }
117
118 function update_1010() {
119         q("ALTER TABLE `contact` ADD `lrdd` CHAR( 255 ) NOT NULL AFTER `url` ");
120 }
121
122 function update_1011() {
123         q("ALTER TABLE `contact` ADD `nick` CHAR( 255 ) NOT NULL AFTER `name` ");
124         $r = q("SELECT * FROM `contact` WHERE 1");
125         if(count($r)) {
126                 foreach($r as $rr) {
127                                 q("UPDATE `contact` SET `nick` = '%s' WHERE `id` = %d LIMIT 1",
128                                         dbesc(basename($rr['url'])),
129                                         intval($rr['id'])
130                                 );
131                 }
132         }
133 }
134
135 function update_1012() {
136         q("ALTER TABLE `item` ADD `inform` MEDIUMTEXT NOT NULL AFTER `tag` ");
137 }
138
139 function update_1013() {
140         q("ALTER TABLE `item` ADD `target-type` CHAR( 255 ) NOT NULL 
141                 AFTER `object` , ADD `target` TEXT NOT NULL AFTER `target-type`");
142
143
144 function update_1014() {
145         require_once('include/Photo.php');
146         q("ALTER TABLE `contact` ADD `micro` TEXT NOT NULL AFTER `thumb` ");
147         $r = q("SELECT * FROM `photo` WHERE `scale` = 4");
148         if(count($r)) {
149                 foreach($r as $rr) {
150                         $ph = new Photo($rr['data']);
151                         if($ph->is_valid()) {
152                                 $ph->scaleImage(48);
153                                 $ph->store($rr['uid'],$rr['contact-id'],$rr['resource-id'],$rr['filename'],$rr['album'],6,(($rr['profile']) ? 1 : 0));
154                         }
155                 }
156         }
157         $r = q("SELECT * FROM `contact` WHERE 1");
158         if(count($r)) {
159                 foreach($r as $rr) {            
160                         if(stristr($rr['thumb'],'avatar'))
161                                 q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d LIMIT 1",
162                                         dbesc(str_replace('avatar','micro',$rr['thumb'])),
163                                         intval($rr['id']));
164                         else
165                                 q("UPDATE `contact` SET `micro` = '%s' WHERE `id` = %d LIMIT 1",
166                                         dbesc(str_replace('5.jpg','6.jpg',$rr['thumb'])),
167                                         intval($rr['id']));
168                 }
169         }
170 }
171
172 function update_1015() {
173         q("ALTER TABLE `item` CHANGE `body` `body` mediumtext NOT NULL");
174 }
175
176 function update_1016() {
177         q("ALTER TABLE `user` ADD `openid` CHAR( 255 ) NOT NULL AFTER `email` ");
178 }
179
180 function update_1017() {
181
182         q(" CREATE TABLE IF NOT EXISTS `clients` (
183 `client_id` VARCHAR( 20 ) NOT NULL ,
184 `pw` VARCHAR( 20 ) NOT NULL ,
185 `redirect_uri` VARCHAR( 200 ) NOT NULL ,
186 PRIMARY KEY ( `client_id` )
187 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
188
189         q(" CREATE TABLE IF NOT EXISTS `tokens` (
190 `id` VARCHAR( 40 ) NOT NULL ,
191 `client_id` VARCHAR( 20 ) NOT NULL ,
192 `expires` INT NOT NULL ,
193 `scope` VARCHAR( 200 ) NOT NULL ,
194 PRIMARY KEY ( `id` )
195 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
196
197         q("CREATE TABLE IF NOT EXISTS `auth_codes` (
198 `id` VARCHAR( 40 ) NOT NULL ,
199 `client_id` VARCHAR( 20 ) NOT NULL ,
200 `redirect_uri` VARCHAR( 200 ) NOT NULL ,
201 `expires` INT NOT NULL ,
202 `scope` VARCHAR( 250 ) NOT NULL ,
203 PRIMARY KEY ( `id` )
204 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
205
206 }
207
208 function update_1018() {
209         q("CREATE TABLE IF NOT EXISTS `queue` (
210 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
211 `cid` INT NOT NULL ,
212 `created` DATETIME NOT NULL ,
213 `last` DATETIME NOT NULL ,
214 `content` MEDIUMTEXT NOT NULL
215 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
216 }
217
218 function update_1019() {
219         q("ALTER TABLE `mail` DROP `delivered`");
220         q("ALTER TABLE `profile` ADD `showwith` TINYINT(1) NOT NULL DEFAULT '0' AFTER `marital` ");
221 }
222
223 function update_1020() {
224         q("ALTER TABLE `profile` DROP `showwith`");
225         q("ALTER TABLE `item` ADD `thr-parent` CHAR( 255 ) NOT NULL AFTER `parent-uri` ");
226 }
227
228 function update_1021() {
229         q("ALTER TABLE `profile_check` ADD `sec` CHAR( 255 ) NOT NULL AFTER `dfrn_id` ");
230         q("ALTER TABLE `profile_check` ADD `cid` INT(10) unsigned  NOT NULL DEFAULT '0' AFTER `uid`");
231         q("ALTER TABLE `item` ADD `private` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `deny_gid` ");
232 }
233
234 function update_1022() {
235         q("CREATE TABLE `pconfig` (
236                 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
237                 `uid` INT NOT NULL DEFAULT '0',
238                 `cat` CHAR( 255 ) NOT NULL ,
239                 `k` CHAR( 255 ) NOT NULL ,
240                 `v` MEDIUMTEXT NOT NULL
241                 ) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_general_ci ");
242 }
243
244 function update_1023() {
245         q("ALTER TABLE `user` ADD `register_date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `timezone` ,
246         ADD `login_date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `register_date` ");
247 }
248
249 function update_1024() {
250         q("ALTER TABLE `profile` ADD `keywords` TEXT NOT NULL AFTER `religion` ");
251 }
252
253 function update_1025() {
254         q("ALTER TABLE `user` ADD `maxreq` int(11) NOT NULL DEFAULT '10' AFTER `pwdreset` ");
255 }
256
257 function update_1026() {
258         q("CREATE TABLE IF NOT EXISTS `hook` (
259         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
260         `hook` CHAR( 255 ) NOT NULL ,
261         `file` CHAR( 255 ) NOT NULL ,
262         `function` CHAR( 255 ) NOT NULL
263         ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
264 }
265
266
267 function update_1027() {
268         q("CREATE TABLE IF NOT EXISTS `addon` (
269         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
270         `name` CHAR( 255 ) NOT NULL ,
271         `version` CHAR( 255 ) NOT NULL ,
272         `installed` TINYINT( 1 ) NOT NULL DEFAULT '0' 
273         ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
274 }
275
276 function update_1028() {
277         q("ALTER TABLE `user` ADD `openidserver` text NOT NULL AFTER `deny_gid` ");
278 }
279
280 function update_1029() {
281         q("ALTER TABLE `contact` ADD `info` MEDIUMTEXT NOT NULL AFTER `reason` ");
282 }
283
284 function update_1030() {
285         q("ALTER TABLE `contact` ADD `bdyear` CHAR( 4 ) NOT NULL COMMENT 'birthday notify flag' AFTER `profile-id` ");
286
287         q("CREATE TABLE IF NOT EXISTS `event` (
288         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
289         `uid` INT NOT NULL ,
290         `cid` INT NOT NULL ,
291         `created` DATETIME NOT NULL ,
292         `edited` DATETIME NOT NULL ,
293         `start` DATETIME NOT NULL ,
294         `finish` DATETIME NOT NULL ,
295         `desc` TEXT NOT NULL ,
296         `location` TEXT NOT NULL ,
297         `type` CHAR( 255 ) NOT NULL ,
298         `adjust` TINYINT( 1 ) NOT NULL DEFAULT '1',
299         `allow_cid` MEDIUMTEXT NOT NULL ,
300         `allow_gid` MEDIUMTEXT NOT NULL ,
301         `deny_cid` MEDIUMTEXT NOT NULL ,
302         `deny_gid` MEDIUMTEXT NOT NULL
303         ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
304
305
306 }
307
308 function update_1031() {
309         // Repair any bad links that slipped into the item table
310         $r = q("SELECT `id`, `object` FROM `item` WHERE `object` != '' ");
311         if($r && count($r)) {
312                 foreach($r as $rr) {
313                         if(strstr($rr['object'],'type=&quot;http')) {
314                                 q("UPDATE `item` SET `object` = '%s' WHERE `id` = %d LIMIT 1",
315                                         dbesc(str_replace('type=&quot;http','href=&quot;http',$rr['object'])),
316                                         intval($rr['id'])
317                                 );
318                         }
319                 }
320         }
321 }
322         
323 function update_1032() {
324         q("ALTER TABLE `profile` ADD `pdesc` CHAR( 255 ) NOT NULL AFTER `name` ");
325 }
326
327 function update_1033() {
328         q("CREATE TABLE IF NOT EXISTS `cache` (
329                 `k` CHAR( 255 ) NOT NULL PRIMARY KEY ,
330                 `v` TEXT NOT NULL,
331                 `updated` DATETIME NOT NULL
332                 ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
333 }
334
335
336 function update_1034() {
337
338         // If you have any of these parent-less posts they can cause problems, and 
339         // we need to delete them. You can't see them anyway.
340         // Legitimate items will usually get re-created on the next 
341         // pull from the hub.
342         // But don't get rid of a post that may have just come in 
343         // and may not yet have the parent id set.
344
345         q("DELETE FROM `item` WHERE `parent` = 0 AND `created` < UTC_TIMESTAMP() - INTERVAL 2 MINUTE");
346
347 }
348
349
350 function update_1035() {
351
352         q("ALTER TABLE `contact` ADD `success_update` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `last-update` ");
353
354 }
355
356 function update_1036() {
357
358         $r = dbq("SELECT * FROM `contact` WHERE `network` = 'dfrn' && `photo` LIKE '%include/photo%' ");
359         if(count($r)) {
360                 foreach($r as $rr) {
361                         q("UPDATE `contact` SET `photo` = '%s', `thumb` = '%s', `micro` = '%s' WHERE `id` = %d LIMIT 1",
362                                 dbesc(str_replace('include/photo','photo',$rr['photo'])),
363                                 dbesc(str_replace('include/photo','photo',$rr['thumb'])),
364                                 dbesc(str_replace('include/photo','photo',$rr['micro'])),
365                                 intval($rr['id']));
366                 }
367         }
368 }
369
370 function update_1037() {
371
372         q("ALTER TABLE `contact` CHANGE `lrdd` `alias` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
373
374 }
375
376 function update_1038() {
377  q("ALTER TABLE `item` ADD `plink` CHAR( 255 ) NOT NULL AFTER `target` ");
378 }
379
380 function update_1039() {
381         q("ALTER TABLE `addon` ADD `timestamp` BIGINT NOT NULL DEFAULT '0'");
382 }
383
384
385 function update_1040() {
386
387         q("CREATE TABLE IF NOT EXISTS `fcontact` (
388         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
389         `url` CHAR( 255 ) NOT NULL ,
390         `name` CHAR( 255 ) NOT NULL ,
391         `photo` CHAR( 255 ) NOT NULL
392         ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
393
394         q("CREATE TABLE IF NOT EXISTS `ffinder` (
395         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
396         `uid` INT UNSIGNED NOT NULL ,
397         `cid` INT UNSIGNED NOT NULL ,
398         `fid` INT UNSIGNED NOT NULL
399         ) ENGINE = MYISAM DEFAULT CHARSET=utf8 ");
400
401 }
402
403 function update_1041() {
404         q("ALTER TABLE `profile` CHANGE `keywords` `prv_keywords` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
405         q("ALTER TABLE `profile` ADD `pub_keywords` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `religion` ");
406 }
407
408 function update_1042() {
409         q("ALTER TABLE `user` ADD `expire` INT UNSIGNED NOT NULL DEFAULT '0' AFTER `maxreq` ");
410 }
411
412
413 function update_1043() {
414         q("ALTER TABLE `user` ADD `blockwall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `blocked` ");
415 }
416
417 function update_1044() {
418         q("ALTER TABLE `profile` ADD FULLTEXT ( `pub_keywords` ) ");
419         q("ALTER TABLE `profile` ADD FULLTEXT ( `prv_keywords` ) ");
420 }
421
422 function update_1045() {
423         q("ALTER TABLE `user` ADD `language` CHAR( 16 ) NOT NULL DEFAULT 'en' AFTER `timezone` ");
424 }
425
426 function update_1046() {
427         q("ALTER TABLE `item` ADD `attach` MEDIUMTEXT NOT NULL AFTER `tag` ");
428 }
429
430 function update_1047() {
431         q("ALTER TABLE `contact` ADD `writable` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `readonly` ");
432 }
433
434 function update_1048() {
435         q("UPDATE `contact` SET `writable` = 1 WHERE `network` = 'stat' AND `notify` != '' ");
436 }
437
438 function update_1049() {
439         q("CREATE TABLE `mailacct` (
440         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
441         `uid` INT NOT NULL,
442         `server` CHAR( 255 ) NOT NULL ,
443         `user` CHAR( 255 ) NOT NULL ,
444         `pass` CHAR( 255 ) NOT NULL ,
445         `reply_to` CHAR( 255 ) NOT NULL ,
446         `last_check` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00'
447         ) ENGINE = MYISAM ");
448 }
449
450 function update_1050() {
451         q("CREATE TABLE `attach` (
452         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
453         `uid` INT NOT NULL ,
454         `filetype` CHAR( 64 ) NOT NULL ,
455         `filesize` INT NOT NULL ,
456         `data` LONGBLOB NOT NULL ,
457         `created` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
458         `edited` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
459         `allow_cid` MEDIUMTEXT NOT NULL ,
460         `allow_gid` MEDIUMTEXT NOT NULL ,
461         `deny_cid` MEDIUMTEXT NOT NULL ,
462         `deny_gid` MEDIUMTEXT NOT NULL
463         ) ENGINE = MYISAM ");
464
465 }
466
467 function update_1051() {
468         q("ALTER TABLE `mailacct` ADD `port` INT NOT NULL AFTER `server` ,
469                 ADD `ssltype` CHAR( 16 ) NOT NULL AFTER `port` ,
470                 ADD `mailbox` CHAR( 255 ) NOT NULL AFTER `ssltype` ");
471
472         q("ALTER TABLE `contact` ADD `addr` CHAR( 255 ) NOT NULL AFTER `url` ");
473 }
474
475 function update_1052() {
476         q("ALTER TABLE `mailacct` CHANGE `pass` `pass` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL");
477         q("ALTER TABLE `mailacct` ADD `pubmail` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `reply_to` ");
478         q("ALTER TABLE `item` ADD `pubmail` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `private` ");
479 }
480
481
482 function update_1053() {
483         q("ALTER TABLE `item` ADD `extid` CHAR( 255 ) NOT NULL AFTER `parent-uri` , ADD INDEX ( `extid` ) ");
484 }
485
486 function update_1054() {
487         q("ALTER TABLE `register` ADD `language` CHAR( 16 ) NOT NULL AFTER `password` ");
488 }
489
490 function update_1055() {
491         q("ALTER TABLE `profile` ADD `hidewall` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `hide-friends` ");
492 }
493
494 function update_1056() {
495         q("ALTER TABLE `attach` ADD `hash` CHAR( 64 ) NOT NULL AFTER `uid` ");
496 }
497
498 function update_1057() {
499         q("ALTER TABLE `attach` ADD `filename` CHAR( 255 ) NOT NULL AFTER `hash` ");
500 }
501
502 function update_1058() {
503         q("ALTER TABLE `item` ADD `event-id` INT NOT NULL AFTER `resource-id` ");
504 }
505
506 function update_1059() {
507         q("ALTER TABLE `queue` ADD `network` CHAR( 32 ) NOT NULL AFTER `cid` ");
508 }
509
510 function update_1060() {
511         q("ALTER TABLE `event` ADD `uri` CHAR( 255 ) NOT NULL AFTER `cid` ");
512 }
513
514 function update_1061() {
515         q("ALTER TABLE `event` ADD `nofinish` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `type` ");
516 }
517
518 function update_1062() {
519         q("ALTER TABLE `user` ADD `prvnets` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `page-flags` ");
520 }
521 function update_1063() {
522         q("ALTER TABLE `addon` ADD `plugin_admin` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `timestamp` ");
523 }
524
525 function update_1064() {
526         q("ALTER TABLE `item` ADD `app` CHAR( 255 ) NOT NULL AFTER `body` ");
527 }
528
529 function update_1065() {
530         q("ALTER TABLE `intro` ADD `fid` INT NOT NULL DEFAULT '0' AFTER `uid`");
531 }
532
533 function update_1066() {
534         $r = q("ALTER TABLE `item` ADD `received` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `edited` ");
535         if($r)
536                 q("ALTER TABLE `item` ADD INDEX ( `received` ) ");
537
538         $r = q("UPDATE `item` SET `received` = `edited` WHERE 1");
539 }
540
541 function update_1067() {
542         q("ALTER TABLE `ffinder` ADD `type` CHAR( 16 ) NOT NULL AFTER `id` ,
543         ADD `note` TEXT NOT NULL AFTER `type` ");
544 }
545
546 function update_1068() {
547         // 1067 was short-sighted. Undo it.
548         q("ALTER TABLE `ffinder` DROP `type` , DROP `note` ");
549
550         // and do this instead.
551
552         q("CREATE TABLE IF NOT EXISTS `fsuggest` (
553         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
554         `uid` INT NOT NULL ,
555         `cid` INT NOT NULL ,
556         `name` CHAR( 255 ) NOT NULL ,
557         `url` CHAR( 255 ) NOT NULL ,
558         `photo` CHAR( 255 ) NOT NULL ,
559         `note` TEXT NOT NULL ,
560         `created` DATETIME NOT NULL 
561         ) ENGINE = MYISAM DEFAULT CHARSET=utf8");
562
563 }
564
565 function update_1069() {
566         q("ALTER TABLE `fsuggest` ADD `request` CHAR( 255 ) NOT NULL AFTER `url` ");
567         q("ALTER TABLE `fcontact` ADD `request` CHAR( 255 ) NOT NULL AFTER `photo` ");
568 }
569
570 // mail body needs to accomodate private photos
571
572 function update_1070() {
573         q("ALTER TABLE `mail` CHANGE `body` `body` MEDIUMTEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ");
574 }
575
576 function update_1071() {
577         q("ALTER TABLE `photo` ADD INDEX ( `uid` ) ");
578         q("ALTER TABLE `photo` ADD INDEX ( `resource-id` ) ");
579         q("ALTER TABLE `photo` ADD INDEX ( `album` ) ");
580         q("ALTER TABLE `photo` ADD INDEX ( `scale` ) ");
581         q("ALTER TABLE `photo` ADD INDEX ( `profile` ) ");
582
583 }
584
585 function update_1072() {
586         q("ALTER TABLE `item` ADD `starred` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` ");
587         q("ALTER TABLE `item` ADD INDEX ( `starred` ) ");
588 }
589
590 function update_1073() {
591         q("ALTER TABLE `contact` ADD `remote_self` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `self` ");
592 }
593
594 function update_1074() {
595         q("ALTER TABLE `user` ADD `hidewall` TINYINT( 1) NOT NULL DEFAULT '0' AFTER `blockwall` ");
596         $r = q("SELECT `uid` FROM `profile` WHERE `is-default` = 1 AND `hidewall` = 1");
597         if(count($r)) {
598                 foreach($r as $rr)
599                         q("UPDATE `user` SET `hidewall` = 1 WHERE `uid` = %d LIMIT 1",
600                                 intval($rr['uid'])
601                         );
602         }
603         q("ALTER TABLE `profile` DROP `hidewall`");
604 }
605
606 function update_1075() {
607         q("ALTER TABLE `user` ADD `guid` CHAR( 16 ) NOT NULL AFTER `uid` ");
608         $r = q("SELECT `uid` FROM `user` WHERE 1");
609         if(count($r)) {
610                 foreach($r as $rr) {
611                         $found = true;
612                         do {
613                                 $guid = substr(random_string(),0,16);
614                                 $x = q("SELECT `uid` FROM `user` WHERE `guid` = '%s' LIMIT 1",
615                                         dbesc($guid)
616                                 );
617                                 if(! count($x))
618                                         $found = false;
619                         } while ($found == true );
620
621                         q("UPDATE `user` SET `guid` = '%s' WHERE `uid` = %d LIMIT 1",
622                                 dbesc($guid),
623                                 intval($rr['uid'])
624                         );
625                 }
626         }
627 }
628
629 function update_1076() {
630         q("CREATE TABLE `guid` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
631                 `guid` CHAR( 16 ) NOT NULL , INDEX ( `guid` ) ) ENGINE = MYISAM ");
632
633 }
634
635 // There was a typo in 1076 so we'll try again in 1077 to make sure
636 // We'll also make it big enough to allow for future growth, I seriously 
637 // doubt Diaspora will be able to leave guids at 16 bytes,
638 // and we can also use the same structure for our own larger guids
639
640 function update_1077() {
641         q("CREATE TABLE IF NOT EXISTS `guid` ( `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
642                 `guid` CHAR( 16 ) NOT NULL , INDEX ( `guid` ) ) ENGINE = MYISAM ");
643
644         q("ALTER TABLE `guid` CHANGE `guid` `guid` CHAR( 64 ) NOT NULL"); 
645 }
646
647 function update_1078() {
648         q("ALTER TABLE `item` ADD `guid` CHAR( 64 ) NOT NULL AFTER `id` , ADD INDEX ( `guid` ) ");
649 }
650
651 function update_1079() {
652         q("CREATE TABLE IF NOT EXISTS `sign` (
653         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
654         `iid` INT UNSIGNED NOT NULL ,
655         `signed_text` MEDIUMTEXT NOT NULL ,
656         `signature` TEXT NOT NULL ,
657         `signer` CHAR( 255 ) NOT NULL ,
658         INDEX ( `iid` )
659         ) ENGINE = MYISAM ");
660
661         q("ALTER TABLE `fcontact` ADD `nick` CHAR( 255 ) NOT NULL ,
662         ADD `addr` CHAR( 255 ) NOT NULL ,
663         ADD `notify` CHAR( 255 ) NOT NULL ,
664         ADD `poll` CHAR( 255 ) NOT NULL ,
665         ADD `confirm` CHAR( 255 ) NOT NULL ,
666         ADD `priority` TINYINT( 1 ) NOT NULL ,
667         ADD `network` CHAR( 32 ) NOT NULL ,
668         ADD `alias` CHAR( 255 ) NOT NULL ,
669         ADD `pubkey` TEXT NOT NULL ,
670         ADD INDEX ( `addr` ) , 
671         ADD INDEX ( `network` ) ");
672
673 }
674
675 function update_1080() {
676         q("ALTER TABLE `fcontact` ADD `updated` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00'");
677 }
678
679 function update_1081() {
680         // there was a typo in update 1081 so it was corrected and moved up to 1082
681 }
682
683 function update_1082() {
684         q("ALTER TABLE `photo` ADD `guid` CHAR( 64 ) NOT NULL AFTER `contact-id`,
685                 ADD INDEX ( `guid` )  ");
686         // make certain the following code is only executed once
687         $r = q("select `id` from `photo` where `guid` != '' limit 1");
688         if($r && count($r))
689                 return;
690         $r = q("SELECT distinct(`resource-id`) FROM `photo` WHERE 1 group by `id`");
691         if(count($r)) {
692                 foreach($r as $rr) {
693                         $guid = get_guid();
694                         q("update `photo` set `guid` = '%s' where `resource-id` = '%s'",
695                                 dbesc($guid),
696                                 dbesc($rr['resource-id'])
697                         );
698                 }
699         }
700 }
701
702 function update_1083() {
703         q("CREATE TABLE IF NOT EXISTS `deliverq` (
704         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
705         `cmd` CHAR( 32 ) NOT NULL ,
706         `item` INT NOT NULL ,
707         `contact` INT NOT NULL
708         ) ENGINE = MYISAM ");
709
710 }
711
712 function update_1084() {
713         q("ALTER TABLE `contact` ADD `attag` CHAR( 255 ) NOT NULL AFTER `nick` ");
714 }
715
716 function update_1085() {
717         q("CREATE TABLE IF NOT EXISTS `search` (
718         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
719         `uid` INT NOT NULL ,
720         `term` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
721         INDEX ( `uid` ),
722         INDEX ( `term` )
723         ) ENGINE = MYISAM ");
724 }
725
726 function update_1086() {
727         q("ALTER TABLE `item` ADD `bookmark` tinyint(1) NOT NULL DEFAULT '0' AFTER `starred` ");
728 }
729
730 function update_1087() {
731         q("ALTER TABLE `item` ADD `commented` datetime NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `edited` ");
732
733         $r = q("SELECT `id` FROM `item` WHERE `parent` = `id` ");
734         if(count($r)) {
735                 foreach($r as $rr) {
736                         $x = q("SELECT max(`created`) AS `cdate` FROM `item` WHERE `parent` = %d LIMIT 1",
737                                 intval($rr['id'])
738                         );
739                         if(count($x))
740                                 q("UPDATE `item` SET `commented` = '%s' WHERE `id` = %d LIMIT 1",
741                                         dbesc($x[0]['cdate']),
742                                         intval($rr['id'])
743                                 );
744                 }
745         }
746 }
747
748 function update_1088() {
749         q("ALTER TABLE `user` ADD `account_expired` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `expire` ,
750                 ADD `account_expires_on` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `account_expired` ,
751                 ADD `expire_notification_sent` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `account_expires_on` ");
752 }
753
754 function update_1089() {
755         q("ALTER TABLE `user` ADD `blocktags` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `hidewall` ");
756 }
757
758 function update_1090() {
759         q("ALTER TABLE `contact` ADD `batch` char(255) NOT NULL AFTER `prvkey` ");
760
761         q("UPDATE `contact` SET `batch` = concat(substring_index(`url`,'/',3),'/receive/public') WHERE `network` = 'dspr' ");
762
763 }
764
765 function update_1091() {
766
767         // catch a few stragglers that may have crept in before we added this on remote connects
768         q("UPDATE `contact` SET `batch` = concat(substring_index(`url`,'/',3),'/receive/public') WHERE `network` = 'dspr' AND `batch` = '' ");
769         q("ALTER TABLE `queue` ADD `batch` TINYINT( 1 ) NOT NULL DEFAULT '0' ");
770         q("ALTER TABLE `fcontact` ADD `batch` char(255) NOT NULL AFTER `addr` ");
771
772 }
773
774 function update_1092() {
775         q("ALTER TABLE `user` ADD INDEX ( `login_date` ) ");
776         q("ALTER TABLE `user` ADD INDEX ( `account_expired` ) ");
777 }
778
779 function update_1093() {
780         q("CREATE TABLE IF NOT EXISTS `fserver` (
781         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
782         `server` CHAR( 255 ) NOT NULL ,
783         `posturl` CHAR( 255 ) NOT NULL ,
784         `key` TEXT NOT NULL,
785         INDEX ( `server` )
786         ) ENGINE = MYISAM ");
787
788         q("ALTER TABLE `group` ADD `visible` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `uid` ");
789
790 }
791
792 function update_1094() {
793         q("ALTER TABLE `item` ADD `postopts` TEXT NOT NULL AFTER `target` ");
794 }
795
796 function update_1095() {
797         q("ALTER TABLE `contact` ADD `bd` DATE NOT NULL AFTER `bdyear` ");
798 }
799
800 function update_1096() {
801         q("ALTER TABLE `item` ADD `origin` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `deleted` , ADD INDEX ( `origin` ) ");
802 }
803
804 function update_1097() {
805         q("ALTER TABLE `queue` 
806                 ADD INDEX (`cid`), 
807                 ADD INDEX (`created`), 
808                 ADD INDEX (`last`), 
809                 ADD INDEX (`network`), 
810                 ADD INDEX (`batch`) 
811         ");
812 }
813
814 function update_1098() {
815         q("ALTER TABLE `contact` 
816                 ADD INDEX (`network`), 
817                 ADD INDEX (`name`), 
818                 ADD INDEX (`nick`), 
819                 ADD INDEX (`attag`), 
820                 ADD INDEX (`url`),
821                 ADD INDEX (`addr`), 
822                 ADD INDEX (`batch`) 
823         ");
824 }
825
826 function update_1099() {
827         q("CREATE TABLE IF NOT EXISTS `gcontact` (
828         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
829         `name` CHAR( 255 ) NOT NULL ,
830         `url` CHAR( 255 ) NOT NULL ,
831         `nurl` CHAR( 255 ) NOT NULL ,
832         `photo` CHAR( 255 ) NOT NULL
833         ) ENGINE = MYISAM ");
834
835         q("CREATE TABLE IF NOT EXISTS `glink` (
836         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
837         `cid` INT NOT NULL ,
838         `uid` INT NOT NULL ,
839         `gcid` INT NOT NULL,
840         `updated` DATETIME NOT NULL
841         ) ENGINE = MYISAM ");
842
843         q("ALTER TABLE `gcontact` ADD INDEX (`nurl`) ");
844         q("ALTER TABLE `glink` ADD INDEX (`cid`), ADD INDEX (`uid`), ADD INDEX (`gcid`), ADD INDEX (`updated`) ");
845
846         q("ALTER TABLE `contact` ADD `poco` TEXT NOT NULL AFTER `confirm` "); 
847
848 }
849
850 function update_1100() {
851         q("ALTER TABLE `contact` ADD `nurl` CHAR( 255 ) NOT NULL AFTER `url` ");
852         q("alter table contact add index (`nurl`) ");
853
854         require_once('include/text.php');
855
856         $r = q("select id, url from contact where url != '' and nurl = '' ");
857         if(count($r)) {
858                 foreach($r as $rr) {
859                         q("update contact set nurl = '%s' where id = %d limit 1",
860                                 dbesc(normalise_link($rr['url'])),
861                                 intval($rr['id'])
862                         ); 
863                 }
864         }
865 }
866
867
868 function update_1101() {
869         q("CREATE TABLE IF NOT EXISTS `gcign` (
870         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
871         `uid` INT NOT NULL ,
872         `gcid` INT NOT NULL
873         ) ENGINE = MYISAM ");
874
875         q("ALTER TABLE `gcign` ADD INDEX (`uid`), ADD INDEX (`gcid`) ");
876 }
877
878 function update_1102() {
879         q("ALTER TABLE `clients` ADD `name` TEXT NULL DEFAULT NULL AFTER `redirect_uri` "); 
880         q("ALTER TABLE `clients` ADD `icon` TEXT NULL DEFAULT NULL AFTER `name` "); 
881         q("ALTER TABLE `clients` ADD `uid` INT NOT NULL DEFAULT 0 AFTER `icon` "); 
882
883         q("ALTER TABLE `tokens` ADD `secret` TEXT NOT NULL AFTER `id` "); 
884         q("ALTER TABLE `tokens` ADD `uid` INT NOT NULL AFTER `scope` "); 
885 }
886
887
888 function update_1103() {
889 //      q("ALTER TABLE `item` ADD INDEX ( `wall` ) ");
890         q("ALTER TABLE `item` ADD FULLTEXT ( `tag` ) "); 
891         q("ALTER TABLE `contact` ADD INDEX ( `pending` ) ");
892         q("ALTER TABLE `user` ADD INDEX ( `hidewall` ) ");
893         q("ALTER TABLE `user` ADD INDEX ( `blockwall` ) ");
894         q("ALTER TABLE `user` ADD INDEX ( `blocked` ) ");
895         q("ALTER TABLE `user` ADD INDEX ( `verified` ) ");
896
897 }
898
899 function update_1104() {
900         q("ALTER TABLE `item` ADD `forum_mode` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `origin` , ADD INDEX ( `forum_mode` ) ");
901
902 }
903
904 function update_1105() {
905         q("ALTER TABLE `mail` ADD `convid` INT NOT NULL AFTER `contact-id` ");
906         q("ALTER TABLE `mail` ADD `guid` CHAR( 64 ) NOT NULL AFTER `uid` ");
907
908         q("CREATE TABLE IF NOT EXISTS `conv` (
909         `id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
910         `guid` CHAR( 64 ) NOT NULL ,
911         `recips` MEDIUMTEXT NOT NULL ,
912         `uid` INT NOT NULL
913         ) ENGINE = MYISAM ");
914 }
915
916
917 function update_1106() {
918         q("ALTER TABLE `item` ADD INDEX ( `author-link` ) ");
919
920 }
921
922 function update_1107() {
923         q("ALTER TABLE `item` ADD INDEX ( `bookmark` ) ");
924
925 }
926
927 function update_1108() { 
928         q("ALTER TABLE `contact` ADD `hidden` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `writable` ,
929 ADD INDEX ( `hidden` ) ");
930
931 }
932
933 function update_1109() {
934         q("ALTER TABLE `conv` ADD `creator` CHAR( 255 ) NOT NULL ,
935                 ADD `created` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
936                 ADD `updated` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00',
937                 ADD `subject` MEDIUMTEXT NOT NULL,
938                 ADD INDEX ( `created` ), ADD INDEX ( `updated` ) ");
939 }
940
941 function update_1110() {
942         q("ALTER TABLE `mail` ADD `reply` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `seen`,
943                 ADD INDEX ( `reply` ), ADD INDEX ( `uid` ), ADD INDEX ( `guid` ), ADD INDEX ( `seen` ),
944                 ADD INDEX ( `uri` ), ADD INDEX ( `parent-uri`), ADD INDEX ( `created` ), ADD INDEX ( `convid` ) ");
945
946 }
947
948 function update_1111() {
949         q("ALTER TABLE `gcontact` ADD `connect` CHAR( 255 ) NOT NULL ");
950 }
951
952
953 function update_1112() {
954
955         q("CREATE TABLE IF NOT EXISTS `notify` (
956 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
957 `type` INT( 11 ) NOT NULL ,
958 `name` CHAR( 255 ) NOT NULL ,
959 `url` CHAR( 255 ) NOT NULL ,
960 `photo` CHAR( 255 ) NOT NULL ,
961 `date` DATETIME NOT NULL ,
962 `msg` MEDIUMTEXT NOT NULL ,
963 `uid` INT NOT NULL ,
964 `link` CHAR( 255 ) NOT NULL ,
965 `seen` TINYINT( 1 ) NOT NULL DEFAULT '0'
966 ) ENGINE = MYISAM ");
967
968         q("ALTER TABLE `notify` ADD INDEX ( `type` ), ADD INDEX ( `uid`), ADD INDEX (`seen`), ADD INDEX (`date`) ");
969
970 }
971
972 function update_1113() {
973         q("ALTER TABLE `notify` ADD `verb` CHAR( 255 ) NOT NULL ,
974 ADD `otype` CHAR( 16 ) NOT NULL");
975 }
976
977 function update_1114() {
978         q("CREATE TABLE IF NOT EXISTS `item_id` (
979 `iid` INT NOT NULL ,
980 `uid` INT NOT NULL ,
981 `face` CHAR( 255 ) NOT NULL ,
982 `dspr` CHAR( 255 ) NOT NULL ,
983 `twit` CHAR( 255 ) NOT NULL ,
984 `stat` CHAR( 255 ) NOT NULL ,
985 PRIMARY KEY ( `iid` ),
986 INDEX ( `uid` ),
987 INDEX ( `face` ),
988 INDEX ( `dspr` ),
989 INDEX ( `twit` ),
990 INDEX ( `stat` )
991 ) ENGINE = MYISAM ");
992
993 }
994
995 function update_1115() {
996         q("ALTER TABLE `item` ADD `moderated` 
997                 TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `pubmail`, 
998                 ADD INDEX (`moderated`) ");
999 }
1000
1001 function update_1116() {
1002         //typo! corrected update was rolled forward
1003 }
1004
1005 function update_1117() {
1006 q("create table if not exists `manage` (
1007 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1008 `uid` INT NOT NULL ,
1009 `mid` INT NOT NULL,
1010 INDEX ( `uid` ),
1011 INDEX ( `mid` )
1012 ) ENGINE = MYISAM ");
1013
1014 }
1015
1016 function update_1118() {
1017         // rolled forward
1018 }
1019
1020 function update_1119() {
1021 q("ALTER TABLE `contact` ADD `closeness` TINYINT( 2 ) NOT NULL DEFAULT '99' AFTER `reason` , ADD INDEX (`closeness`) ");
1022 q("update contact set closeness = 0 where self = 1");
1023 q("ALTER TABLE `item` ADD `spam` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` , ADD INDEX (`spam`) ");
1024 }
1025
1026
1027 function update_1120() {
1028
1029         // item table update from 1119 did not get into database.sql file.
1030         // might be missing on new installs. We'll check.
1031
1032         $r = q("describe item");
1033         if($r && count($r)) {
1034                 foreach($r as $rr)
1035                         if($rr['Field'] == 'spam')
1036                                 return;
1037         }
1038         q("ALTER TABLE `item` ADD `spam` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `visible` , ADD INDEX (`spam`) ");
1039
1040 }
1041
1042 function update_1121() {
1043         q("CREATE TABLE IF NOT EXISTS `poll_result` (
1044         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1045         `poll_id` INT NOT NULL ,
1046         `choice` INT NOT NULL ,
1047         INDEX ( `poll_id` ),
1048         INDEX ( `choice` )
1049         ) ENGINE = MYISAM ");
1050
1051         q("CREATE TABLE IF NOT EXISTS `poll` (
1052         `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1053         `uid` INT NOT NULL ,
1054         `q0` MEDIUMTEXT NOT NULL ,
1055         `q1` MEDIUMTEXT NOT NULL ,
1056         `q2` MEDIUMTEXT NOT NULL ,
1057         `q3` MEDIUMTEXT NOT NULL ,
1058         `q4` MEDIUMTEXT NOT NULL ,
1059         `q5` MEDIUMTEXT NOT NULL ,
1060         `q6` MEDIUMTEXT NOT NULL ,
1061         `q7` MEDIUMTEXT NOT NULL ,
1062         `q8` MEDIUMTEXT NOT NULL ,
1063         `q9` MEDIUMTEXT NOT NULL ,
1064         INDEX ( `uid` )
1065         ) ENGINE = MYISAM ");
1066
1067 }
1068
1069 function update_1122() {
1070 q("ALTER TABLE `notify` ADD `hash` CHAR( 64 ) NOT NULL AFTER `id` ,
1071 ADD INDEX ( `hash` ) ");
1072 }
1073
1074 function update_1123() {
1075 set_config('system','allowed_themes','dispy,quattro,testbubble,vier,darkbubble,darkzero,duepuntozero,greenzero,purplezero,quattro-green,slackr');
1076 }
1077
1078 function update_1124() {
1079 q("alter table item add index (`author-name`) ");
1080 }
1081
1082 function update_1125() {
1083   q("CREATE TABLE IF NOT EXISTS `notify-threads` (
1084   `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1085   `notify-id` INT NOT NULL,
1086   `master-parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
1087   `parent-item` INT( 10 ) unsigned NOT NULL DEFAULT '0',
1088   `receiver-uid` INT NOT NULL,
1089   INDEX ( `master-parent-item` ),
1090   INDEX ( `receiver-uid` )
1091   ) ENGINE = MyISAM DEFAULT CHARSET=utf8");
1092 }
1093
1094 function update_1126() {
1095         q("ALTER TABLE `mailacct` ADD `action` INT NOT NULL AFTER `pass`,
1096                 ADD `movetofolder` CHAR(255) NOT NULL AFTER `action`");
1097 }
1098
1099 function update_1127() {
1100         q("CREATE TABLE IF NOT EXISTS `spam` (
1101   `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1102   `uid` INT NOT NULL,
1103   `spam` INT NOT NULL DEFAULT '0',
1104   `ham` INT NOT NULL DEFAULT '0',
1105   `term` CHAR(255) NOT NULL,
1106   INDEX ( `uid` ),
1107   INDEX ( `spam` ),
1108   INDEX ( `ham` ),
1109   INDEX ( `term` )
1110   ) ENGINE = MyISAM DEFAULT CHARSET=utf8");
1111 }
1112
1113
1114 function update_1128() {
1115         q("alter table spam add `date` DATETIME NOT NULL DEFAULT '0000-00-00 00:00:00' AFTER `term` ");
1116 }
1117
1118 function update_1129() {
1119         q("ALTER TABLE `notify` ADD `parent` INT NOT NULL AFTER `link` , ADD INDEX ( `parent` ), ADD INDEX ( `link` ), ADD INDEX ( `otype` ) ");
1120 }
1121
1122 function update_1130() {
1123         q("ALTER TABLE `item` ADD `file` MEDIUMTEXT NOT NULL AFTER `inform`, ADD FULLTEXT KEY (`file`) ");
1124 }
1125
1126 function update_1131() {
1127         q("ALTER TABLE `contact` ADD `forum` TINYINT( 1 ) NOT NULL DEFAULT '0' AFTER `writable` , ADD INDEX ( `forum` ) ");
1128 }
1129
1130
1131 function update_1132() {
1132         q("CREATE TABLE IF NOT EXISTS `userd` (
1133 `id` INT NOT NULL AUTO_INCREMENT PRIMARY KEY ,
1134 `username` CHAR( 255 ) NOT NULL,
1135 INDEX ( `username` )
1136 ) ENGINE = MYISAM ");
1137
1138 }
1139