Merge pull request #12910 from annando/delete-blocked

Blocked servers can now be deleted
This commit is contained in:
Hypolite Petovan 2023-03-18 18:10:06 -04:00 committed by GitHub
commit 34b575233a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 3 deletions

View file

@ -23,6 +23,7 @@ namespace Friendica\Worker;
use Friendica\Core\Logger; use Friendica\Core\Logger;
use Friendica\Database\DBA; use Friendica\Database\DBA;
use Friendica\DI;
use Friendica\Model\GServer; use Friendica\Model\GServer;
use Friendica\Util\Network; use Friendica\Util\Network;
@ -33,11 +34,14 @@ class UpdateBlockedServers
*/ */
public static function execute() public static function execute()
{ {
Logger::debug('Update blocked servers - start'); Logger::info('Update blocked servers - start');
$gservers = DBA::select('gserver', ['id', 'url', 'blocked']); $gservers = DBA::select('gserver', ['id', 'url', 'blocked']);
$changed = 0;
$unchanged = 0;
while ($gserver = DBA::fetch($gservers)) { while ($gserver = DBA::fetch($gservers)) {
$blocked = Network::isUrlBlocked($gserver['url']); $blocked = Network::isUrlBlocked($gserver['url']);
if (!is_null($gserver['blocked']) && ($blocked == $gserver['blocked'])) { if (!is_null($gserver['blocked']) && ($blocked == $gserver['blocked'])) {
$unchanged++;
continue; continue;
} }
@ -46,8 +50,15 @@ class UpdateBlockedServers
} else { } else {
GServer::setUnblockedById($gserver['id']); GServer::setUnblockedById($gserver['id']);
} }
$changed++;
} }
DBA::close($gservers); DBA::close($gservers);
Logger::debug('Update blocked servers - done'); Logger::info('Update blocked servers - done', ['changed' => $changed, 'unchanged' => $unchanged]);
if (DI::config()->get('system', 'delete-blocked-servers')) {
Logger::info('Delete blocked servers - start');
$ret = DBA::delete('gserver', ["`blocked` AND NOT EXISTS(SELECT `gsid` FROM `inbox-status` WHERE `gsid` = `gserver`.`id`) AND NOT EXISTS(SELECT `gsid` FROM `contact` WHERE gsid= `gserver`.`id`) AND NOT EXISTS(SELECT `gsid` FROM `apcontact` WHERE `gsid` = `gserver`.`id`) AND NOT EXISTS(SELECT `gsid` FROM `delivery-queue` WHERE `gsid` = `gserver`.`id`) AND NOT EXISTS(SELECT `gsid` FROM `diaspora-contact` WHERE `gsid` = `gserver`.`id`) AND NOT EXISTS(SELECT `gserver-id` FROM `gserver-tag` WHERE `gserver-id` = `gserver`.`id`)"]);
Logger::info('Delete blocked servers - done', ['ret' => $ret, 'rows' => DBA::affectedRows()]);
}
} }
} }

View file

@ -237,6 +237,10 @@ return [
// Periodically delete waiting database processes. // Periodically delete waiting database processes.
'delete_sleeping_processes' => false, 'delete_sleeping_processes' => false,
// delete-blocked-servers (Boolean)
// Delete blocked servers if there are no foreign key violations.
'delete-blocked-servers' => false,
// dice_profiler_threshold (Float) // dice_profiler_threshold (Float)
// For profiling Dice class creation (0 = disabled, >0 = seconds threshold for profiling) // For profiling Dice class creation (0 = disabled, >0 = seconds threshold for profiling)
'dice_profiler_threshold' => 0.5, 'dice_profiler_threshold' => 0.5,