2018-08-18 18:43:47 +02:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
"""Telegram bot for fortunes-spam.
|
|
|
|
|
|
|
|
Build it with: docker build -t fortunes-spam-bot .
|
|
|
|
Run it with something like: docker run -ti --rm -e SPAMBOT_TOKEN=your-telegram-token fortunes-spam-bot
|
|
|
|
|
2025-01-02 10:59:01 +01:00
|
|
|
Copyright 2018-2025 Davide Alberani <da@mimante.net> Apache 2.0 license
|
2018-08-18 18:43:47 +02:00
|
|
|
"""
|
|
|
|
|
|
|
|
import os
|
|
|
|
import logging
|
|
|
|
import subprocess
|
2025-01-02 10:59:01 +01:00
|
|
|
from telegram import Update
|
|
|
|
from telegram.ext import Application, CommandHandler
|
2018-08-18 18:43:47 +02:00
|
|
|
|
|
|
|
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
|
|
|
level=logging.INFO)
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
2021-06-12 15:47:41 +02:00
|
|
|
EXTERNAL_VOL = '/fortunes'
|
2018-08-18 18:43:47 +02:00
|
|
|
|
|
|
|
def getSpam(section):
|
2021-06-12 15:47:41 +02:00
|
|
|
extPath = os.path.join(EXTERNAL_VOL, section)
|
|
|
|
if os.path.isfile(extPath):
|
|
|
|
section = extPath
|
2018-08-18 18:43:47 +02:00
|
|
|
cmd = ['fortune', '-o', section]
|
|
|
|
process = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
|
|
|
|
stdout, stderr = process.communicate()
|
|
|
|
try:
|
|
|
|
stdout = stdout.strip()
|
|
|
|
stdout = stdout.decode('utf8')
|
2025-01-02 10:59:01 +01:00
|
|
|
except Exception:
|
2018-08-18 18:43:47 +02:00
|
|
|
return 'uh-oh: something was wrong with the encoding of the can\'s label; try again'
|
|
|
|
if process.returncode != 0:
|
|
|
|
return 'something terrible is happening: exit code: %s, stderr: %s' % (
|
|
|
|
process.returncode, stderr.decode('utf8'))
|
|
|
|
if not stdout:
|
|
|
|
return 'sadness: the spam can was empty; try again'
|
|
|
|
return stdout
|
|
|
|
|
|
|
|
|
2025-01-02 10:59:01 +01:00
|
|
|
async def serve(section, update, context):
|
2018-08-18 18:43:47 +02:00
|
|
|
spam = getSpam(section)
|
2021-06-12 15:47:41 +02:00
|
|
|
logging.info('%s wants some spam; serving:\n%s' % (update.effective_user.username, spam))
|
2025-01-02 10:59:01 +01:00
|
|
|
await update.message.reply_text(spam)
|
2018-08-18 18:43:47 +02:00
|
|
|
|
|
|
|
|
2021-06-12 15:47:41 +02:00
|
|
|
def en(update, context):
|
|
|
|
return serve('spam-o', update, context)
|
2018-08-18 18:43:47 +02:00
|
|
|
|
|
|
|
|
2021-06-12 15:47:41 +02:00
|
|
|
def it(update, context):
|
|
|
|
return serve('spam-ita-o', update, context)
|
2018-08-18 18:43:47 +02:00
|
|
|
|
|
|
|
|
2025-01-02 10:59:01 +01:00
|
|
|
async def about(update, context):
|
2021-06-12 15:47:41 +02:00
|
|
|
logging.info('%s required more info' % update.effective_user.username)
|
2025-01-02 10:59:01 +01:00
|
|
|
await update.message.reply_text('See https://github.com/alberanid/fortunes-spam')
|
2018-08-18 19:24:18 +02:00
|
|
|
|
|
|
|
|
2018-08-18 18:43:47 +02:00
|
|
|
if __name__ == '__main__':
|
2018-08-18 19:24:18 +02:00
|
|
|
if 'SPAMBOT_TOKEN' not in os.environ:
|
2018-08-18 18:43:47 +02:00
|
|
|
print("Please specify the Telegram token in the SPAMBOT_TOKEN environment variable")
|
|
|
|
logging.info('start serving delicious spam')
|
2025-01-02 10:59:01 +01:00
|
|
|
application = Application.builder().token(os.environ['SPAMBOT_TOKEN']).build()
|
|
|
|
application.add_handler(CommandHandler('en', en))
|
|
|
|
application.add_handler(CommandHandler('it', it))
|
|
|
|
application.add_handler(CommandHandler('about', about))
|
|
|
|
application.run_polling(allowed_updates=Update.ALL_TYPES)
|