Skip to content

Commit

Permalink
Update InstanceService, improve unlisted/banned network post filtering
Browse files Browse the repository at this point in the history
  • Loading branch information
dansup committed Jan 15, 2023
1 parent 87cff47 commit a0da6ec
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 3 deletions.
16 changes: 15 additions & 1 deletion app/Services/InstanceService.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,14 @@

class InstanceService
{
const CACHE_KEY_BY_DOMAIN = 'pf:services:instance:by_domain:';
const CACHE_KEY_BANNED_DOMAINS = 'instances:banned:domains';
const CACHE_KEY_UNLISTED_DOMAINS = 'instances:unlisted:domains';
const CACHE_KEY_NSFW_DOMAINS = 'instances:auto_cw:domains';

public static function getByDomain($domain)
{
return Cache::remember('pf:services:instance:by_domain:'.$domain, 3600, function() use($domain) {
return Cache::remember(self::CACHE_KEY_BY_DOMAIN.$domain, 3600, function() use($domain) {
return Instance::whereDomain($domain)->first();
});
}
Expand Down Expand Up @@ -50,4 +51,17 @@ public static function software($domain)
return $instance->software;
});
}

public static function refresh()
{
Cache::forget(self::CACHE_KEY_BANNED_DOMAINS);
Cache::forget(self::CACHE_KEY_UNLISTED_DOMAINS);
Cache::forget(self::CACHE_KEY_NSFW_DOMAINS);

self::getBannedDomains();
self::getUnlistedDomains();
self::getNsfwDomains();

return true;
}
}
13 changes: 12 additions & 1 deletion app/Services/NetworkTimelineService.php
Original file line number Diff line number Diff line change
Expand Up @@ -77,6 +77,11 @@ public static function warmCache($force = false, $limit = 100)
if(self::count() == 0 || $force == true) {
$hideNsfw = config('instance.hide_nsfw_on_public_feeds');
Redis::del(self::CACHE_KEY);
$filteredDomains = collect(InstanceService::getBannedDomains())
->merge(InstanceService::getUnlistedDomains())
->unique()
->values()
->toArray();
$ids = Status::whereNotNull('uri')
->whereScope('public')
->when($hideNsfw, function($q, $hideNsfw) {
Expand All @@ -88,7 +93,13 @@ public static function warmCache($force = false, $limit = 100)
->where('created_at', '>', now()->subHours(config('instance.timeline.network.max_hours_old')))
->orderByDesc('created_at')
->limit($limit)
->pluck('id');
->pluck('uri', 'id');
$ids = $ids->filter(function($k, $v) use($filteredDomains) {
$domain = parse_url($k, PHP_URL_HOST);
return !in_array($domain, $filteredDomains);
})->map(function($k, $v) {
return $v;
})->flatten();
foreach($ids as $id) {
self::add($id);
}
Expand Down
9 changes: 8 additions & 1 deletion app/Util/ActivityPub/Helpers.php
Original file line number Diff line number Diff line change
Expand Up @@ -510,7 +510,14 @@ public static function storeStatus($url, $profile, $activity)
$status->created_at->gt(now()->subHours(config('instance.timeline.network.max_hours_old'))) &&
(config('instance.hide_nsfw_on_public_feeds') == true ? $status->is_nsfw == false : true)
) {
NetworkTimelineService::add($status->id);
$filteredDomains = collect(InstanceService::getBannedDomains())
->merge(InstanceService::getUnlistedDomains())
->unique()
->values()
->toArray();
if(!in_array($urlDomain, $filteredDomains)) {
NetworkTimelineService::add($status->id);
}
}

IncrementPostCount::dispatch($pid)->onQueue('low');
Expand Down

0 comments on commit a0da6ec

Please sign in to comment.