1
0
Fork 0
mirror of https://github.com/Lynnesbian/FediBooks/ synced 2024-11-16 21:08:57 +00:00
FediBooks/service.py

31 lines
814 B
Python
Raw Normal View History

#!/usr/bin/env python3
import MySQLdb
from multiprocessing import Pool
import json
2019-09-06 02:38:50 +00:00
import functions
cfg = json.load(open('config.json'))
2019-09-06 02:38:50 +00:00
print("Establishing DB connection")
db = MySQLdb.connect(
host = cfg['db_host'],
user=cfg['db_user'],
passwd=cfg['db_pass'],
db=cfg['db_name']
)
print("Cleaning up database")
# delete any fedi accounts we no longer need
2019-09-06 02:38:50 +00:00
cursor = db.cursor()
cursor.execute("DELETE FROM fedi_accounts WHERE handle NOT IN (SELECT fedi_id FROM bot_learned_accounts)")
2019-09-06 02:47:39 +00:00
2019-09-07 03:31:11 +00:00
print("Generating posts")
2019-09-10 01:50:55 +00:00
cursor.execute("SELECT handle FROM bots WHERE enabled = TRUE AND TIMESTAMPDIFF(MINUTE, last_post, CURRENT_TIMESTAMP()) > post_frequency")
2019-09-07 03:31:11 +00:00
bots = cursor.fetchall()
with Pool(8) as p:
2019-09-09 03:39:28 +00:00
p.map(functions.make_post, bots)
2019-09-07 03:31:11 +00:00
2019-09-06 02:47:39 +00:00
#TODO: other cron tasks should be done here, like updating profile pictures