Обработка ошибок в React Native SDK

Каждая ошибка, возвращаемая SDK, имеет тип AdaptyErrorCode. Пример:

Включите подробные логи перед отладкой. Большинство AdaptyError оборачивают ошибку StoreKit, Play Billing, сети или бэкенда. При включённых verbose-логах (adapty.setLogLevel('verbose') — см. Логирование для pure RN или Expo) эта ошибка выводится в консоль, что обычно сразу указывает на причину.

Если эти решения не помогли, перейдите к разделу Другие проблемы — там описаны шаги, которые нужно предпринять перед обращением в поддержку, чтобы мы могли помочь вам эффективнее.

try {
  const params: MakePurchaseParamsInput = {};
  await adapty.makePurchase(product, params);
} catch (error) {
  if (
    error instanceof AdaptyError &&
    error.adaptyCode === getErrorCode(ErrorCode['2'])
  ) {
    // payment cancelled
  }
}

Системные коды StoreKit

ОшибкаКодРешение
unknown0Код ошибки, указывающий на возникновение неизвестной или непредвиденной ошибки.
Повторите попытку или обратитесь к разделу Другие проблемы.
clientInvalid1Этот код ошибки означает, что клиенту не разрешено выполнять запрошенное действие.
paymentCancelled2

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

Никаких действий не требуется, однако с точки зрения бизнес-логики вы можете предложить пользователю скидку или напомнить о покупке позже.

paymentInvalid3Эта ошибка означает, что один из параметров платежа не был распознан App Store.
paymentNotAllowed4Этот код ошибки означает, что пользователю не разрешено авторизовывать платежи.
storeProductNotAvailable5Этот код ошибки означает, что запрошенный продукт недоступен в сторе.
Попробуйте переустановить приложение.
cloudServicePermissionDenied6Этот код ошибки означает, что пользователь не предоставил доступ к информации облачного сервиса.
cloudServiceNetworkConnectionFailed7Этот код ошибки означает, что устройству не удалось подключиться к сети.
cloudServiceRevoked8Этот код ошибки означает, что пользователь отозвал разрешение на использование этого облачного сервиса.
privacyAcknowledgementRequired9Этот код ошибки означает, что пользователь ещё не принял политику конфиденциальности Apple.
unauthorizedRequestData10Этот код ошибки означает, что приложение пытается использовать свойство, для которого у него нет необходимых прав доступа.
invalidOfferIdentifier11

Идентификатор предложения недействителен. Например, вы не создали предложение с таким идентификатором в App Store или отозвали его.

Убедитесь, что нужные предложения настроены в AppStore Connect, и передайте корректный идентификатор предложения.

invalidSignature12Этот код ошибки означает, что подпись в скидке на оплату недействительна.
missingOfferParams13Этот код ошибки означает, что в скидке на оплату отсутствуют обязательные параметры.
invalidOfferPrice14Этот код ошибки означает, что указанная вами в App Store Connect цена больше не является действительной. Предложения всегда должны представлять собой сниженную цену.

Кастомные коды ошибок Android

ОшибкаКодРешение
adaptyNotInitialized20Необходимо правильно настроить Adapty SDK с помощью метода Adapty.activate. Узнайте, как это сделать для React Native.
productNotFound22Эта ошибка означает, что запрошенный для покупки продукт недоступен в сторе.
invalidJson23JSON пейвола невалиден. Исправьте его в дашборде Adapty. Подробнее см. в разделе Настройка пейвола с помощью Remote Config.
currentSubscriptionToUpdateNotFoundInHistory24Исходная подписка, которую нужно продлить, не найдена.
pendingPurchase25Эта ошибка означает, что покупка находится в состоянии ожидания, а не завершена. Подробнее см. на странице Handling pending transactions в документации Android Developer.
billingServiceTimeout97Эта ошибка означает, что запрос превысил максимальное время ожидания ответа от Google Play. Причиной может быть, например, задержка выполнения действия, запрошенного вызовом Play Billing Library.
featureNotSupported98Запрошенная функция не поддерживается Play Store на текущем устройстве.
billingServiceDisconnected99Эта критическая ошибка означает, что соединение клиентского приложения с сервисом Google Play Store через BillingClient было разорвано.
billingServiceUnavailable102Эта временная ошибка означает, что сервис Google Play Billing в данный момент недоступен. В большинстве случаев это связано с проблемой сетевого соединения между клиентским устройством и сервисами Google Play Billing.
billingUnavailable103

Эта ошибка означает, что в процессе покупки произошла ошибка на стороне пользователя. Возможные причины:

1. Приложение Play Store на устройстве пользователя устарело.

2. Пользователь находится в неподдерживаемой стране.

3. Пользователь является корпоративным, и администратор заблокировал покупки.

4. Google Play не может списать средства с платёжного метода пользователя. Например, срок действия кредитной карты истёк.

5. Пользователь не авторизован в приложении Play Store.

