2010-09-09 05:14:17 +02:00
< ? php
2018-01-17 19:42:40 +01:00
use Friendica\Core\Addon ;
2017-11-07 03:22:52 +01:00
use Friendica\Core\Config ;
2018-07-20 04:15:21 +02:00
use Friendica\Core\L10n ;
2017-11-07 03:22:52 +01:00
use Friendica\Core\PConfig ;
2018-10-14 13:19:37 +02:00
use Friendica\Core\Update ;
2017-11-05 13:15:53 +01:00
use Friendica\Core\Worker ;
2018-07-20 14:19:26 +02:00
use Friendica\Database\DBA ;
2018-05-08 19:50:06 +02:00
use Friendica\Model\Contact ;
use Friendica\Model\Item ;
2018-01-21 04:37:13 +01:00
use Friendica\Model\User ;
2018-07-21 14:25:11 +02:00
use Friendica\Util\DateTimeFormat ;
2017-11-05 13:15:53 +01:00
2010-12-10 05:41:42 +01:00
/**
*
* update . php - automatic system update
*
2017-12-22 15:48:29 +01:00
* This function is responsible for doing post update changes to the data
* ( not the structure ) in the database .
2014-06-04 00:44:58 +02:00
*
2018-11-25 07:07:31 +01:00
* Database structure changes are done in config / dbstructure . config . php
2010-12-10 05:41:42 +01:00
*
2017-12-22 21:06:15 +01:00
* If there is a need for a post process to a structure change , update this file
2017-12-22 22:31:32 +01:00
* by adding a new function at the end with the number of the new DB_UPDATE_VERSION .
2010-12-10 05:41:42 +01:00
*
2017-12-22 22:31:32 +01:00
* The numbered script in this file has to be exactly like the DB_UPDATE_VERSION
2010-12-10 05:41:42 +01:00
*
2017-12-22 15:48:29 +01:00
* Example :
* You are currently on version 4711 and you are preparing changes that demand an update script .
2010-12-10 05:41:42 +01:00
*
2017-12-22 22:31:32 +01:00
* 1. Create a function " update_4712() " here in the update . php
2018-10-21 07:56:58 +02:00
* 2. Apply the needed structural changes in config / dbStructure . php
2018-11-25 07:07:31 +01:00
* 3. Set DB_UPDATE_VERSION in config / dbstructure . config . php to 4712.
2018-07-20 21:47:16 +02:00
*
* If you need to run a script before the database update , name the function " pre_update_4712() "
2010-12-10 05:41:42 +01:00
*/
2017-12-22 22:31:32 +01:00
function update_1178 () {
2017-12-22 15:48:29 +01:00
require_once 'mod/profiles.php' ;
2015-01-26 01:07:15 +01:00
$profiles = q ( " SELECT `uid`, `about`, `locality`, `pub_keywords`, `gender` FROM `profile` WHERE `is-default` " );
foreach ( $profiles AS $profile ) {
if ( $profile [ " about " ] . $profile [ " locality " ] . $profile [ " pub_keywords " ] . $profile [ " gender " ] == " " )
continue ;
$profile [ " pub_keywords " ] = profile_clean_keywords ( $profile [ " pub_keywords " ]);
$r = q ( " UPDATE `contact` SET `about` = '%s', `location` = '%s', `keywords` = '%s', `gender` = '%s' WHERE `self` AND `uid` = %d " ,
2018-07-21 15:10:13 +02:00
DBA :: escape ( $profile [ " about " ]),
DBA :: escape ( $profile [ " locality " ]),
DBA :: escape ( $profile [ " pub_keywords " ]),
DBA :: escape ( $profile [ " gender " ]),
2015-01-26 01:07:15 +01:00
intval ( $profile [ " uid " ])
);
}
}
2015-02-08 16:03:23 +01:00
2017-12-22 22:31:32 +01:00
function update_1179 () {
2017-11-07 03:22:52 +01:00
if ( Config :: get ( 'system' , 'no_community_page' ))
Config :: set ( 'system' , 'community_page_style' , CP_NO_COMMUNITY_PAGE );
2015-02-08 20:35:40 +01:00
2015-02-08 16:03:23 +01:00
// Update the central item storage with uid=0
2017-11-05 13:15:53 +01:00
Worker :: add ( PRIORITY_LOW , " threadupdate " );
2015-02-08 16:03:23 +01:00
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2015-02-08 16:03:23 +01:00
}
2015-03-07 21:24:39 +01:00
2017-12-22 22:31:32 +01:00
function update_1181 () {
2015-03-07 21:24:39 +01:00
// Fill the new fields in the term table.
2017-11-15 22:12:33 +01:00
Worker :: add ( PRIORITY_LOW , " TagUpdate " );
2015-03-07 21:24:39 +01:00
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2015-03-07 21:24:39 +01:00
}
2015-10-17 15:26:11 +02:00
2017-12-22 22:31:32 +01:00
function update_1189 () {
2015-10-17 15:26:11 +02:00
2017-11-07 03:22:52 +01:00
if ( strlen ( Config :: get ( 'system' , 'directory_submit_url' )) &&
! strlen ( Config :: get ( 'system' , 'directory' ))) {
Config :: set ( 'system' , 'directory' , dirname ( Config :: get ( 'system' , 'directory_submit_url' )));
2017-11-07 15:12:01 +01:00
Config :: delete ( 'system' , 'directory_submit_url' );
2015-10-17 15:26:11 +02:00
}
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2015-10-17 15:26:11 +02:00
}
2015-11-11 23:39:14 +01:00
2017-12-22 22:31:32 +01:00
function update_1191 () {
2017-11-07 03:22:52 +01:00
Config :: set ( 'system' , 'maintenance' , 1 );
2015-11-11 23:39:14 +01:00
2018-01-17 19:42:40 +01:00
if ( Addon :: isEnabled ( 'forumlist' )) {
2018-01-17 20:22:38 +01:00
$addon = 'forumlist' ;
$addons = Config :: get ( 'system' , 'addon' );
$addons_arr = [];
2015-11-12 16:42:27 +01:00
2018-01-17 20:22:38 +01:00
if ( $addons ) {
$addons_arr = explode ( " , " , str_replace ( " " , " " , $addons ));
2015-11-12 16:42:27 +01:00
2018-01-17 20:22:38 +01:00
$idx = array_search ( $addon , $addons_arr );
2015-11-11 23:39:14 +01:00
if ( $idx !== false ){
2018-01-17 20:22:38 +01:00
unset ( $addons_arr [ $idx ]);
2016-10-02 03:40:41 +02:00
//delete forumlist manually from addon and hook table
2018-01-17 19:42:40 +01:00
// since Addon::uninstall() don't work here
2015-11-13 00:16:39 +01:00
q ( " DELETE FROM `addon` WHERE `name` = 'forumlist' " );
q ( " DELETE FROM `hook` WHERE `file` = 'addon/forumlist/forumlist.php' " );
2018-01-17 20:22:38 +01:00
Config :: set ( 'system' , 'addon' , implode ( " , " , $addons_arr ));
2015-11-11 23:39:14 +01:00
}
}
}
2015-11-12 16:42:27 +01:00
// select old formlist addon entries
$r = q ( " SELECT `uid`, `cat`, `k`, `v` FROM `pconfig` WHERE `cat` = '%s' " ,
2018-07-21 15:10:13 +02:00
DBA :: escape ( 'forumlist' )
2015-11-11 23:40:26 +01:00
);
2015-11-11 23:39:14 +01:00
2015-11-12 16:42:27 +01:00
// convert old forumlist addon entries in new config entries
2018-07-21 14:46:04 +02:00
if ( DBA :: isResult ( $r )) {
2015-11-12 16:42:27 +01:00
foreach ( $r as $rr ) {
$uid = $rr [ 'uid' ];
$family = $rr [ 'cat' ];
$key = $rr [ 'k' ];
$value = $rr [ 'v' ];
2015-11-11 23:39:14 +01:00
2017-03-21 17:02:59 +01:00
if ( $key === 'randomise' )
2017-11-07 15:12:01 +01:00
PConfig :: delete ( $uid , $family , $key );
2015-11-11 23:39:14 +01:00
2015-11-12 16:42:27 +01:00
if ( $key === 'show_on_profile' ) {
2017-03-21 17:02:59 +01:00
if ( $value )
2017-11-07 03:22:52 +01:00
PConfig :: set ( $uid , feature , forumlist_profile , $value );
2015-11-11 23:39:14 +01:00
2017-11-07 15:12:01 +01:00
PConfig :: delete ( $uid , $family , $key );
2015-11-12 16:42:27 +01:00
}
2015-11-11 23:39:14 +01:00
2015-11-12 16:42:27 +01:00
if ( $key === 'show_on_network' ) {
2017-03-21 17:02:59 +01:00
if ( $value )
2017-11-07 03:22:52 +01:00
PConfig :: set ( $uid , feature , forumlist_widget , $value );
2015-11-11 23:39:14 +01:00
2017-11-07 15:12:01 +01:00
PConfig :: delete ( $uid , $family , $key );
2015-11-12 16:42:27 +01:00
}
2015-11-11 23:39:14 +01:00
}
}
2015-11-12 16:42:27 +01:00
2017-11-07 03:22:52 +01:00
Config :: set ( 'system' , 'maintenance' , 0 );
2015-11-12 16:42:27 +01:00
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2015-11-11 23:39:14 +01:00
}
2016-09-26 21:35:01 +02:00
2017-12-22 22:31:32 +01:00
function update_1203 () {
2016-09-26 21:35:01 +02:00
$r = q ( " UPDATE `user` SET `account-type` = %d WHERE `page-flags` IN (%d, %d) " ,
2018-07-28 01:25:57 +02:00
DBA :: escape ( Contact :: ACCOUNT_TYPE_COMMUNITY ), DBA :: escape ( Contact :: PAGE_COMMUNITY ), DBA :: escape ( Contact :: PAGE_PRVGROUP ));
2016-10-09 09:01:19 +02:00
}
2018-01-21 04:37:13 +01:00
function update_1244 () {
// Sets legacy_password for all legacy hashes
2018-07-20 14:19:26 +02:00
DBA :: update ( 'user' , [ 'legacy_password' => true ], [ 'SUBSTR(password, 1, 4) != "$2y$"' ]);
2018-01-21 04:37:13 +01:00
// All legacy hashes are re-hashed using the new secure hashing function
2018-07-20 14:19:26 +02:00
$stmt = DBA :: select ( 'user' , [ 'uid' , 'password' ], [ 'legacy_password' => true ]);
while ( $user = DBA :: fetch ( $stmt )) {
DBA :: update ( 'user' , [ 'password' => User :: hashPassword ( $user [ 'password' ])], [ 'uid' => $user [ 'uid' ]]);
2018-01-21 04:37:13 +01:00
}
// Logged in users are forcibly logged out
2018-07-20 14:19:26 +02:00
DBA :: delete ( 'session' , [ '1 = 1' ]);
2018-01-21 04:37:13 +01:00
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-01-21 04:37:13 +01:00
}
2018-01-22 23:58:03 +01:00
function update_1245 () {
$rino = Config :: get ( 'system' , 'rino_encrypt' );
if ( ! $rino ) {
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-01-22 23:58:03 +01:00
}
Config :: set ( 'system' , 'rino_encrypt' , 1 );
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-01-22 23:58:03 +01:00
}
2018-01-24 00:57:51 +01:00
function update_1247 () {
// Removing hooks with the old name
2018-07-20 14:19:26 +02:00
DBA :: e ( " DELETE FROM `hook`
2018-01-24 00:57:51 +01:00
WHERE `hook` LIKE 'plugin_%' " );
// Make sure we install the new renamed ones
Addon :: reload ();
}
2018-05-08 19:50:06 +02:00
function update_1260 () {
Config :: set ( 'system' , 'maintenance' , 1 );
2018-07-21 14:25:11 +02:00
Config :: set ( 'system' , 'maintenance_reason' , L10n :: t ( '%s: Updating author-id and owner-id in item and thread table. ' , DateTimeFormat :: utcNow () . ' ' . date ( 'e' )));
2018-05-08 19:50:06 +02:00
2018-07-20 14:19:26 +02:00
$items = DBA :: p ( " SELECT `id`, `owner-link`, `owner-name`, `owner-avatar`, `network` FROM `item`
2018-05-08 19:50:06 +02:00
WHERE `owner-id` = 0 AND `owner-link` != '' " );
2018-07-20 14:19:26 +02:00
while ( $item = DBA :: fetch ( $items )) {
2018-05-08 19:50:06 +02:00
$contact = [ 'url' => $item [ 'owner-link' ], 'name' => $item [ 'owner-name' ],
2018-05-09 09:09:47 +02:00
'photo' => $item [ 'owner-avatar' ], 'network' => $item [ 'network' ]];
2018-05-08 19:50:06 +02:00
$cid = Contact :: getIdForURL ( $item [ 'owner-link' ], 0 , false , $contact );
if ( empty ( $cid )) {
continue ;
}
Item :: update ([ 'owner-id' => $cid ], [ 'id' => $item [ 'id' ]]);
}
2018-07-20 14:19:26 +02:00
DBA :: close ( $items );
2018-05-08 19:50:06 +02:00
2018-07-20 14:19:26 +02:00
DBA :: e ( " UPDATE `thread` INNER JOIN `item` ON `thread`.`iid` = `item`.`id`
2018-05-08 19:50:06 +02:00
SET `thread` . `owner-id` = `item` . `owner-id` WHERE `thread` . `owner-id` = 0 " );
2018-07-20 14:19:26 +02:00
$items = DBA :: p ( " SELECT `id`, `author-link`, `author-name`, `author-avatar`, `network` FROM `item`
2018-05-08 19:50:06 +02:00
WHERE `author-id` = 0 AND `author-link` != '' " );
2018-07-20 14:19:26 +02:00
while ( $item = DBA :: fetch ( $items )) {
2018-05-08 19:50:06 +02:00
$contact = [ 'url' => $item [ 'author-link' ], 'name' => $item [ 'author-name' ],
2018-05-09 09:09:47 +02:00
'photo' => $item [ 'author-avatar' ], 'network' => $item [ 'network' ]];
2018-05-08 19:50:06 +02:00
$cid = Contact :: getIdForURL ( $item [ 'author-link' ], 0 , false , $contact );
if ( empty ( $cid )) {
continue ;
}
Item :: update ([ 'author-id' => $cid ], [ 'id' => $item [ 'id' ]]);
}
2018-07-20 14:19:26 +02:00
DBA :: close ( $items );
2018-05-08 19:50:06 +02:00
2018-07-20 14:19:26 +02:00
DBA :: e ( " UPDATE `thread` INNER JOIN `item` ON `thread`.`iid` = `item`.`id`
2018-05-08 19:50:06 +02:00
SET `thread` . `author-id` = `item` . `author-id` WHERE `thread` . `author-id` = 0 " );
Config :: set ( 'system' , 'maintenance' , 0 );
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-05-08 19:50:06 +02:00
}
2018-05-10 12:41:32 +02:00
function update_1261 () {
// This fixes the results of an issue in the develop branch of 2018-05.
2018-07-20 14:19:26 +02:00
DBA :: update ( 'contact' , [ 'blocked' => false , 'pending' => false ], [ 'uid' => 0 , 'blocked' => true , 'pending' => true ]);
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-05-10 12:41:32 +02:00
}
2018-07-19 15:52:05 +02:00
function update_1278 () {
Config :: set ( 'system' , 'maintenance' , 1 );
2018-07-21 14:25:11 +02:00
Config :: set ( 'system' , 'maintenance_reason' , L10n :: t ( '%s: Updating post-type.' , DateTimeFormat :: utcNow () . ' ' . date ( 'e' )));
2018-07-19 15:52:05 +02:00
Item :: update ([ 'post-type' => Item :: PT_PAGE ], [ 'bookmark' => true ]);
Item :: update ([ 'post-type' => Item :: PT_PERSONAL_NOTE ], [ 'type' => 'note' ]);
Config :: set ( 'system' , 'maintenance' , 0 );
2018-10-14 13:19:37 +02:00
return Update :: SUCCESS ;
2018-07-19 15:52:05 +02:00
}
2018-10-17 20:34:24 +02:00
function update_1288 () {
// Updates missing `uri-id` values
DBA :: e ( " UPDATE `item-activity` INNER JOIN `item` ON `item`.`iaid` = `item-activity`.`id` SET `item-activity`.`uri-id` = `item`.`uri-id` WHERE `item-activity`.`uri-id` IS NULL OR `item-activity`.`uri-id` = 0 " );
DBA :: e ( " UPDATE `item-content` INNER JOIN `item` ON `item`.`icid` = `item-content`.`id` SET `item-content`.`uri-id` = `item`.`uri-id` WHERE `item-content`.`uri-id` IS NULL OR `item-content`.`uri-id` = 0 " );
2018-10-29 10:16:07 +01:00
return Update :: SUCCESS ;
2018-10-17 20:34:24 +02:00
}
2018-12-18 17:53:00 +01:00
// Post-update script of PR 5751
2018-12-20 11:49:58 +01:00
function update_1293 ()
{
2018-12-18 17:53:00 +01:00
$allGenders = DBA :: select ( 'contact' , [ 'id' , 'gender' ]);
$allLangs = L10n :: getAvailableLanguages ();
$success = 0 ;
$fail = 0 ;
2018-12-18 18:00:35 +01:00
foreach ( $allGenders as $key => $gender ) {
foreach ( $allLangs as $key => $lang ) {
2018-12-18 17:53:00 +01:00
$a = new \stdClass ();
$a -> strings = [];
// First we get the the localizations
if ( file_exists ( " view/lang/ $lang /strings.php " )) {
include " view/lang/ $lang /strings.php " ;
}
if ( file_exists ( " addon/morechoice/lang/ $lang /strings.php " )) {
include " addon/morechoice/lang/ $lang /strings.php " ;
}
$localizedStrings = $a -> strings ;
unset ( $a );
$key = array_search ( $gender [ 'gender' ], $localizedStrings );
if ( $key !== false ) {
break ;
}
// defaulting to empty string
$key = '' ;
}
DBA :: update ( 'contact' , [ 'gender' => $key ], [ 'id' => $gender [ 'id' ]]);
logger :: log ( 'Updated contact ' . $gender [ 'id' ] . ' to gender ' . $key . ' (was: ' . $gender [ 'gender' ] . ')' );
if ( $key == '' ) {
$fail ++ ;
} else {
$success ++ ;
}
}
Logger :: log ( " Gender fix completed. Success: $success . Fail: $fail " );
return Update :: SUCCESS ;
}