From 6c606b5c3070272229da5ac1d42cff883aab0824 Mon Sep 17 00:00:00 2001 From: octospacc Date: Sun, 9 Jul 2023 21:39:15 +0200 Subject: [PATCH] Initial Mastodon and any-platform support --- ModWinDog/Mods.py | 35 +++++++++++++++++++++++-------- WinDog.py | 52 ++++++++++++++++++++++++++++++++++++++++++----- requirements.txt | 7 +++++++ 3 files changed, 80 insertions(+), 14 deletions(-) diff --git a/ModWinDog/Mods.py b/ModWinDog/Mods.py index bfd61fb..5e011ab 100644 --- a/ModWinDog/Mods.py +++ b/ModWinDog/Mods.py @@ -37,13 +37,17 @@ def multifun(update:Update, context:CallbackContext) -> None: Text = CharEscape(choice(Locale.__(f'{Key}.empty')), 'MARKDOWN_SPEECH') update.message.reply_markdown_v2(Text, reply_to_message_id=ReplyToMsg) -def cStart(update:Update, context:CallbackContext) -> None: - Cmd = HandleCmd(update) - if not Cmd: return - user = update.effective_user - update.message.reply_markdown_v2('Hi\!', - #CharEscape(choice(Locale.__('start')).format(CharEscape(user.mention_markdown_v2(), 'MARKDOWN')), 'MARKDOWN'), - reply_to_message_id=update.message.message_id) +def cStart(Context, Data=None) -> None: + SendMsg(Context, {"Text": "Hi stupid :3"}) + +#def cStart(update:Update, context:CallbackContext) -> None: +# Cmd = HandleCmd(update) +# if not Cmd: return +# user = update.effective_user +# update.message.reply_markdown_v2(#'Hi\!', +# #CharEscape(choice(Locale.__('start')).format(CharEscape(user.mention_markdown_v2(), 'MARKDOWN')), 'MARKDOWN'), +# CharEscape(choice(Locale.__('start')), '.!').format(user.mention_markdown_v2()), +# reply_to_message_id=update.message.message_id) def cHelp(update:Update, context:CallbackContext) -> None: Cmd = HandleCmd(update) @@ -52,11 +56,24 @@ def cHelp(update:Update, context:CallbackContext) -> None: CharEscape(choice(Locale.__('help')), 'MARKDOWN_SPEECH'), reply_to_message_id=update.message.message_id) -def cConfig(update:Update, context:CallbackContext) -> None: +def cSource(update:Update, context:CallbackContext) -> None: Cmd = HandleCmd(update) if not Cmd: return -def cEcho(update:Update, context:CallbackContext) -> None: +def cConfig(update:Update, context:CallbackContext) -> None: + Cmd = HandleCmd(update) + if not Cmd: return + # ... area: eu, us, ... + # ... language: en, it, ... + # ... userdata: import, export, delete + +def cEcho(Context, Data=None) -> None: + if Data.Body: + SendMsg(Context, {"Text": Data.Body}) + else: + SendMsg(Context, {"Text": choice(Locale.__('echo.empty'))}) + +def cEcho2(update:Update, context:CallbackContext) -> None: Cmd = HandleCmd(update) if not Cmd: return Msg = update.message.text diff --git a/WinDog.py b/WinDog.py index 8e7cf24..7ed269d 100755 --- a/WinDog.py +++ b/WinDog.py @@ -10,6 +10,8 @@ from os.path import isfile from random import choice, randint from types import SimpleNamespace #from traceback import format_exc as TraceText +import mastodon, telegram +from bs4 import BeautifulSoup from telegram import Update, ForceReply, Bot from telegram.utils.helpers import escape_markdown from telegram.ext import Updater, CommandHandler, MessageHandler, Filters, CallbackContext @@ -26,6 +28,11 @@ for Dir in ('Lib', 'Mod'): with open(File, 'r') as File: exec(File.read()) +Endpoints = { + "start": cStart, + "echo": cEcho, +} + def SetupLocale() -> None: global Locale for File in listdir('./Locale'): @@ -111,7 +118,8 @@ def ParseCmd(Msg) -> dict: def filters(update:Update, context:CallbackContext=None) -> None: if Debug and Dumper: - Text = update.message.text.replace('\n', '\\n') + Text = update.message.text + Text = (Text.replace('\n', '\\n') if Text else '') with open('Dump.txt', 'a') as File: File.write(f'[{time.ctime()}] [{int(time.time())}] [{update.message.chat.id}] [{update.message.message_id}] [{update.message.from_user.id}] {Text}\n') ''' @@ -162,8 +170,24 @@ def RandHexStr(Len:int) -> str: def HttpGet(Url:str): return urlopen(Request(Url, headers={"User-Agent": WebUserAgent})) -#def SendMsg(Data, context): -# pass +def SendMsg(Context, Data): + #Data: Text, Media, Files + if type(Context) == dict: + Event = Context['Event'] if 'Event' in Context else None + Manager = Context['Manager'] if 'Manager' in Context else None + else: + [Event, Manager] = [Context, Context] + if isinstance(Manager, mastodon.Mastodon): + Manager.status_post( + (Data['Text'] + '\n\n@' + Event['account']['acct']), + in_reply_to_id=Event['status']['id'], + visibility=('direct' if Event['status']['visibility'] == 'direct' else 'unlisted') + ) + elif isinstance(Manager, telegram.Update): + Event.message.reply_markdown_v2( + Data['Text'], + reply_to_message_id=Event.message.message_id + ) def Main() -> None: SetupDb() @@ -177,7 +201,8 @@ def Main() -> None: dispatcher.add_handler(CommandHandler('start', cStart)) dispatcher.add_handler(CommandHandler('config', cConfig)) dispatcher.add_handler(CommandHandler('help', cHelp)) - dispatcher.add_handler(CommandHandler('echo', cEcho)) + dispatcher.add_handler(CommandHandler('source', cSource)) + dispatcher.add_handler(CommandHandler('echo', cEcho2)) dispatcher.add_handler(CommandHandler('ping', cPing)) #dispatcher.add_handler(CommandHandler('time', cTime)) dispatcher.add_handler(CommandHandler('hash', cHash)) @@ -197,7 +222,24 @@ def Main() -> None: print('Starting WinDog...') updater.start_polling() - updater.idle() + + #if MastodonUrl and MastodonToken: + Mastodon = mastodon.Mastodon(api_base_url=MastodonUrl, access_token=MastodonToken) + class mmyListener(mastodon.StreamListener): + def on_notification(self, Event): + if Event['type'] == 'mention': + Msg = BeautifulSoup(Event['status']['content'], 'html.parser').get_text(' ').strip().replace('\t', ' ') + if not Msg.split('@')[0]: + Msg = ' '.join('@'.join(Msg.split('@')[1:]).strip().split(' ')[1:]).strip() + if Msg[0] in '.!/': + Cmd = ParseCmd(Msg) + if Cmd.Name in Endpoints: + Endpoints[Cmd.Name]({"Event": Event, "Manager": Mastodon}, Cmd) + + Mastodon.stream_user(mmyListener()) + + while True: + time.sleep(9**9) if __name__ == '__main__': try: diff --git a/requirements.txt b/requirements.txt index 8d142fa..4f2b8c4 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,2 +1,9 @@ +# Some bot modules urllib3 + +# Mastodon support +Mastodon.py +beautifulsoup4 + +# Telegram support python-telegram-bot