developerError105Критическая ошибка, указывающая на некорректное использование API.
billingError106Критическая ошибка, указывающая на внутреннюю проблему в самом Google Play.
itemAlreadyOwned107Расходуемая покупка уже была приобретена.
itemNotOwned108Эта ошибка означает, что запрошенное действие над элементом завершилось неудачно, так как

Пользовательские коды StoreKit

ОшибкаКодРешение
noProductIDsFound1000

Эта ошибка означает, что ни один из продуктов, запрошенных на пейволе, недоступен для покупки в App Store, хотя они там и числятся. Иногда ошибка сопровождается предупреждением InvalidProductIdentifiers. Если предупреждение появляется без ошибки — его можно игнорировать.

Если вы столкнулись с этой ошибкой, следуйте инструкциям в разделе Исправление ошибки Code-1000 noProductIDsFound.

productRequestFailed1002

Не удалось получить список доступных продуктов. Возможная причина:

- Кэш ещё не создан, и при этом отсутствует интернет-соединение.

cantMakePayments1003Встроенные покупки запрещены на этом устройстве. См. гайд по устранению проблемы.
noPurchasesToRestore1004Эта ошибка означает, что Google Play не нашёл покупку для восстановления.
cantReadReceipt1005

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

Никаких действий не требуется, однако с точки зрения бизнес-логики вы можете предложить пользователю скидку или напомнить об этом позже.

productPurchaseFailed1006Покупка продукта не удалась. Эта ошибка оборачивает исходную ошибку StoreKit — прочитайте её (или включите подробное логирование, чтобы увидеть в консоли) для выяснения реальной причины. Обёрнутая ошибка, как правило, является одним из кодов StoreKit 0–14 из таблицы выше — чаще всего это paymentCancelled, paymentInvalid, paymentNotAllowed или invalidOfferPrice. Если определить конкретную причину не удаётся, попробуйте новый профиль песочницы; если проблема сохраняется — обратитесь в поддержку Apple.
refreshReceiptFailed1010Эта ошибка означает, что чек не был получен. Применимо только к StoreKit 1.
receiveRestoredTransactionsFailed1011Восстановление покупок не удалось.

Пользовательские сетевые коды

ОшибкаКодРешение
notActivated2002SDK Adapty не активирован.
Чаще всего возникает, когда сплэш-экран или ранний UI-хук вызывает методы Adapty до того, как adapty.activate завершится. Симптом непостоянный и может не воспроизводиться на симуляторе, потому что тайминги на реальном устройстве отличаются. Используйте await для activate перед вызовом любых других методов SDK. Полная последовательность описана в разделе Порядок вызовов в React Native SDK.
badRequest2003Некорректный запрос.
Убедитесь, что вы выполнили все шаги, необходимые для интеграции с App Store.
serverError2004Ошибка сервера.
Повторите попытку через некоторое время. Если проблема не исчезнет, обратитесь в службу поддержки Adapty.
networkFailed2005Ошибка указывает на проблемы с сетевым подключением на устройстве пользователя.
Попробуйте отключить VPN или переключиться с мобильной сети на Wi-Fi (или наоборот).
decodingFailed2006Ошибка указывает на сбой декодирования ответа.
Проверьте свой код и убедитесь, что передаваемые параметры корректны. Например, эта ошибка может означать, что вы используете недействительный API-ключ.
encodingFailed2009Ошибка указывает на сбой кодирования запроса.
missingURL2010Запрошенный URL равен nil.
analyticsDisabled3000Невозможно обработать события аналитики, так как вы отключили её.
wrongParam3001Ошибка указывает на некорректные параметры.
Если вы используете Paywall Builder и не можете отобразить пейвол из-за этой ошибки, включите Show on device в Paywall Builder.
Другая возможная причина — версия локального файла резервного пейвола не совпадает с версией SDK. Скачайте новый файл в дашборде.
activateOnceError3005Метод .activate нельзя вызывать более одного раза.
profileWasChanged3006Профиль пользователя был изменён во время операции.
Это происходит, когда метод вызывается в то время, пока adapty.identify ещё выполняется — незавершённый вызов попадает на профиль, который вот-вот будет заменён, и SDK отклоняет его. Всегда используйте await для identify перед любым пользовательским вызовом. Подробнее в разделе Порядок вызовов в React Native SDK.
unsupportedData3007Ошибка указывает на то, что формат данных не поддерживается SDK.
persistingDataError3100Произошла ошибка при сохранении данных.
fetchTimeoutError3101Ошибка указывает на превышение времени ожидания операции получения данных.

Другие проблемы

Если вы ещё не нашли решение, попробуйте следующее:

  • Обновите SDK до последней версии: мы всегда рекомендуем обновляться до последних версий SDK, так как они более стабильны и содержат исправления известных проблем.
  • Обратитесь в поддержку или получите помощь от других разработчиков на форуме поддержки.
  • Напишите в поддержку на [email protected] или в чат: если вы не готовы обновить SDK или обновление не помогло, обратитесь в нашу службу поддержки. Обратите внимание: проблема решится быстрее, если вы включите подробное логирование и поделитесь логами с командой. Также можно приложить соответствующие фрагменты кода.