Merge pull request #7543 from annando/queue-failed
Delivery count now counts the failed delivery attempts as well
This commit is contained in:
commit
f775fedc4a
8 changed files with 49 additions and 11 deletions
19
database.sql
19
database.sql
|
@ -1,9 +1,23 @@
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
-- Friendica 2019.09-dev (Dalmatian Bellflower)
|
-- Friendica 2019.09-rc (Dalmatian Bellflower)
|
||||||
-- DB_UPDATE_VERSION 1319
|
-- DB_UPDATE_VERSION 1321
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE 2fa_app_specific_password
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `2fa_app_specific_password` (
|
||||||
|
`id` mediumint unsigned NOT NULL auto_increment COMMENT 'Password ID for revocation',
|
||||||
|
`uid` mediumint unsigned NOT NULL COMMENT 'User ID',
|
||||||
|
`description` varchar(255) COMMENT 'Description of the usage of the password',
|
||||||
|
`hashed_password` varchar(255) NOT NULL COMMENT 'Hashed password',
|
||||||
|
`generated` datetime NOT NULL COMMENT 'Datetime the password was generated',
|
||||||
|
`last_used` datetime COMMENT 'Datetime the password was last used',
|
||||||
|
PRIMARY KEY(`id`),
|
||||||
|
INDEX `uid_description` (`uid`,`description`)
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Two-factor app-specific _password';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE 2fa_recovery_codes
|
-- TABLE 2fa_recovery_codes
|
||||||
--
|
--
|
||||||
|
@ -680,6 +694,7 @@ CREATE TABLE IF NOT EXISTS `item-delivery-data` (
|
||||||
`inform` mediumtext COMMENT 'Additional receivers of the linked item',
|
`inform` mediumtext COMMENT 'Additional receivers of the linked item',
|
||||||
`queue_count` mediumint NOT NULL DEFAULT 0 COMMENT 'Initial number of delivery recipients, used as item.delivery_queue_count',
|
`queue_count` mediumint NOT NULL DEFAULT 0 COMMENT 'Initial number of delivery recipients, used as item.delivery_queue_count',
|
||||||
`queue_done` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries, used as item.delivery_queue_done',
|
`queue_done` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries, used as item.delivery_queue_done',
|
||||||
|
`queue_failed` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of unsuccessful deliveries, used as item.delivery_queue_failed',
|
||||||
`activitypub` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via ActivityPub',
|
`activitypub` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via ActivityPub',
|
||||||
`dfrn` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via DFRN',
|
`dfrn` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via DFRN',
|
||||||
`legacy_dfrn` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via legacy DFRN',
|
`legacy_dfrn` mediumint NOT NULL DEFAULT 0 COMMENT 'Number of successful deliveries via legacy DFRN',
|
||||||
|
|
|
@ -1222,11 +1222,12 @@ class Worker
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defers the current worker entry
|
* Defers the current worker entry
|
||||||
|
* @return boolean had the entry been deferred?
|
||||||
*/
|
*/
|
||||||
public static function defer()
|
public static function defer()
|
||||||
{
|
{
|
||||||
if (empty(BaseObject::getApp()->queue)) {
|
if (empty(BaseObject::getApp()->queue)) {
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
$queue = BaseObject::getApp()->queue;
|
$queue = BaseObject::getApp()->queue;
|
||||||
|
@ -1241,7 +1242,7 @@ class Worker
|
||||||
|
|
||||||
if ($new_retrial > $max_level) {
|
if ($new_retrial > $max_level) {
|
||||||
Logger::info('The task exceeded the maximum retry count', ['id' => $id, 'max_level' => $max_level, 'retrial' => $new_retrial]);
|
Logger::info('The task exceeded the maximum retry count', ['id' => $id, 'max_level' => $max_level, 'retrial' => $new_retrial]);
|
||||||
return;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Calculate the delay until the next trial
|
// Calculate the delay until the next trial
|
||||||
|
@ -1263,6 +1264,8 @@ class Worker
|
||||||
DBA::update('workerqueue', $fields, ['id' => $id]);
|
DBA::update('workerqueue', $fields, ['id' => $id]);
|
||||||
self::$db_duration += (microtime(true) - $stamp);
|
self::$db_duration += (microtime(true) - $stamp);
|
||||||
self::$db_duration_write += (microtime(true) - $stamp);
|
self::$db_duration_write += (microtime(true) - $stamp);
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -59,7 +59,7 @@ class Item extends BaseObject
|
||||||
'event-id', 'event-created', 'event-edited', 'event-start', 'event-finish',
|
'event-id', 'event-created', 'event-edited', 'event-start', 'event-finish',
|
||||||
'event-summary', 'event-desc', 'event-location', 'event-type',
|
'event-summary', 'event-desc', 'event-location', 'event-type',
|
||||||
'event-nofinish', 'event-adjust', 'event-ignore', 'event-id',
|
'event-nofinish', 'event-adjust', 'event-ignore', 'event-id',
|
||||||
'delivery_queue_count', 'delivery_queue_done'
|
'delivery_queue_count', 'delivery_queue_done', 'delivery_queue_failed'
|
||||||
];
|
];
|
||||||
|
|
||||||
// Field list that is used to deliver items via the protocols
|
// Field list that is used to deliver items via the protocols
|
||||||
|
|
|
@ -21,6 +21,7 @@ class ItemDeliveryData
|
||||||
// New delivery fields with virtual field name in item fields
|
// New delivery fields with virtual field name in item fields
|
||||||
'queue_count' => 'delivery_queue_count',
|
'queue_count' => 'delivery_queue_count',
|
||||||
'queue_done' => 'delivery_queue_done',
|
'queue_done' => 'delivery_queue_done',
|
||||||
|
'queue_failed' => 'delivery_queue_failed',
|
||||||
];
|
];
|
||||||
|
|
||||||
const ACTIVITYPUB = 1;
|
const ACTIVITYPUB = 1;
|
||||||
|
@ -88,6 +89,20 @@ class ItemDeliveryData
|
||||||
return DBA::e('UPDATE `item-delivery-data` SET `queue_done` = `queue_done` + 1' . $sql . ' WHERE `iid` = ?', $item_id);
|
return DBA::e('UPDATE `item-delivery-data` SET `queue_done` = `queue_done` + 1' . $sql . ' WHERE `iid` = ?', $item_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Increments the queue_failed for the given item ID.
|
||||||
|
*
|
||||||
|
* Avoids racing condition between multiple delivery threads.
|
||||||
|
*
|
||||||
|
* @param integer $item_id
|
||||||
|
* @return bool
|
||||||
|
* @throws \Exception
|
||||||
|
*/
|
||||||
|
public static function incrementQueueFailed($item_id)
|
||||||
|
{
|
||||||
|
return DBA::e('UPDATE `item-delivery-data` SET `queue_failed` = `queue_failed` + 1 WHERE `iid` = ?', $item_id);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Insert a new item delivery data entry
|
* Insert a new item delivery data entry
|
||||||
*
|
*
|
||||||
|
|
|
@ -432,7 +432,7 @@ class Post extends BaseObject
|
||||||
'return' => ($a->cmd) ? bin2hex($a->cmd) : '',
|
'return' => ($a->cmd) ? bin2hex($a->cmd) : '',
|
||||||
'delivery' => [
|
'delivery' => [
|
||||||
'queue_count' => $item['delivery_queue_count'],
|
'queue_count' => $item['delivery_queue_count'],
|
||||||
'queue_done' => $item['delivery_queue_done'],
|
'queue_done' => $item['delivery_queue_done'] + $item['delivery_queue_failed'], /// @todo Possibly display it separately in the future
|
||||||
'notifier_pending' => L10n::t('Notifier task is pending'),
|
'notifier_pending' => L10n::t('Notifier task is pending'),
|
||||||
'delivery_pending' => L10n::t('Delivery to remote servers is pending'),
|
'delivery_pending' => L10n::t('Delivery to remote servers is pending'),
|
||||||
'delivery_underway' => L10n::t('Delivery to remote servers is underway'),
|
'delivery_underway' => L10n::t('Delivery to remote servers is underway'),
|
||||||
|
|
|
@ -54,8 +54,8 @@ class APDelivery extends BaseObject
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!$success) {
|
if (!$success && !Worker::defer() && in_array($cmd, [Delivery::POST])) {
|
||||||
Worker::defer();
|
ItemDeliveryData::incrementQueueFailed($target_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -327,7 +327,9 @@ class Delivery extends BaseObject
|
||||||
Model\Contact::markForArchival($contact);
|
Model\Contact::markForArchival($contact);
|
||||||
|
|
||||||
Logger::info('Delivery failed: defer message', ['id' => defaults($target_item, 'guid', $target_item['id'])]);
|
Logger::info('Delivery failed: defer message', ['id' => defaults($target_item, 'guid', $target_item['id'])]);
|
||||||
Worker::defer();
|
if (!Worker::defer() && in_array($cmd, [Delivery::POST, Delivery::POKE])) {
|
||||||
|
Model\ItemDeliveryData::incrementQueueFailed($target_item['id']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -412,7 +414,9 @@ class Delivery extends BaseObject
|
||||||
if (empty($contact['contact-type']) || ($contact['contact-type'] != Model\Contact::TYPE_RELAY)) {
|
if (empty($contact['contact-type']) || ($contact['contact-type'] != Model\Contact::TYPE_RELAY)) {
|
||||||
Logger::info('Delivery failed: defer message', ['id' => defaults($target_item, 'guid', $target_item['id'])]);
|
Logger::info('Delivery failed: defer message', ['id' => defaults($target_item, 'guid', $target_item['id'])]);
|
||||||
// defer message for redelivery
|
// defer message for redelivery
|
||||||
Worker::defer();
|
if (!Worker::defer() && in_array($cmd, [Delivery::POST, Delivery::POKE])) {
|
||||||
|
Model\ItemDeliveryData::incrementQueueFailed($target_item['id'], Model\ItemDeliveryData::DIASPORA);
|
||||||
|
}
|
||||||
} elseif (in_array($cmd, [Delivery::POST, Delivery::POKE])) {
|
} elseif (in_array($cmd, [Delivery::POST, Delivery::POKE])) {
|
||||||
Model\ItemDeliveryData::incrementQueueDone($target_item['id'], Model\ItemDeliveryData::DIASPORA);
|
Model\ItemDeliveryData::incrementQueueDone($target_item['id'], Model\ItemDeliveryData::DIASPORA);
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
|
|
||||||
if (!defined('DB_UPDATE_VERSION')) {
|
if (!defined('DB_UPDATE_VERSION')) {
|
||||||
define('DB_UPDATE_VERSION', 1320);
|
define('DB_UPDATE_VERSION', 1321);
|
||||||
}
|
}
|
||||||
|
|
||||||
return [
|
return [
|
||||||
|
@ -763,6 +763,7 @@ return [
|
||||||
"inform" => ["type" => "mediumtext", "comment" => "Additional receivers of the linked item"],
|
"inform" => ["type" => "mediumtext", "comment" => "Additional receivers of the linked item"],
|
||||||
"queue_count" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Initial number of delivery recipients, used as item.delivery_queue_count"],
|
"queue_count" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Initial number of delivery recipients, used as item.delivery_queue_count"],
|
||||||
"queue_done" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries, used as item.delivery_queue_done"],
|
"queue_done" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries, used as item.delivery_queue_done"],
|
||||||
|
"queue_failed" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of unsuccessful deliveries, used as item.delivery_queue_failed"],
|
||||||
"activitypub" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via ActivityPub"],
|
"activitypub" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via ActivityPub"],
|
||||||
"dfrn" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via DFRN"],
|
"dfrn" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via DFRN"],
|
||||||
"legacy_dfrn" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via legacy DFRN"],
|
"legacy_dfrn" => ["type" => "mediumint", "not null" => "1", "default" => "0", "comment" => "Number of successful deliveries via legacy DFRN"],
|
||||||
|
|
Loading…
Reference in a new issue