diff options
author | zotlabs <mike@macgirvin.com> | 2017-11-02 03:13:30 -0700 |
---|---|---|
committer | zotlabs <mike@macgirvin.com> | 2017-11-02 03:13:30 -0700 |
commit | 1b290f573acdd4f003b6ffcce6c0705ea461bd9d (patch) | |
tree | 262a1c0a418227784cfec6f9d40875edd9b9923c /include/network.php | |
parent | bdf50a824e6ee7f72532ba9b6e31c8730a8a497e (diff) | |
download | volse-hubzilla-1b290f573acdd4f003b6ffcce6c0705ea461bd9d.tar.gz volse-hubzilla-1b290f573acdd4f003b6ffcce6c0705ea461bd9d.tar.bz2 volse-hubzilla-1b290f573acdd4f003b6ffcce6c0705ea461bd9d.zip |
put deferred queue logic every place we create a delivery process (except for protocol 'friend requests' which aren't likely to swamp the delivery system). Remove it from the queue_delivery function which was too late to do anything.
Diffstat (limited to 'include/network.php')
-rw-r--r-- | include/network.php | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/include/network.php b/include/network.php index 2f29a70c4..73a6aeff2 100644 --- a/include/network.php +++ b/include/network.php @@ -1438,6 +1438,17 @@ function do_delivery($deliveries) { if(! (is_array($deliveries) && count($deliveries))) return; + + $x = q("select count(outq_hash) as total from outq where outq_delivered = 0"); + if(intval($x[0]['total']) > intval(get_config('system','force_queue_threshold',300))) { + logger('immediate delivery deferred.', LOGGER_DEBUG, LOG_INFO); + foreach($deliveries as $d) { + update_queue_item($d); + } + return; + } + + $interval = ((get_config('system','delivery_interval') !== false) ? intval(get_config('system','delivery_interval')) : 2 ); |