From f185f6fd3dde9a63feb735dd6dd87aaf278a6415 Mon Sep 17 00:00:00 2001 From: Michael Date: Mon, 9 Sep 2019 20:03:11 +0000 Subject: [PATCH 1/2] Pending contacts part 2: Fix contact deletion / added cron job for repairs --- mod/notifications.php | 13 ++++++++----- src/Worker/CronJobs.php | 10 ++++++++++ 2 files changed, 18 insertions(+), 5 deletions(-) diff --git a/mod/notifications.php b/mod/notifications.php index ed83de8ab2..ac642122c2 100644 --- a/mod/notifications.php +++ b/mod/notifications.php @@ -12,9 +12,11 @@ use Friendica\Core\L10n; use Friendica\Core\NotificationsManager; use Friendica\Core\Protocol; use Friendica\Core\Renderer; +use Friendica\Core\Logger; use Friendica\Core\System; use Friendica\Database\DBA; use Friendica\Module\Login; +use Friendica\Model\Contact; function notifications_post(App $a) { @@ -46,13 +48,14 @@ function notifications_post(App $a) if ($_POST['submit'] == L10n::t('Discard')) { DBA::delete('intro', ['id' => $intro_id]); - if (!$fid) { - // The check for blocked and pending is in case the friendship was already approved - // and we just want to get rid of the now pointless notification + // The check for pending is in case the friendship was already approved + // and we just want to get rid of the pending contact $condition = ['id' => $contact_id, 'uid' => local_user(), - 'self' => false, 'blocked' => true, 'pending' => true]; - DBA::delete('contact', $condition); + 'self' => false, 'pending' => true, 'rel' => Contact::FOLLOWER]; + if (DBA::exists('contact', $condition)) { + Contact::remove($contact_id); + } } $a->internalRedirect('notifications/intros'); } diff --git a/src/Worker/CronJobs.php b/src/Worker/CronJobs.php index 3a2c330fe5..32f9b64aa4 100644 --- a/src/Worker/CronJobs.php +++ b/src/Worker/CronJobs.php @@ -23,6 +23,7 @@ use Friendica\Network\Probe; use Friendica\Protocol\PortableContact; use Friendica\Util\Network; use Friendica\Util\Proxy as ProxyUtils; +use Friendica\Util\Strings; class CronJobs { @@ -301,6 +302,15 @@ class CronJobs /// - remove sign entries without item /// - remove children when parent got lost /// - set contact-id in item when not present + + // Add intro entries for pending contacts + $pending_contacts = DBA::p("SELECT `uid`, `id`, `url`, `network`, `created` FROM `contact` + WHERE `pending` AND `rel` = ? AND NOT EXISTS (SELECT `id` FROM `intro` WHERE `contact-id` = `contact`.`id`)", 0); //Contact::FOLLOWER); + while ($contact = DBA::fetch($pending_contacts)) { + DBA::insert('intro', ['uid' => $contact['uid'], 'contact-id' => $contact['id'], 'blocked' => false, + 'hash' => Strings::getRandomHex(), 'datetime' => $contact['created']]); + } + DBA::close($pending_contacts); } /** From 323285216b695014f559782423929f957c03c4ce Mon Sep 17 00:00:00 2001 From: Michael Date: Mon, 9 Sep 2019 20:39:19 +0000 Subject: [PATCH 2/2] We have to check for "0" in "rel" as well --- mod/notifications.php | 2 +- src/Worker/CronJobs.php | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/mod/notifications.php b/mod/notifications.php index ac642122c2..3276e65491 100644 --- a/mod/notifications.php +++ b/mod/notifications.php @@ -52,7 +52,7 @@ function notifications_post(App $a) // The check for pending is in case the friendship was already approved // and we just want to get rid of the pending contact $condition = ['id' => $contact_id, 'uid' => local_user(), - 'self' => false, 'pending' => true, 'rel' => Contact::FOLLOWER]; + 'self' => false, 'pending' => true, 'rel' => [0, Contact::FOLLOWER]]; if (DBA::exists('contact', $condition)) { Contact::remove($contact_id); } diff --git a/src/Worker/CronJobs.php b/src/Worker/CronJobs.php index 32f9b64aa4..ba48971747 100644 --- a/src/Worker/CronJobs.php +++ b/src/Worker/CronJobs.php @@ -305,7 +305,7 @@ class CronJobs // Add intro entries for pending contacts $pending_contacts = DBA::p("SELECT `uid`, `id`, `url`, `network`, `created` FROM `contact` - WHERE `pending` AND `rel` = ? AND NOT EXISTS (SELECT `id` FROM `intro` WHERE `contact-id` = `contact`.`id`)", 0); //Contact::FOLLOWER); + WHERE `pending` AND `rel` IN (?, ?) AND NOT EXISTS (SELECT `id` FROM `intro` WHERE `contact-id` = `contact`.`id`)", 0, Contact::FOLLOWER); while ($contact = DBA::fetch($pending_contacts)) { DBA::insert('intro', ['uid' => $contact['uid'], 'contact-id' => $contact['id'], 'blocked' => false, 'hash' => Strings::getRandomHex(), 'datetime' => $contact['created']]);