2016-07-15 01:30:54 +02:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# This program is dedicated to the public domain under the CC0 license.
|
|
|
|
|
2019-02-13 13:38:07 +01:00
|
|
|
"""
|
2016-07-15 01:30:54 +02:00
|
|
|
First, a few callback functions are defined. Then, those functions are passed to
|
|
|
|
the Dispatcher and registered at their respective places.
|
|
|
|
Then, the bot is started and runs until we press Ctrl-C on the command line.
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
Example of a bot-user conversation using ConversationHandler.
|
|
|
|
Send /start to initiate the conversation.
|
|
|
|
Press Ctrl-C on the command line or send a signal to the process to stop the
|
|
|
|
bot.
|
|
|
|
"""
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
import logging
|
|
|
|
|
2016-12-11 22:44:52 +01:00
|
|
|
from telegram import (ReplyKeyboardMarkup, ReplyKeyboardRemove)
|
2019-08-23 21:32:12 +02:00
|
|
|
from telegram.ext import (Updater, CommandHandler, MessageHandler, Filters,
|
2016-07-15 01:30:54 +02:00
|
|
|
ConversationHandler)
|
|
|
|
|
|
|
|
# Enable logging
|
|
|
|
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
|
|
|
|
level=logging.INFO)
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
GENDER, PHOTO, LOCATION, BIO = range(4)
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def start(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
reply_keyboard = [['Boy', 'Girl', 'Other']]
|
|
|
|
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text(
|
|
|
|
'Hi! My name is Professor Bot. I will hold a conversation with you. '
|
|
|
|
'Send /cancel to stop talking to me.\n\n'
|
|
|
|
'Are you a boy or a girl?',
|
|
|
|
reply_markup=ReplyKeyboardMarkup(reply_keyboard, one_time_keyboard=True))
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return GENDER
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def gender(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("Gender of %s: %s", user.first_name, update.message.text)
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('I see! Please send me a photo of yourself, '
|
2016-11-08 22:14:11 +01:00
|
|
|
'so I know what you look like, or send /skip if you don\'t want to.',
|
2016-12-11 22:44:52 +01:00
|
|
|
reply_markup=ReplyKeyboardRemove())
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return PHOTO
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def photo(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2018-09-21 08:57:01 +02:00
|
|
|
photo_file = update.message.photo[-1].get_file()
|
2016-07-15 01:30:54 +02:00
|
|
|
photo_file.download('user_photo.jpg')
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("Photo of %s: %s", user.first_name, 'user_photo.jpg')
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('Gorgeous! Now, send me your location please, '
|
|
|
|
'or send /skip if you don\'t want to.')
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return LOCATION
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def skip_photo(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("User %s did not send a photo.", user.first_name)
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('I bet you look great! Now, send me your location please, '
|
|
|
|
'or send /skip.')
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return LOCATION
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def location(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
|
|
|
user_location = update.message.location
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("Location of %s: %f / %f", user.first_name, user_location.latitude,
|
|
|
|
user_location.longitude)
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('Maybe I can visit you sometime! '
|
|
|
|
'At last, tell me something about yourself.')
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return BIO
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def skip_location(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("User %s did not send a location.", user.first_name)
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('You seem a bit paranoid! '
|
|
|
|
'At last, tell me something about yourself.')
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return BIO
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def bio(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("Bio of %s: %s", user.first_name, update.message.text)
|
2016-09-24 15:32:22 +02:00
|
|
|
update.message.reply_text('Thank you! I hope we can talk again some day.')
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return ConversationHandler.END
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def cancel(update, context):
|
2016-07-15 01:30:54 +02:00
|
|
|
user = update.message.from_user
|
2017-10-20 20:24:00 +02:00
|
|
|
logger.info("User %s canceled the conversation.", user.first_name)
|
2016-11-08 22:14:11 +01:00
|
|
|
update.message.reply_text('Bye! I hope we can talk again some day.',
|
2016-12-11 22:44:52 +01:00
|
|
|
reply_markup=ReplyKeyboardRemove())
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
return ConversationHandler.END
|
|
|
|
|
|
|
|
|
2018-09-21 08:57:01 +02:00
|
|
|
def error(update, context):
|
2017-10-20 20:24:00 +02:00
|
|
|
"""Log Errors caused by Updates."""
|
2018-09-21 08:57:01 +02:00
|
|
|
logger.warning('Update "%s" caused error "%s"', update, context.error)
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
|
|
|
|
def main():
|
2018-09-21 08:57:01 +02:00
|
|
|
# Create the Updater and pass it your bot's token.
|
|
|
|
# Make sure to set use_context=True to use the new context based callbacks
|
|
|
|
# Post version 12 this will no longer be necessary
|
|
|
|
updater = Updater("TOKEN", use_context=True)
|
2016-07-15 01:30:54 +02:00
|
|
|
|
|
|
|
# Get the dispatcher to register handlers
|
|
|
|
dp = updater.dispatcher
|
|
|
|
|
|
|
|
# Add conversation handler with the states GENDER, PHOTO, LOCATION and BIO
|
|
|
|
conv_handler = ConversationHandler(
|
|
|
|
entry_points=[CommandHandler('start', start)],
|
|
|
|
|
|
|
|
states={
|
2019-08-23 21:32:12 +02:00
|
|
|
GENDER: [MessageHandler(Filters.regex('^(Boy|Girl|Other)$'), gender)],
|
2016-07-15 01:30:54 +02:00
|
|
|
|
2016-10-25 19:51:56 +02:00
|
|
|
PHOTO: [MessageHandler(Filters.photo, photo),
|
2016-07-15 01:30:54 +02:00
|
|
|
CommandHandler('skip', skip_photo)],
|
|
|
|
|
2016-10-25 19:51:56 +02:00
|
|
|
LOCATION: [MessageHandler(Filters.location, location),
|
2016-07-15 01:30:54 +02:00
|
|
|
CommandHandler('skip', skip_location)],
|
|
|
|
|
2016-10-25 19:51:56 +02:00
|
|
|
BIO: [MessageHandler(Filters.text, bio)]
|
2016-07-15 01:30:54 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
fallbacks=[CommandHandler('cancel', cancel)]
|
|
|
|
)
|
|
|
|
|
|
|
|
dp.add_handler(conv_handler)
|
|
|
|
|
|
|
|
# log all errors
|
|
|
|
dp.add_error_handler(error)
|
|
|
|
|
|
|
|
# Start the Bot
|
|
|
|
updater.start_polling()
|
|
|
|
|
2017-02-18 16:03:50 +01:00
|
|
|
# Run the bot until you press Ctrl-C or the process receives SIGINT,
|
2016-07-15 01:30:54 +02:00
|
|
|
# SIGTERM or SIGABRT. This should be used most of the time, since
|
|
|
|
# start_polling() is non-blocking and will stop the bot gracefully.
|
|
|
|
updater.idle()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|