From 58d46ff64060527bfe960fe1cbaf098bd51bb615 Mon Sep 17 00:00:00 2001 From: Tao Bojlen Date: Tue, 4 Sep 2018 19:52:12 +0200 Subject: [PATCH] add opt-in whitelist for small instances --- frontend/src/components/Sidebar.tsx | 4 +++- scraper/management/commands/scrape.py | 16 +++++++++++++--- whitelist.txt | 1 + 3 files changed, 17 insertions(+), 4 deletions(-) create mode 100644 whitelist.txt diff --git a/frontend/src/components/Sidebar.tsx b/frontend/src/components/Sidebar.tsx index a7b77ab..e44410f 100644 --- a/frontend/src/components/Sidebar.tsx +++ b/frontend/src/components/Sidebar.tsx @@ -238,7 +238,9 @@ class SidebarImpl extends React.Component { + Message @tao to opt in} /> ) } diff --git a/scraper/management/commands/scrape.py b/scraper/management/commands/scrape.py index 47f2e8c..29d5b79 100644 --- a/scraper/management/commands/scrape.py +++ b/scraper/management/commands/scrape.py @@ -7,12 +7,14 @@ import json import multiprocessing as mp import requests import time +import os from dateutil.parser import parse as datetime_parser from datetime import datetime, timedelta, timezone from functional import seq from django_bulk_update.helper import bulk_update from django.core.management.base import BaseCommand from django import db +from django.conf import settings from scraper.models import Instance, PeerRelationship from scraper.management.commands._util import require_lock, InvalidResponseException, get_key, log, validate_int, PersonalInstanceException @@ -29,10 +31,10 @@ from scraper.management.commands._util import require_lock, InvalidResponseExcep # TODO: use the /api/v1/server/followers and /api/v1/server/following endpoints in peertube instances -SEED = 'mastodon.social' +SEED = 'mastodon.ar.al' TIMEOUT = 20 # seconds NUM_THREADS = 16 # roughly 40MB each -PERSONAL_INSTANCE_THRESHOLD = 5 # instances with <= this many users won't be scraped +PERSONAL_INSTANCE_THRESHOLD = 5 # instances with < this many users won't be scraped STATUS_SCRAPE_LIMIT = 5000 @@ -42,6 +44,9 @@ class Command(BaseCommand): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.scraped_count = 0 + f = open(os.path.join(settings.BASE_DIR, '../whitelist.txt'), 'r') + self.whitelist = seq(f.readlines()).map(lambda i: i.lower().strip()).to_list() + f.close() @staticmethod def get_instance_info(instance_name: str): @@ -97,6 +102,7 @@ class Command(BaseCommand): # Continuing, so get url for next page min_id = earliest_status['id'] url = 'https://' + instance_name + '/api/v1/timelines/public?local=true&limit=1000&max_id=' + min_id + time.sleep(1) # Sleep to avoid overloading the instance mentions_seq = (seq(mentions) .filter(lambda m: not m['acct'].endswith(instance_name) and '@' in m['acct']) @@ -116,7 +122,11 @@ class Command(BaseCommand): # Check if this is a personal instance before continuing user_count = get_key(data, ['info', 'stats', 'user_count']) - if isinstance(user_count, int) and user_count < PERSONAL_INSTANCE_THRESHOLD: + print(self.whitelist) + print(instance.name) + if isinstance(user_count, int)\ + and user_count < PERSONAL_INSTANCE_THRESHOLD\ + and instance.name not in self.whitelist: raise PersonalInstanceException data['peers'] = self.get_instance_peers(instance.name) diff --git a/whitelist.txt b/whitelist.txt new file mode 100644 index 0000000..3d0b213 --- /dev/null +++ b/whitelist.txt @@ -0,0 +1 @@ +mastodon.social