Первый навык
Добро пожаловать, путник!
Здесь будет представлено, как можно взаимодействовать с API Алисы и отвечать на его запросы.
База
Перед тем, как начать разработку навыка для Алисы, важно знать официальную документацию и принцип работы навыков.
Взаимодействие с Алисой происходит через webhook'и (или облачные функции) -
Яндекс отправляет запрос с новым событие навыка, он что-то думает и возвращает ответ. Навыки не опрашивают Алису на предмет новых сообщений, действий и так далее.
Здесь нет pooling'а,
поэтому нельзя узнать, принял ли Яндекс ваш ответ без ошибок (но не всегда).
Важно
Именно из-за вебхуков все хэндлеры (и мидлвари) обязаны что-то вернуть, иначе Алиса завершит сессию пользователя.
Типизация
На момент создания библиотеки разработчики постарались перевести все json-объекты из документации в модели pydantic'а, которые и являются подсказками типов.
В моделях не учтены все возможные ограничения Алисы (например, размер всего ответа),
поэтому обязательно уточняйте их в официальной документации и тестируйте свои навыки.
Первые шаги
Начнём с написания простого эхо-навыка.
Для начала работы следует ознакомиться с основными классами фреймворка: Skill, Dispatcher, и OneSkillAiohttpRequestHandler.
При иницализации навыка нужно указать его айди (обязательно) и OAuth Token (опицонально).
Первый позволяет игнорировать запросы, адресованные не этому навыку, а второй даёт возможность взаимодействовать с файлами ваших навыков.
Теперь в диспетчер можно добавить нужный обработчик:
Разберём этот фрагмент построчно:
@dp.message() - это декоратор, который регистрирует функцию-обработчик, которая сработает, если сообщение будет отвечать заданным фильтрам.
Здесь их нет, поэтому функция будет срабатывать на каждое сообщение.
async def message_handler(message: Message) -> AliceResponse: - сигнатура функции-обработчика, в которой первым аргументом всегда будет текущее событие.
Эта функция возвращает AliceResponse, но фреймворк поддерживает и другие варианты.
if message.session.new: - проверяем, первое ли это сообщение в текущей сессии (т.е. пользователь только открыл навык).
Если это так, то вместо эха будет приветствие.
return AliceResponse(response=Response(text=text)) - возвращаем полный объект, который ждёт Алиса.
Вместо него можно вернуть просто Response или str, которая станет текстом.
Запуск
Теперь надо как-то запустить эту шайтан-машину, чтобы она принимала запросы от Алисы.
Для этого напишем простую точку входа, которая будет чуть модифицирована в дальнейшем:
Примеры
Полный код из этой главы: