Разработка мобильного криптокошелька (кастодиальный)

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

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Разработка мобильного криптокошелька (кастодиальный)
Сложная
от 2 недель до 3 месяцев
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • 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
    874
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Разработка мобильного криптокошелька (кастодиальный)

В кастодиальном кошельке приватные ключи пользователей хранятся на стороне оператора. Это фундаментальное отличие от некастодиального: пользователь доверяет оператору управление своими активами, оператор берёт на себя ответственность за безопасность. Именно такую модель используют большинство централизованных бирж (Coinbase, Binance) и корпоративных крипто-решений.

Технически проще для пользователя — не нужно беречь seed-фразу, есть привычное восстановление через email. Но требования к безопасности серверной инфраструктуры и регуляторная нагрузка — несравнимо выше.

Архитектура хранения ключей

Хранить приватные ключи пользователей в обычной базе данных — это приговор при первом же взломе. Правильная архитектура:

HSM (Hardware Security Module). Физическое устройство, которое генерирует, хранит и использует ключи — они никогда не выходят за пределы HSM. Подписание транзакций происходит внутри HSM: приложение отправляет транзакцию, HSM возвращает подписанную транзакцию, ключ не экспортируется. Популярные решения: Thales Luna, AWS CloudHSM, Azure Dedicated HSM.

KMS (Key Management Service). Облачный аналог: AWS KMS, Google Cloud KMS, Azure Key Vault. Ключи не экспортируются, операции подписания через API. Дешевле HSM, проще в масштабировании, но ключи в облаке провайдера — регуляторные ограничения для некоторых юрисдикций.

MPC (Multi-Party Computation). Современный подход: приватный ключ никогда не существует целиком в одном месте. Несколько участников (серверные узлы) имеют шарды ключа, подписание происходит через MPC-протокол без реконструкции ключа. Fireblocks, Fordefi, ZenGo используют этот подход. Устойчиво к компрометации одного узла.

Схема холодного/горячего хранения. Большинство средств — в холодном хранилище (offline HSM, hardware wallets). Горячий кошелёк (online) — только операционный запас для обработки текущих выводов. Соотношение 95/5 или 98/2 — отраслевой стандарт для бирж.

Серверная архитектура транзакций

Клиентское приложение не подписывает транзакции — оно только инициирует запрос. Флоу:

  1. Пользователь вводит параметры вывода в мобильном приложении
  2. Приложение отправляет запрос на бэкенд с аутентификацией (JWT + 2FA)
  3. Бэкенд валидирует: достаточно ли средств, не превышены ли лимиты, не в whitelist ли адрес
  4. Запрос ставится в очередь на подписание (не автоматически — может быть ручная или автоматическая апробация)
  5. Signing service запрашивает HSM/KMS подписать транзакцию
  6. Подписанная транзакция уходит в блокчейн-узел
  7. Мониторинг подтверждений, уведомление пользователя

Очередь транзакций — не просто async processing. Это защита от параллельных атак: два запроса на вывод одного баланса не должны оба пройти. Оптимистичная блокировка или pessimistic lock на уровне аккаунта при инициации вывода.

Аккаунтинг: UTXO vs account-based

Для Ethereum-совместимых сетей — account-based модель. Один адрес на пользователя или адрес-пул с account mapping:

  • Dedicated address: каждый пользователь получает уникальный депозитный адрес → проще идентификация входящих, дороже в gas при консолидации
  • Shared address + memo/tag: один депозитный адрес, идентификация через memo (как XRP, TON) или calldata

Для Bitcoin — UTXO. Каждый UTXO принадлежит конкретному пользователю или требует address-transaction mapping. Конкретный Bitcoin адрес для каждого депозита, sweep UTXO на холодный кошелёк по расписанию.

Внутренняя база аккаунтинга должна давать мгновенные балансы без блокчейн-запроса. Все операции — в внутренней БД, блокчейн — финальное подтверждение. Это как в банке: внутренняя бухгалтерская система не ждёт Fedwire для каждого запроса баланса.

Мобильный клиент: особенности кастодиальной модели

Для пользователя кастодиальный кошелёк ближе к банковскому приложению, чем к MetaMask. Функционал:

  • Регистрация/логин с KYC (если требуется регулятором)
  • Балансы по активам в реальном времени (WebSocket для live updates)
  • История транзакций с фильтрами
  • Отправка (с адресной книгой, QR-сканером, whitelist адресов)
  • Получение (QR с адресом, мониторинг входящих)
  • Swap между активами (через внутренний движок или агрегатор)

Биометрическая аутентификация на устройстве — для подтверждения операций, но сам ключ она не защищает (ключи на сервере). Здесь биометрия защищает сессию приложения.

KYC и AML — регуляторная обязанность

Кастодиальный кошелёк в большинстве юрисдикций — финансовый сервис. VASP (Virtual Asset Service Provider) по FATF Recommendations. Это означает:

  • KYC (Know Your Customer): верификация личности, документы, selfie liveness check. Интеграция с провайдерами: Sumsub, Onfido, Jumio, Veriff
  • AML screening: проверка транзакций против санкционных списков (OFAC, EU), блокировка известных миксеров и darknet адресов. Провайдеры: Chainalysis, Elliptic, TRM Labs
  • Travel Rule (FATF Recommendation 16): при переводах > $1000 нужно передавать данные отправителя/получателя между VASP. Протоколы: TRP, OpenVASP, TRISA

Без этого в ЕС, США, большинстве развитых стран — нельзя законно работать. Интеграция KYC/AML — обязательный этап, не опциональный.

Push-уведомления и мониторинг

Мониторинг входящих транзакций — через webhook от блокчейн-провайдера (Alchemy Webhooks, Moralis Streams, QuickNode Streams) или собственный event listener. При подтверждении депозита — зачислить на внутренний баланс, отправить push через FCM/APNs.

Уведомления о подозрительной активности: вход с нового устройства, вывод крупной суммы, смена email — немедленный push + email.

Сроки и этапы

MVP кастодиального кошелька (один блокчейн, базовые операции, KMS вместо HSM, упрощённый KYC) — 2–3 месяца. Полноценная система с HSM/MPC, мультичейн поддержкой, AML интеграцией, регуляторной отчётностью — 6–12 месяцев командой. Регуляторная часть (получение лицензии VASP) — параллельный процесс, сроки зависят от юрисдикции. Стоимость рассчитывается после анализа требований: количество блокчейнов, юрисдикции, объём KYC/AML, требования к инфраструктуре безопасности.