def collect_values(message, user_id): user = db_operator.get_user(user_id) try: user['last_sending_date'] except KeyError: db_operator.set_user_last_date(user_id, str(datetime.today())) lens = db_operator.check_collect_progress(user_id) if lens[1] < lens[0] and db_operator.get_current_state( user_id) == constants.States.S_ENTER_DATA.value: if data_processing.msg_check(message, 'digit'): if db_operator.update_data_value(user_id, user['vars'][f'{lens[1] + 22}'], message): lens = db_operator.check_collect_progress(user_id) if lens[0] >= lens[1] + 1: text = f"Введите {user['vars'][f'{lens[1] + 22}']}" options = { 'later_hour': 'через час', 'later_day': 'завтра', } bot_actions.bot_send_keyboard(text, user_id, options) else: bot_actions.send_message( user_id, text="Нужно ввести цифры, попробуй ещё раз.") if lens[1] == lens[0]: send_data(user_id) db_operator.set_user_next_date(user_id) bot_actions.send_message( user_id, f'Ваши данные успешно отправлены на адрес {user["mail_to"]}.\n' f'Следующая дата отправки - ' f'{db_operator.get_user_data(user_id, "next_date").split(".")[0][:-3]}' ) db_operator.set_state(user_id, constants.States.S_USER_WAIT.value) time.sleep(1)
def user_asks_help(user_id): user = db_operator.get_user(user_id) if user: try: bot_actions.send_message( user_id, "<b>Ваши данные</b>:\n" f"<b>Текст письма</b>:\n {user['mail_text']}\n" f"<b>Получатель</b>: {user['mail_to']}\n" f"<b>Следующая дата отправки</b>: {user['next_date'].split('.')[0][:-3]}\n" "Комадны:\n" "/help - ее вы уже использовали и видите результат\n" "/update - изменить некоторые данные\n" "/delete - удалить свои данные\n" "/last - последние отправленные данные\n" "/info - чтобы узнать обо мне" "Чтобы сохранить шаблон, но отменить оправку данных, просто напишите 'отмена'", parse_mode='HTML') except Exception as e: print( f'Error while running "user_asks_help" 3 with args: {e.args}') return None else: bot_actions.send_message( user_id, 'Чтобы создать шаблон письма для отправи данных - воспользуйтесь командой /start\n' 'Чтобы узнать обо мне - /info')
def send_data(user_id): user = db_operator.get_user(user_id) try: vars_dict = db_operator.get_last_data(user_id) vars_dict.update({'дата': date.today().strftime('%d.%m.%Y')}) except Exception: vars_dict = None for mail_to in user['mail_to'].split(): s = smtplib.SMTP('smtp.gmail.com', port=587) s.set_debuglevel(1) if vars_dict: msg = MIMEText(user['mail_text'].format(**vars_dict), 'plain', 'utf-8') else: msg = MIMEText(user['mail_text'], 'plain', 'utf-8') msg['Subject'] = Header(user['mail_theme']) msg['From'] = private_constants.email_from try: s.starttls() s.login(private_constants.email_from, private_constants.mailpass) msg['To'] = mail_to print(msg['To']) s.sendmail(msg['From'], msg['To'], msg.as_string()) finally: s.quit()
def user_doing_nothing(message, user_id): user = db_operator.get_user(user_id) if user: bot_actions.bot_send_keyboard( 'Нажмите на кнопку, чтобы возобновить отправку данных.\nЧтобы получить справку, введите /help', user_id, {'renew': 'Возобновить'}) else: bot_actions.send_message( user_id, 'Чтобы узнать обо мне, воспользуйтесь командой /info\n' 'Чтобы получить информацию о командах и ваших данных ' '(если вы их вносили) - /help')
def when_timer_stop(flag, user_id, in_progress=False): user = db_operator.get_user(user_id) db_operator.set_state(user_id, user['last_state']) print(f'state is {db_operator.get_current_state(user_id)}') text = '' options = { 'later_hour': 'через час', 'later_day': 'завтра', } try: if flag: text = "Введите ранее запрошенные показания:" else: try: if str(datetime.today() )[:10] == user['last_sending_date'][:10]: data_v = db_operator.get_last_data(user_id) us_vars = db_operator.get_user_data(user_id, 'vars').values() if all(x in data_v.keys() for x in us_vars): db_operator.set_user_last_date( user_id, str(datetime.today() + timedelta(days=1))) db_operator.set_user_next_date(user_id) bot_actions.send_message( user_id, 'Данные за сегодняшнее число уже были отправлены\n' '<b>Следующая дата отправки</b>: ' f'{db_operator.get_user_data(user_id, "next_date")}', parse_mode='HTML') user_set_timer(None, user_id) return elif not in_progress: lens = db_operator.check_collect_progress(user_id) text = f"Введите {user['vars'][f'{lens[1] + 22}']}" except Exception: if not in_progress: lens = db_operator.check_collect_progress(user_id) text = f"Введите {user['vars'][f'{lens[1] + 22}']}" except KeyError: try: print(user['last_sending_date']) except KeyError: db_operator.set_user_last_date(user_id, str(datetime.today())) text = "Подтвердите отправку" options = {'send': 'Отправить'} if text: bot_actions.bot_send_keyboard(text, user_id, options)
def user_set_timer(message, user_id): user_id = str(user_id) user = db_operator.get_user(user_id) if user and user['collecting'] == 'true': db_operator.set_user_last_state(user_id, constants.States.S_ENTER_DATA.value) db_operator.set_state(user_id, constants.States.S_USER_WAIT.value) seconds = datetime.fromisoformat(user['next_date']) - datetime.today() if seconds.total_seconds() > TIMEOUT_MAX: timer = Timer(timedelta(days=30).total_seconds(), user_set_timer, args=(None, user_id)) else: timer = Timer( seconds.total_seconds() - timedelta(hours=user['tz_delta']).total_seconds(), lambda: when_timer_stop(False, user_id)) timers.update({user_id: {'timer': timer, 'in_progress': False}}) timers[user_id]['timer'].start() print(timers[user_id]['timer'])
def user_wait(message, user_id): user_id = str(user_id) if timers[user_id]['in_progress'] or 'отмен' in message.lower(): timers[user_id]['timer'].cancel() if 'отмен' in message.lower(): bot_actions.send_message(user_id, 'Отправка данных отменена') db_operator.set_state(user_id, constants.States.S_START.value) db_operator.swap_collect(user_id) return elif message.isdigit(): when_timer_stop(False, user_id, in_progress=True) db_operator.set_state( user_id, db_operator.get_user_data(user_id, 'last_state')) actions[db_operator.get_user_data(user_id, 'last_state')](message, user_id) else: when_timer_stop(True, user_id) else: user = db_operator.get_user(user_id) bot_actions.send_message( user_id, 'Следующая отправка данных:\n' f'{user["next_date"].split(".")[0][:-3]}')
def update_data(user_id): try: user = db_operator.get_user(user_id) msg = f"<b>Ваши данные</b>:\n" \ f"<b>Текст письма</b>:\n{user['mail_text']}\n" \ f"<b>Тема письма</b>:\n{user['mail_theme']}\n" \ f"<b>Получатель</b>: {user['mail_to']}\n" \ f"<b>Временная разница с сервером</b>: {user['tz_delta']} ч\n" \ f"<b>Период отправки данных</b>: {constants.choose_period[(user['send_period'])][0]}\n" keys = [ key for key in constants.choose_period[data_processing.in_array( list(constants.choose_period.keys()), [user['send_period']])] [1:] ] send_period_info = [ f'<b>{value[key][1]}</b>{user[key]}\n' for value in constants.corQuests for key in keys if key in value.keys() ] msg = f'{msg}{"".join(send_period_info)}' bot_actions.send_message(user_id, msg, parse_mode='HTML') options = { 'update_template': 'Текст письма', 'update_mail_theme': 'Тема письма', 'update_mail_to': 'Получатель', 'update_send_period': 'Период отправки данных', 'update_timezone': 'Часовой пояс', } db_operator.set_user_data(user_id, 'updating', 'true') bot_actions.bot_send_keyboard( 'Укажите, какие данных вы хотели бы отредактировать: ', user_id, options) except TypeError: bot_actions.send_message( user_id, 'У меня нет ваших данных.\n' 'Чтобы узнать обо мне, воспользуйтесь командой /info\n' 'Чтобы начать создание шаблона - /start')
def new_user_init(user_id): if db_operator.get_user(user_id): bot_actions.send_message( user_id, 'Я нашел ваши данные!\n' 'Если хотите проверить и изменить свои данные, используйте команду /update\n' 'Если хотите удалить свои данные - /delete') else: if db_operator.init_user(user_id=user_id): bot_actions.send_message( user_id, 'Начнем с формирования шаблона!\n<b>Если ' 'вдруг что-то пойдет не так - воспользуйтесь командой</b> /delete!\n' 'Введите текст письма. Следуйте примеру, выделяя места появления данных' ' и текущей даты фигурными скобками (если отметить место для текущей даты' ', при отправке письма она будет появляться в выбранном месте ' 'автоматически). Пример:\n\n' '<i>Добрый день!\n' 'Показания ИПУ по адресу ул. Пушкина, д. 1, кв. 2 на {дата}:\n\n' 'Электроэнергия: {показания счетчика электроэнергии}\n' 'Холодное водоснабжение: {показания счетчика холодной воды}\n' 'Горячее водоснабжение: {показания счетчика горячей воды}\n\n' 'С уважением, Петров А. А.</i>', parse_mode='HTML') db_operator.set_state(user_id, constants.States.S_SET_TEMPLATE.value)
def callback_wait(user_id, option): user_id = str(user_id) user = db_operator.get_user(user_id) if option == 'day': time_obj = parse(parse_time(user['at_time'])) seconds_delta = datetime.today() + timedelta(days=1) seconds_delta = seconds_delta.replace(hour=time_obj.hour, minute=time_obj.minute, second=0) - datetime.today() bot_actions.send_message( user_id, text=f"Переспрошу завтра в {time_obj.hour}:{time_obj.minute}") else: seconds_delta = timedelta(hours=1) bot_actions.send_message(user_id, text="Переспрошу через час") timer = Timer(seconds_delta.total_seconds(), when_timer_stop, args=(True, user_id)) timers.update({user_id: {'timer': timer, 'in_progress': True}}) db_operator.set_user_last_state(user_id, constants.States.S_ENTER_DATA.value) db_operator.set_state(user_id, constants.States.S_USER_WAIT.value) timers[user_id]['timer'].start() print(timers[user_id]['timer'])