mirror of
https://codeberg.org/catask-org/catask.git
synced 2025-04-18 21:03:41 -05:00
revamp some fediverse crosspost logic and add bluesky crosspost
This commit is contained in:
parent
dd27fc8e09
commit
76b5c58b50
1 changed files with 76 additions and 12 deletions
88
functions.py
88
functions.py
|
@ -7,7 +7,6 @@ from pathlib import Path
|
|||
from mistune import HTMLRenderer, escape
|
||||
from PIL import Image
|
||||
from psycopg.rows import dict_row
|
||||
from mastodon import Mastodon
|
||||
import traceback
|
||||
import base64
|
||||
import time
|
||||
|
@ -313,7 +312,29 @@ def addAnswer(question_id: int, answer: str, cw: str) -> dict:
|
|||
|
||||
return jsonify({'message': _('Answer added successfully!')}), 201
|
||||
|
||||
if cfg['crosspost']['fediverse']['enabled']:
|
||||
from mastodon import Mastodon
|
||||
|
||||
app.logger.debug("Initializing Mastodon.py client...")
|
||||
|
||||
fedi_client = Mastodon(
|
||||
client_id = cfg['crosspost']['fediverse']['client']['id'],
|
||||
client_secret = cfg['crosspost']['fediverse']['client']['secret'],
|
||||
api_base_url = 'https://' + cfg['crosspost']['fediverse']['instance'],
|
||||
access_token = cfg['crosspost']['fediverse']['token']
|
||||
)
|
||||
|
||||
if cfg['crosspost']['bluesky']['enabled']:
|
||||
from atproto import Client, client_utils
|
||||
|
||||
app.logger.debug("[postOnBluesky] Initializing ATProto client...")
|
||||
|
||||
bsky_client = Client()
|
||||
bsky_client.login(cfg['crosspost']['bluesky']['handle'], cfg['crosspost']['bluesky']['appPassword'])
|
||||
|
||||
def postOnFediverse(question_id: int, answer: str, cw: str) -> None:
|
||||
global fedi_client
|
||||
|
||||
# reloading config file
|
||||
cfg = loadJSON(const.configFile)
|
||||
|
||||
|
@ -325,23 +346,66 @@ def postOnFediverse(question_id: int, answer: str, cw: str) -> None:
|
|||
cursor.execute("SELECT id, content FROM questions WHERE id=%s", (question_id,))
|
||||
question = cursor.fetchone()
|
||||
|
||||
app.logger.debug("[postOnFediverse] Initializing Mastodon client...")
|
||||
warning = f"{cfg['crosspost']['fediverse']['cw']}"
|
||||
|
||||
if question.get('cw') and not cw:
|
||||
warning += f", {question['cw']}"
|
||||
|
||||
elif question.get('cw') and cw and (question['cw'] != cw):
|
||||
warning += f", {question['cw']}, {cw}"
|
||||
|
||||
elif (question.get('cw') and cw) and question['cw'] == cw:
|
||||
warning += f", {cw}"
|
||||
|
||||
elif cw and not question.get('cw'):
|
||||
warning += f", {cw}"
|
||||
|
||||
client = Mastodon(
|
||||
client_id = cfg['crosspost']['fediverse']['client']['id'],
|
||||
client_secret = cfg['crosspost']['fediverse']['client']['secret'],
|
||||
api_base_url = 'https://' + cfg['crosspost']['fediverse']['instance'],
|
||||
access_token = cfg['crosspost']['fediverse']['token']
|
||||
)
|
||||
if cw:
|
||||
warning = f"{cfg['crosspost']['fediverse']['cw']}, {cw}"
|
||||
else:
|
||||
warning = cfg['crosspost']['fediverse']['cw']
|
||||
warning = ""
|
||||
|
||||
post_content = f"{question['content']} — {answer} {cfg['instance']['fullBaseUrl']}/q/{question['id']}/"
|
||||
client.status_post(post_content, visibility=cfg['crosspost']['fediverse']['visibility'], spoiler_text=warning)
|
||||
fedi_client.status_post(post_content, visibility=cfg['crosspost']['fediverse']['visibility'], spoiler_text=warning)
|
||||
|
||||
app.logger.debug(f"[postOnFediverse] Made Fediverse post: {post_content}")
|
||||
|
||||
def postOnBluesky(question_id: int, answer: str, cw: str) -> None:
|
||||
global bsky_client
|
||||
|
||||
# reloading config file
|
||||
cfg = loadJSON(const.configFile)
|
||||
|
||||
conn = connectToDb()
|
||||
cursor = conn.cursor()
|
||||
|
||||
app.logger.debug(f"[postOnBluesky] Grabbing question {question_id} from database...")
|
||||
|
||||
cursor.execute("SELECT id, content, cw FROM questions WHERE id=%s", (question_id,))
|
||||
question = cursor.fetchone()
|
||||
|
||||
if question.get('cw') and not cw:
|
||||
warning = f"[CW: {question['cw']}]\n\n"
|
||||
|
||||
elif question.get('cw') and cw and (question['cw'] != cw):
|
||||
warning = f"[CW: {question['cw']}, {cw}]\n\n"
|
||||
|
||||
elif question['cw'] == cw:
|
||||
warning = f"[CW: {cw}]\n\n"
|
||||
|
||||
elif cw and not question.get('cw'):
|
||||
warning = f"[CW: {cw}]\n\n"
|
||||
|
||||
else:
|
||||
warning = ""
|
||||
|
||||
# warning = f"{ '[CW:' if cw or question.get('cw') else '' }{ ' ' + question['cw'] if question.get('cw') else '' }{ ', ' + cw if cw else '' }{']\n\n' if cw or question.get('cw') else '' }"
|
||||
|
||||
text_builder = client_utils.TextBuilder()
|
||||
text_builder.text(f"{warning}{question['content']} — {answer} ")
|
||||
text_builder.link(f"{cfg['instance']['fullBaseUrl']}/q/{question['id']}/", f"{cfg['instance']['fullBaseUrl']}/q/{question['id']}/")
|
||||
bsky_client.send_post(text_builder)
|
||||
|
||||
app.logger.debug(f"[postOnBluesky] Made Bluesky post: {text_builder.build_text()}")
|
||||
|
||||
def ntfySend(cw, return_val, from_who, question) -> None:
|
||||
app.logger.debug("[CatAsk/functions/ntfySend] started ntfy flow")
|
||||
ntfy_cw = f" [CW: {cw}]" if cw else ""
|
||||
|
|
Loading…
Add table
Reference in a new issue