Initial Mastodon and any-platform support

This commit is contained in:
octospacc 2023-07-09 21:39:15 +02:00
parent 4a538c66f3
commit 6c606b5c30
3 changed files with 80 additions and 14 deletions

View File

@ -37,13 +37,17 @@ def multifun(update:Update, context:CallbackContext) -> None:
Text = CharEscape(choice(Locale.__(f'{Key}.empty')), 'MARKDOWN_SPEECH') Text = CharEscape(choice(Locale.__(f'{Key}.empty')), 'MARKDOWN_SPEECH')
update.message.reply_markdown_v2(Text, reply_to_message_id=ReplyToMsg) update.message.reply_markdown_v2(Text, reply_to_message_id=ReplyToMsg)
def cStart(update:Update, context:CallbackContext) -> None: def cStart(Context, Data=None) -> None:
Cmd = HandleCmd(update) SendMsg(Context, {"Text": "Hi stupid :3"})
if not Cmd: return
user = update.effective_user #def cStart(update:Update, context:CallbackContext) -> None:
update.message.reply_markdown_v2('Hi\!', # Cmd = HandleCmd(update)
#CharEscape(choice(Locale.__('start')).format(CharEscape(user.mention_markdown_v2(), 'MARKDOWN')), 'MARKDOWN'), # if not Cmd: return
reply_to_message_id=update.message.message_id) # 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: def cHelp(update:Update, context:CallbackContext) -> None:
Cmd = HandleCmd(update) Cmd = HandleCmd(update)
@ -52,11 +56,24 @@ def cHelp(update:Update, context:CallbackContext) -> None:
CharEscape(choice(Locale.__('help')), 'MARKDOWN_SPEECH'), CharEscape(choice(Locale.__('help')), 'MARKDOWN_SPEECH'),
reply_to_message_id=update.message.message_id) 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) Cmd = HandleCmd(update)
if not Cmd: return 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) Cmd = HandleCmd(update)
if not Cmd: return if not Cmd: return
Msg = update.message.text Msg = update.message.text

View File

@ -10,6 +10,8 @@ from os.path import isfile
from random import choice, randint from random import choice, randint
from types import SimpleNamespace from types import SimpleNamespace
#from traceback import format_exc as TraceText #from traceback import format_exc as TraceText
import mastodon, telegram
from bs4 import BeautifulSoup
from telegram import Update, ForceReply, Bot from telegram import Update, ForceReply, Bot
from telegram.utils.helpers import escape_markdown from telegram.utils.helpers import escape_markdown
from telegram.ext import Updater, CommandHandler, MessageHandler, Filters, CallbackContext from telegram.ext import Updater, CommandHandler, MessageHandler, Filters, CallbackContext
@ -26,6 +28,11 @@ for Dir in ('Lib', 'Mod'):
with open(File, 'r') as File: with open(File, 'r') as File:
exec(File.read()) exec(File.read())
Endpoints = {
"start": cStart,
"echo": cEcho,
}
def SetupLocale() -> None: def SetupLocale() -> None:
global Locale global Locale
for File in listdir('./Locale'): for File in listdir('./Locale'):
@ -111,7 +118,8 @@ def ParseCmd(Msg) -> dict:
def filters(update:Update, context:CallbackContext=None) -> None: def filters(update:Update, context:CallbackContext=None) -> None:
if Debug and Dumper: 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: 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') 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): def HttpGet(Url:str):
return urlopen(Request(Url, headers={"User-Agent": WebUserAgent})) return urlopen(Request(Url, headers={"User-Agent": WebUserAgent}))
#def SendMsg(Data, context): def SendMsg(Context, Data):
# pass #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: def Main() -> None:
SetupDb() SetupDb()
@ -177,7 +201,8 @@ def Main() -> None:
dispatcher.add_handler(CommandHandler('start', cStart)) dispatcher.add_handler(CommandHandler('start', cStart))
dispatcher.add_handler(CommandHandler('config', cConfig)) dispatcher.add_handler(CommandHandler('config', cConfig))
dispatcher.add_handler(CommandHandler('help', cHelp)) 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('ping', cPing))
#dispatcher.add_handler(CommandHandler('time', cTime)) #dispatcher.add_handler(CommandHandler('time', cTime))
dispatcher.add_handler(CommandHandler('hash', cHash)) dispatcher.add_handler(CommandHandler('hash', cHash))
@ -197,7 +222,24 @@ def Main() -> None:
print('Starting WinDog...') print('Starting WinDog...')
updater.start_polling() 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__': if __name__ == '__main__':
try: try:

View File

@ -1,2 +1,9 @@
# Some bot modules
urllib3 urllib3
# Mastodon support
Mastodon.py
beautifulsoup4
# Telegram support
python-telegram-bot python-telegram-bot