fedi-block-api/fetch_blocks.py

41 lines
2 KiB
Python
Raw Normal View History

from requests import get
from json import loads
import sqlite3
conn = sqlite3.connect("blocks.db")
c = conn.cursor()
with open("pleroma_instances.txt", "r") as f:
while blocker := f.readline().strip():
print(blocker)
c.execute(f"delete from blocks where blocker = '{blocker}'")
conn.commit()
try:
json = loads(get(f"https://{blocker}/nodeinfo/2.1.json").text)
for mrf in json["metadata"]["federation"]["mrf_simple"]:
for blocked in json["metadata"]["federation"]["mrf_simple"][mrf]:
c.execute(f"insert into blocks select '{blocker}', '{blocked}', '', '{mrf}'")
for blocked in json["metadata"]["federation"]["quarantined_instances"]:
c.execute(f"insert into blocks select '{blocker}', '{blocked}', '', 'quarantined_instances'")
conn.commit()
except:
pass
with open("mastodon_instances.txt", "r") as f:
while blocker := f.readline().strip():
print(blocker)
c.execute(f"delete from blocks where blocker = '{blocker}'")
conn.commit()
try:
json = loads(get(f"http://127.0.0.1:8069/{blocker}").text)
for blocked in json["reject"]:
c.execute(f"insert into blocks select '{blocker}', ifnull((select domain from instances where hash = '{blocked['hash']}'), '{blocked['hash']}'), '{blocked['reason']}', 'reject'")
for blocked in json["media_removal"]:
c.execute(f"insert into blocks select '{blocker}', ifnull((select domain from instances where hash = '{blocked['hash']}'), '{blocked['hash']}'), '{blocked['reason']}', 'media_removal'")
for blocked in json["federated_timeline_removal"]:
c.execute(f"insert into blocks select '{blocker}', ifnull((select domain from instances where hash = '{blocked['hash']}'), '{blocked['hash']}'), '{blocked['reason']}', 'federated_timeline_removal'")
conn.commit()
except:
pass
conn.close()