Реализация AI-агента с выполнением действий в мобильном приложении (бронирование, заказ)

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация AI-агента с выполнением действий в мобильном приложении (бронирование, заказ)
Сложная
~1-2 недели
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1054
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    864
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Реализация AI-агента с выполнением действий в мобильном приложении (бронирование, заказ)

Агент, который не только отвечает, но и делает — это другой уровень ответственности. Забронировать столик, оформить заказ, перевести деньги. Ошибка в таком агенте — это не «неправильный текст», это реальное действие с реальными последствиями. Именно поэтому архитектура агентов с выполнением действий принципиально отличается от информационных.

Human-in-the-loop: почему это обязательно

Ни один агент в продакшене не должен выполнять необратимые действия без явного подтверждения пользователя. Это не перестраховка — это правило. GPT-4o иногда интерпретирует «я бы хотел заказать пиццу» как прямую команду к действию, а не как выражение желания.

Правильный UX: агент собирает все параметры → показывает сводку → ждёт confirm от пользователя → выполняет. На мобильном это реализуется через специальный инструмент request_confirmation:

// Инструмент подтверждения — не выполняет действие, а запрашивает разрешение
data class ConfirmationRequest(
    val action: String,        // "book_restaurant"
    val summary: String,       // "Столик на 2 в Кафе Минск, 26 марта 19:00"
    val details: Map<String, Any>  // все параметры для отображения
)

// Агент вызывает этот инструмент последним перед действием
// Клиент показывает Bottom Sheet с деталями и кнопкой "Подтвердить"

Модель не должна иметь возможности «пропустить» подтверждение. В системном промпте явно прописываем: «Перед любым бронированием или заказом ОБЯЗАТЕЛЬНО вызови инструмент request_confirmation и дожидайся ответа пользователя».

Идемпотентность и защита от дублирования

Пользователь нажал «Подтвердить», соединение прервалось, приложение не знает — выполнился заказ или нет. Без идемпотентности — двойной заказ. Решение: генерируем idempotency_key (UUID) до первой отправки и передаём с каждым повтором:

// iOS — создаём ключ один раз, сохраняем до подтверждения выполнения
let idempotencyKey = UUID().uuidString
UserDefaults.standard.set(idempotencyKey, forKey: "pending_order_key")

// Передаём в заголовке или теле запроса к бэкенду
request.setValue(idempotencyKey, forHTTPHeaderField: "Idempotency-Key")

Большинство платёжных систем (Stripe, YooKassa) поддерживают Idempotency-Key нативно. Для собственного бэкенда нужно хранить ключи в Redis с TTL 24 часа и возвращать кешированный результат для повторных запросов.

Откат и обработка частичных сбоев

Сценарий: агент забронировал рейс, но отель не ответил. Нужно либо отменить рейс, либо уведомить пользователя о частичном успехе. Паттерн Saga: каждое действие имеет компенсирующее действие (отмена). Агент должен знать об этих компенсирующих действиях и уметь их вызывать.

{
  "name": "cancel_flight_booking",
  "description": "Отменяет ранее выполненное бронирование рейса. Используй ТОЛЬКО при явной просьбе пользователя или при сбое в последующих шагах бронирования.",
  "parameters": {
    "booking_id": {"type": "string", "description": "ID бронирования из результата search_flights"}
  }
}

Состояние заказа и офлайн-очередь

Действие может занимать время — ответ от внешней системы бронирования иногда приходит через 3–10 секунд. На мобильном это означает индикатор прогресса с описанием текущего шага («Проверяем наличие мест...»), а не просто спиннер.

Если приложение было свёрнуто во время выполнения — используйте WorkManager на Android для фоновой задачи с статусом, или BGTaskScheduler на iOS. Пользователь должен получить push-уведомление с результатом.

Локально сохраняйте состояние агента в Room/Core Data: текущий шаг, параметры, идентификаторы бронирований. При перезапуске приложения — восстановление состояния и возможность продолжить или отменить.

Что тестировать обязательно

  • Двойное нажатие «Подтвердить» (race condition)
  • Таймаут внешнего API на шаге оплаты
  • Отказ одного сервиса при успехе другого (частичная транзакция)
  • Изменение цены или доступности между поиском и бронированием
  • Попытка агента выполнить действие без подтверждения (adversarial prompts)

Этапы работы

Анализ бизнес-процессов и определение «опасных» действий → проектирование human-in-the-loop для каждого → реализация идемпотентности и компенсирующих действий → агентный цикл с управлением состоянием → UI подтверждения и прогресса → интеграционное тестирование edge-cases → нагрузочные тесты.

Сроки: агент для одного типа действия (например, только бронирование столика) — 3–4 недели. Мультидоменный агент (рейс + отель + трансфер) — 6–10 недель.