2017-10-28 12:06:34 +03:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
"""
|
|
|
|
A example script to automatically send messages based on certain triggers.
|
|
|
|
|
|
|
|
The script makes uses of environment variables to determine the API ID,
|
|
|
|
hash, phone and such to be used. You may want to add these to your .bashrc
|
|
|
|
file, including TG_API_ID, TG_API_HASH, TG_PHONE and optionally TG_SESSION.
|
|
|
|
|
|
|
|
This script assumes that you have certain files on the working directory,
|
|
|
|
such as "xfiles.m4a" or "anytime.png" for some of the automated replies.
|
|
|
|
"""
|
2018-02-16 23:02:47 +03:00
|
|
|
import re
|
2017-10-28 12:06:34 +03:00
|
|
|
from collections import defaultdict
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
from os import environ
|
|
|
|
|
2018-02-16 23:02:47 +03:00
|
|
|
from telethon import TelegramClient, events, utils
|
2017-10-28 12:06:34 +03:00
|
|
|
|
|
|
|
"""Uncomment this for debugging
|
|
|
|
import logging
|
|
|
|
logging.basicConfig(level=logging.DEBUG)
|
|
|
|
logging.debug('dbg')
|
|
|
|
logging.info('info')
|
|
|
|
"""
|
|
|
|
|
|
|
|
REACTS = {'emacs': 'Needs more vim',
|
|
|
|
'chrome': 'Needs more Firefox'}
|
|
|
|
|
|
|
|
# A list of dates of reactions we've sent, so we can keep track of floods
|
|
|
|
recent_reacts = defaultdict(list)
|
|
|
|
|
|
|
|
|
2018-02-16 23:02:47 +03:00
|
|
|
if __name__ == '__main__':
|
|
|
|
# TG_API_ID and TG_API_HASH *must* exist or this won't run!
|
|
|
|
session_name = environ.get('TG_SESSION', 'session')
|
|
|
|
client = TelegramClient(
|
|
|
|
session_name, int(environ['TG_API_ID']), environ['TG_API_HASH'],
|
|
|
|
spawn_read_thread=False, proxy=None, update_workers=4
|
|
|
|
)
|
|
|
|
|
|
|
|
@client.on(events.NewMessage)
|
|
|
|
def my_handler(event: events.NewMessage.Event):
|
|
|
|
global recent_reacts
|
|
|
|
|
|
|
|
# This utils function gets the unique identifier from peers (to_id)
|
|
|
|
to_id = utils.get_peer_id(event.message.to_id)
|
|
|
|
|
|
|
|
# Through event.raw_text we access the text of messages without format
|
|
|
|
words = re.split('\W+', event.raw_text)
|
|
|
|
|
|
|
|
# Try to match some reaction
|
2017-10-28 12:06:34 +03:00
|
|
|
for trigger, response in REACTS.items():
|
2018-02-16 23:02:47 +03:00
|
|
|
if len(recent_reacts[to_id]) > 3:
|
2017-10-28 12:06:34 +03:00
|
|
|
# Silently ignore triggers if we've recently sent 3 reactions
|
|
|
|
break
|
|
|
|
|
|
|
|
if trigger in words:
|
|
|
|
# Remove recent replies older than 10 minutes
|
2018-02-16 23:02:47 +03:00
|
|
|
recent_reacts[to_id] = [
|
|
|
|
a for a in recent_reacts[to_id] if
|
2017-10-28 12:06:34 +03:00
|
|
|
datetime.now() - a < timedelta(minutes=10)
|
|
|
|
]
|
2018-02-16 23:02:47 +03:00
|
|
|
# Send a reaction as a reply (otherwise, event.respond())
|
|
|
|
event.reply(response)
|
2017-10-28 12:06:34 +03:00
|
|
|
# Add this reaction to the list of recent actions
|
2018-02-16 23:02:47 +03:00
|
|
|
recent_reacts[to_id].append(datetime.now())
|
|
|
|
|
|
|
|
# Automatically send relevant media when we say certain things
|
|
|
|
# When invoking requests, get_input_entity needs to be called manually
|
|
|
|
if event.out:
|
|
|
|
if event.raw_text.lower() == 'x files theme':
|
|
|
|
client.send_voice_note(event.message.to_id, 'xfiles.m4a',
|
|
|
|
reply_to=event.message.id)
|
|
|
|
if event.raw_text.lower() == 'anytime':
|
|
|
|
client.send_file(event.message.to_id, 'anytime.png',
|
|
|
|
reply_to=event.message.id)
|
|
|
|
if '.shrug' in event.text:
|
|
|
|
event.edit(event.text.replace('.shrug', r'¯\_(ツ)_/¯'))
|
|
|
|
|
|
|
|
if 'TG_PHONE' in environ:
|
|
|
|
client.start(phone=environ['TG_PHONE'])
|
|
|
|
else:
|
|
|
|
client.start()
|
|
|
|
|
|
|
|
print('(Press Ctrl+C to stop this)')
|
|
|
|
client.idle()
|