-
Notifications
You must be signed in to change notification settings - Fork 326
/
Copy pathcallback_bot.py
62 lines (51 loc) · 2.2 KB
/
callback_bot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# -*- coding: utf-8 -*-
from flask import Flask, request
import vk_api
from vk_api.utils import get_random_id
"""
Пример бота для группы ВКонтакте использующего
callback-api для получения сообщений.
Подробнее: https://vk.com/dev/callback_api
Перед запуском необходимо установить flask (pip install flask)
Запуск:
$ FLASK_APP=callback_bot.py flask run
При развертывании запускать с помощью gunicorn (pip install gunicorn):
$ gunicorn callback_bot:app
"""
app = Flask(__name__)
vk_session = vk_api.VkApi(token='your_group_token')
vk = vk_session.get_api()
confirmation_code = 'smthing code'
"""
При развертывании путь к боту должен быть секретный,
поэтому поменяйте my_bot на случайную строку
Например:
756630756e645f336173313372336767
Сгенерировать строку можно через:
$ python3 -c "import secrets;print(secrets.token_hex(16))"
"""
@app.route('/my_bot', methods=['POST'])
def bot():
# получаем данные из запроса
data = request.get_json(force=True, silent=True)
# ВКонтакте в своих запросах всегда отправляет поле type:
if not data or 'type' not in data:
return 'not ok'
# проверяем тип пришедшего события
if data['type'] == 'confirmation':
# если это запрос защитного кода
# отправляем его
return confirmation_code
# если же это сообщение, отвечаем пользователю
elif data['type'] == 'message_new':
# получаем ID пользователя
from_id = data['object']['message']['from_id']
# отправляем сообщение
vk.messages.send(
message='Hello World!',
random_id=get_random_id(),
peer_id=from_id
)
# возвращаем серверу VK "ok" и код 200
return 'ok'
return 'ok' # игнорируем другие типы