Назад к вопросам
Arendadata
Principal
24
Система оплаты с помощью телефона Необходимо реализовать архитектуру, где клиент может оплачивать покупки на кассе/КСО (касса самообслуживания) с помощью мобильного приложения. Оплата происходит НЕ по СБП. Пользователь покупая товары, выбирает оплатить с помощью приложения. Касса или КСО должны определить пользователя и запускается процесс оплаты с помощью банка клиента. СJM: - Кассир/клиент сканирует товары. - Переходит к оплате. - Идентифицируется на кассе/КСО. - Выбирает оплатить в приложении Магнит. - Переходит в приложение Магнит. - Выбирает установленный на телефоне банк с которого происходит оплата. - В приложении банка оплачивает покупку. - Возвращается на экран результата оплаты в приложении Магнит. - На кассе/КСО получает сообщение об успешной оплате. Нефункциональные требования: - DAU = 1000 в магазине - Кол-во магазинов 500 - Количество касс - 5 касс в среднем. - Оплата должна происходить за максимум 2 минуты. - Страница оплаты должна открываться максимум 250мс.
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Для реализации системы оплаты с помощью мобильного приложения, не используя СБП, можно предложить следующую архитектуру:
-
Идентификация пользователя на кассе/КСО:
- Касса/КСО генерирует уникальный QR-код с информацией о покупке и идентификатором транзакции.
- Пользователь сканирует QR-код в приложении Магнит.
-
Переход в приложение Магнит:
- Приложение Магнит получает данные о покупке и предлагает выбрать банк для оплаты.
-
Оплата через банк:
- Приложение Магнит инициирует переход в приложение банка с передачей параметров оплаты (сумма, идентификатор транзакции).
- Пользователь подтверждает оплату в приложении банка.
-
Подтверждение оплаты:
- Банк отправляет уведомление о статусе оплаты в backend Магнита.
- Backend Магнита обновляет статус транзакции.
- Касса/КСО получает уведомление о успешной оплате через push-сообщение или polling.
-
Отображение результата:
- Приложение Магнит показывает результат оплаты.
- Касса/КСО завершает процесс покупки.
Нефункциональные требования:
- Для обеспечения DAU 1000 на магазин и 500 магазинов с 5 кассами каждая, система должна быть масштабируемой и распределённой.
- Использовать кэширование и быстрые очереди сообщений для минимизации задержек.
- Оптимизировать генерацию и обработку QR-кодов.
- Страница оплаты должна загружаться не более 250 мс — использовать CDN, минимизировать запросы.
- Время оплаты до 2 минут — предусмотреть асинхронные уведомления и таймауты.
Такой подход обеспечивает безопасность, масштабируемость и удобство для пользователя.