Доброго дня. Помогите плз полному профану. Из этой статьи
m.habrahabr.ru/post/261473, закинул на Raspberry вот этот скрипт:
telegram.py (python2.7) - обновлено
# -*- coding: utf-8 -*-
import requests
import time
import subprocess
import os
#import mailchecker
requests.packages.urllib3.disable_warnings() # Подавление InsecureRequestWarning, с которым я пока ещё не разобрался
# Ключ авторизации Вашего бота Вы можете получить в любом клиенте Telegram у бота @BotFather
# ADMIN_ID - идентификатор пользователя (то есть Вас), которому подчиняется бот
# Чтобы определить Ваш ID, я предлагаю отправить боту сообщение от своего имени (аккаунта) через любой клиент
# А затем получить это сообщения с помощью обычного GET запроса
# Для этого вставьте в адресную строку Вашего браузера следующий адрес, заменив <token> на свой ключ:
# https://api.telegram.org/bot<token>/getUpdates
# Затем, в ответе найдите объект "from":{"id":01234567,"first_name":"Name","username":"username"}
# Внимательно проверьте имя, логин и текст сообщения
# Если всё совпадает, то цифровое значение ключа "id" - это и есть ваш идентификатор
# Переменным ADMIN_ID и TOKEN необходимо присвоить Вашим собственные значения
INTERVAL = 3 # Интервал проверки наличия новых сообщений (обновлений) на сервере в секундах
ADMIN_ID = 12345678 # ID пользователя. Комманды от других пользователей выполняться не будут
URL = 'https://api.telegram.org/bot' # Адрес HTTP Bot API
TOKEN = '123456789:???????????????????????????????????' # Ключ авторизации для Вашего бота
offset = 0 # ID последнего полученного обновления
def check_updates():
"""Проверка обновлений на сервере и инициация действий, в зависимости от команды"""
global offset
data = {'offset': offset + 1, 'limit': 5, 'timeout': 0} # Формируем параметры запроса
try:
request = requests.post(URL + TOKEN + '/getUpdates', data=data) # Отправка запроса обновлений
except:
log_event('Error getting updates') # Логгируем ошибку
return False # Завершаем проверку
if not request.status_code == 200: return False # Проверка ответа сервера
if not request.json()['ok']: return False # Проверка успешности обращения к API
for update in request.json()['result']: # Проверка каждого элемента списка
offset = update['update_id'] # Извлечение ID сообщения
# Ниже, если в обновлении отсутствует блок 'message'
# или же в блоке 'message' отсутствует блок 'text', тогда
if not 'message' in update or not 'text' in update['message']:
log_event('Unknown update: %s' % update) # сохраняем в лог пришедшее обновление
continue # и переходим к следующему обновлению
from_id = update['message']['chat']['id'] # Извлечение ID чата (отправителя)
name = update['message']['chat']['username'] # Извлечение username отправителя
if from_id <> ADMIN_ID: # Если отправитель не является администратором, то
send_text("You're not autorized to use me!", from_id) # ему отправляется соответствующее уведомление
log_event('Unautorized: %s' % update) # обновление записывается в лог
continue # и цикл переходит к следующему обновлению
message = update['message']['text'] # Извлечение текста сообщения
parameters = (offset, name, from_id, message)
log_event('Message (id%s) from %s (id%s): "%s"' % parameters) # Вывод в лог ID и текста сообщения
# В зависимости от сообщения, выполняем необходимое действие
run_command(*parameters)
def run_command(offset, name, from_id, cmd):
if cmd == '/ping': # Ответ на ping
send_text(from_id, 'pong') # Отправка ответа
elif cmd == '/help': # Ответ на help
send_text(from_id, 'No help today. Sorry.') # Ответ
elif cmd == '/photo': # Запрос фотографии с подключенной Web-камеры
# Для оператора If ниже. Если первая попытка успешна - выполняется условие, если нет, то вторая попытка и условие
# Если и вторая не успешна, тогда отчитываемся об ошибке
# Всё потому, что на моей конфигурации крайне изредка камера бывает недоступна с первого раза
if make_photo(offset) or make_photo(offset):
# Ниже, отправка пользователю уведомления об активности бота
requests.post(URL + TOKEN + '/sendChatAction', data={'chat_id': from_id, 'action': 'upload_photo'})
send_photo(from_id, offset) # Вызов процедуры отправки фото
else:
send_text(from_id, 'Error occured') # Ответ, сообщающий об ошибке
elif cmd == '/mail':
check_mail() # Вызов процедуры проверки почты
else:
send_text(from_id, 'Got it.') # Отправка ответа
def log_event(text):
"""
Процедура логгирования
ToDo: 1) Запись лога в файл
"""
event = '%s >> %s' % (time.ctime(), text)
print event
def send_text(chat_id, text):
"""Отправка текстового сообщения по chat_id
ToDo: повторная отправка при неудаче"""
log_event('Sending to %s: %s' % (chat_id, text)) # Запись события в лог
data = {'chat_id': chat_id, 'text': text} # Формирование запроса
request = requests.post(URL + TOKEN + '/sendMessage', data=data) # HTTP запрос
if not request.status_code == 200: # Проверка ответа сервера
return False # Возврат с неудачей
return request.json()['ok'] # Проверка успешности обращения к API
def make_photo(photo_id):
"""Обращение к приложению fswebcam для получения снимка с Web-камеры"""
photo_name = 'photo/%s.jpg' % photo_id # Формирование имени файла фотографии
subprocess.call('fswebcam -q -r 1280x720 %s' % photo_name, shell=True) # Вызов shell-команды
return os.path.exists(photo_name) # Проверка, появился ли файл с таким названием
def send_photo(chat_id, photo_id):
"""Отправка фото по его идентификатору выбранному контакту"""
data = {'chat_id': chat_id} # Формирование параметров запроса
photo_name = 'photo/%s.jpg' % photo_id # Формирования имени файла фотографии
if not os.path.exists(photo_name): return False # Проверка существования фотографии
files = {'photo': open(photo_name, 'rb')} # Открытие фото и присвоение
request = requests.post(URL + TOKEN + '/sendPhoto', data=data, files=files) # Отправка фото
return request.json()['ok'] # Возврат True или False, полученного из ответа сервера, в зависимости от результата
def check_mail():
"""Проверка почтовых ящиков с помощью самодельного модуля"""
print "Подключите и настройте модуль проверки почты"
return False
try:
log_event('Checking mail...') # Запись в лог
respond = mailchecker.check_all() # Получаем ответ от модуля проверки
except:
log_event('Mail check failed.') # Запись в лог
return False # И возврат с неудачей
if not respond: respond = 'No new mail.' # Если ответ пустой, тогда заменяем его на соответствующее сообщение
send_text(ADMIN_ID, respond) # Отправляем это сообщение администратору
return True
if __name__ == "__main__":
while True:
try:
check_updates()
time.sleep(INTERVAL)
except KeyboardInterrupt:
print 'Прервано пользователем..'
break
Для удаленного управления Raspberry через Telegram мессенджер.
Прописал автозапуск в rc.local
ПРОБЛЕМА в том, что через некоторое время Raspberry перестает реагировать на команды посланные через Telegram. Подскажите плз что делать? Заранее спасибо и простите, если вопрос сформулирован коряво