Sobes.tech
Назад к вопросам
Principal
24

Система оплаты с помощью телефона Необходимо реализовать архитектуру, где клиент может оплачивать покупки на кассе/КСО (касса самообслуживания) с помощью мобильного приложения. Оплата происходит НЕ по СБП. Пользователь покупая товары, выбирает оплатить с помощью приложения. Касса или КСО должны определить пользователя и запускается процесс оплаты с помощью банка клиента. СJM: - Кассир/клиент сканирует товары. - Переходит к оплате. - Идентифицируется на кассе/КСО. - Выбирает оплатить в приложении Магнит. - Переходит в приложение Магнит. - Выбирает установленный на телефоне банк с которого происходит оплата. - В приложении банка оплачивает покупку. - Возвращается на экран результата оплаты в приложении Магнит. - На кассе/КСО получает сообщение об успешной оплате. Нефункциональные требования: - DAU = 1000 в магазине - Кол-во магазинов 500 - Количество касс - 5 касс в среднем. - Оплата должна происходить за максимум 2 минуты. - Страница оплаты должна открываться максимум 250мс.

Компании, где спрашивали
ArendadataArendadata

Ответ от нейросети

sobes.tech AI

Для реализации системы оплаты с помощью мобильного приложения, не используя СБП, можно предложить следующую архитектуру:

  1. Идентификация пользователя на кассе/КСО:

    • Касса/КСО генерирует уникальный QR-код с информацией о покупке и идентификатором транзакции.
    • Пользователь сканирует QR-код в приложении Магнит.
  2. Переход в приложение Магнит:

    • Приложение Магнит получает данные о покупке и предлагает выбрать банк для оплаты.
  3. Оплата через банк:

    • Приложение Магнит инициирует переход в приложение банка с передачей параметров оплаты (сумма, идентификатор транзакции).
    • Пользователь подтверждает оплату в приложении банка.
  4. Подтверждение оплаты:

    • Банк отправляет уведомление о статусе оплаты в backend Магнита.
    • Backend Магнита обновляет статус транзакции.
    • Касса/КСО получает уведомление о успешной оплате через push-сообщение или polling.
  5. Отображение результата:

    • Приложение Магнит показывает результат оплаты.
    • Касса/КСО завершает процесс покупки.

Нефункциональные требования:

  • Для обеспечения DAU 1000 на магазин и 500 магазинов с 5 кассами каждая, система должна быть масштабируемой и распределённой.
  • Использовать кэширование и быстрые очереди сообщений для минимизации задержек.
  • Оптимизировать генерацию и обработку QR-кодов.
  • Страница оплаты должна загружаться не более 250 мс — использовать CDN, минимизировать запросы.
  • Время оплаты до 2 минут — предусмотреть асинхронные уведомления и таймауты.

Такой подход обеспечивает безопасность, масштабируемость и удобство для пользователя.