Don't delete and recreate the rows over and over again

This commit is contained in:
Michael 2020-03-06 13:51:36 +00:00
parent bd77556b49
commit 9adf09be51
2 changed files with 7 additions and 2 deletions

View File

@ -1303,7 +1303,7 @@ class GContact
$gcid = $gcontact['id'];
if (!empty($followers)) {
// Clear the follower list, since it will be recreated in the next step
DBA::delete('gfollower', ['gcid' => $gcid]);
DBA::update('gfollower', ['deleted' => true], ['gcid' => $gcid]);
}
$contacts = array_unique(array_merge($followers, $followings));
@ -1317,12 +1317,16 @@ class GContact
$fields = ['gcid' => $gcontact['id'], 'follower-gcid' => $gcid];
}
Logger::info('Set relation between contacts', $fields);
DBA::update('gfollower', $fields, $fields, true);
DBA::update('gfollower', ['deleted' => false], $fields, true);
continue;
}
Logger::info('Discover new AP contact', ['url' => $contact]);
Worker::add(PRIORITY_LOW, 'UpdateGContact', $contact);
}
if (!empty($followers)) {
// Delete all followers that aren't undeleted
DBA::delete('gfollower', ['gcid' => $gcid, 'deleted' => true]);
}
Logger::info('AP contacts discovery finished', ['url' => $url]);
return;
}

View File

@ -495,6 +495,7 @@ return [
"fields" => [
"gcid" => ["type" => "int unsigned", "not null" => "1", "default" => "0", "primary" => "1", "relation" => ["gcontact" => "id"], "comment" => "global contact"],
"follower-gcid" => ["type" => "int unsigned", "not null" => "1", "default" => "0", "primary" => "1", "relation" => ["gcontact" => "id"], "comment" => "global contact of the follower"],
"deleted" => ["type" => "boolean", "not null" => "1", "default" => "0", "comment" => "1 indicates that the connection has been deleted"],
],
"indexes" => [
"PRIMARY" => ["gcid", "follower-gcid"],