mirror of
https://gitlab.com/octospacc/WinDog.git
synced 2025-01-05 12:27:09 +01:00
Initial Mastodon and any-platform support
This commit is contained in:
parent
4a538c66f3
commit
6c606b5c30
@ -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
|
||||||
|
52
WinDog.py
52
WinDog.py
@ -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:
|
||||||
|
@ -1,2 +1,9 @@
|
|||||||
|
# Some bot modules
|
||||||
urllib3
|
urllib3
|
||||||
|
|
||||||
|
# Mastodon support
|
||||||
|
Mastodon.py
|
||||||
|
beautifulsoup4
|
||||||
|
|
||||||
|
# Telegram support
|
||||||
python-telegram-bot
|
python-telegram-bot
|
||||||
|
Loading…
Reference in New Issue
Block a user