Разработка мобильного приложения для купонов и скидок
Приложение для купонов и скидок выглядит несложным до момента, когда нужно интегрировать геолокацию («скидки рядом со мной»), push-уведомления («ты в торговом центре — вот скидка»), партнёрские API торговых сетей и систему погашения купонов без мошенничества. Каждый из этих блоков имеет нетривиальные технические детали.
Геолокационные предложения
«Скидки рядом» — это либо простой запрос к API с текущими координатами, либо proximity marketing через геофенсинг.
Простой вариант: пользователь открывает приложение → текущие координаты → GET /offers?lat=55.75&lng=37.61&radius=1000. Работает только при открытом приложении.
Геофенсинг: приложение регистрирует геофенсы вокруг торговых точек-партнёров. При входе — push-уведомление с актуальными скидками этого магазина. На iOS — CLCircularRegion, лимит 20 регионов одновременно. Если партнёров 500 — нужна динамическая регистрация ближайших 20 при изменении местоположения.
Алгоритм: при значительном изменении местоположения (startMonitoringSignificantLocationChanges()) — запрос 20 ближайших магазинов, перерегистрация геофенсов. На Android — аналогично, но через GeofencingClient с лимитом 100 геофенсов.
BLE-beacon proximity (Eddystone, iBeacon): приложение обнаруживает маяки в магазине — push с персонализированным предложением. CoreBluetooth / Android BluetoothLeScanner. Требует от партнёра установки маяков, что усложняет B2B-продажу. Зато точность — метры, не сотни метров.
Отображение и фильтрация купонов
Список купонов — RecyclerView (Android) / LazyVStack (SwiftUI). Карточка купона: изображение, название магазина, размер скидки, срок действия, расстояние. Skeleton loading пока загружается.
Фильтры: категория, расстояние, процент скидки, онлайн/офлайн. Сортировка: по расстоянию, по размеру скидки, по сроку истечения. Всё на сервере — клиент только передаёт параметры фильтрации.
Карточный flip-анимация для раскрытия условий купона — CATransform3DMakeRotation (UIKit) / .rotation3DEffect (SwiftUI). Не обязательна, но выглядит живо.
Активация и погашение купонов без мошенничества
Это ключевая техническая задача. Купон нельзя сделать статичным QR-кодом — его можно сфотографировать и использовать многократно.
Одноразовый токен: при нажатии «использовать» — запрос к серверу, сервер генерирует JWT с exp: now + 300sec и used: false. QR-код с токеном показывается 5 минут. Кассир сканирует → сервер помечает used: true. Повторное сканирование — ошибка «купон уже использован».
Динамический QR: QR меняется каждые 30 секунд (TOTP-подход). Сервер знает текущее значение, кассир видит актуальный код. Сложнее в реализации, защита от скриншота.
Штрих-код магазина: пользователь показывает номер карты лояльности, скидка применяется на кассе автоматически. Требует интеграции с кассовым ПО партнёра.
Для большинства кейсов — одноразовый токен с 5-минутным lifetime достаточно.
Персонализация и категории
История купонов пользователя → ML-рекомендации (опционально). Простой вариант без ML: категории интересов в профиле, push только по интересующим категориям. Пользователь выбрал «кафе» и «спорт» — не получает купоны на одежду.
Избранные магазины: подписка на скидки конкретного партнёра. При появлении нового купона — push-уведомление с deep link на карточку купона.
Интеграция с партнёрами
Партнёрский кабинет (веб) — отдельная тема. Мобильная часть только потребляет API. Но API должно поддерживать разные модели купонов: процентная скидка, фиксированная сумма, «купи N получи M», бонусные баллы.
Кешбэк — если пользователь показал купон, кассир подтвердил через партнёрский терминал → приложение начисляет баллы. Баланс баллов в приложении, история начислений, вывод или обмен на купоны.
Стек: Flutter или React Native, Google Maps SDK для карты с магазинами, Firebase Cloud Messaging для push, Mapbox для геофенсинга (или нативные API), CoreBluetooth / BLE для beacon.
Срок: от 8 до 14 недель. Стоимость рассчитывается индивидуально.







