Перейти к основному содержимому
Версия: 3.6.0

Покупки в приложении

Автоматическая верификация и отправка информации о покупке

к сведению

Начиная с Appodeal SDK 3.7.0+, появилась возможность автоматически верефицировать и отправлять информацию о покупках/подписках в Appodeal, а также получать информацию о покупках из Appodeal SDK с помощью Appsflyer.

Чтобы активировать эту функцию, свяжитесь с нами по электронной почте support@appodeal.com или в чате и попросите включить функцию roi360.

примечание

Автоматическая проверка покупок работает с версиями Google Play Billing Library 5-7.

Добавьте следующую зависимость в build.gradle на уровне модуля:.

buildscript {
dependencies {
// ... остальные зависимости проекта
implementation("com.android.billingclient:billing:5.0.0")
// или
implementation("com.android.billingclient:billing-ktx:5.0.0")
}
}

Для автоматической проверки покупок вам необходимо сгенерировать и предоставить нашей команде JSON-ключ из Google Cloud Platform, а также настроить возможность получения информации о покупках из Google Play Developer Console.

Для этого вам необходимо выполнить следующие шаги:

Шаг 1. Свяжите аккаунт разработчика Google Play с проектом Google Cloud.

  • В Google Play Console перейдите к своему аккаунту разработчика Google Play.
  • Свяжите аккаунт с проектом Google Cloud. Инструкции в этой справке Google.
  • Включите Google Play API для разработчиков. Инструкции в этой справке Google.

Шаг 2. Настройка учетной записи службы в облачной платформе Google

Необходимые условия: Доступ к Google Cloud Platform.

Чтобы настроить учетную запись службы:

2.1 Создайте или найдите аккаунт службы:

  1. В Google Cloud Platform перейдите в раздел Service accounts и нажмите Create Service Account.
  1. Заполните данные учетной записи сервиса.
  1. Скопируйте адрес электронной почты и нажмите Create and continue.
примечание

Это письмо вы должны пригласить в Google Play Console (см. ниже).

  1. На шаге Grant this service account access to the project выберите роль подписчика Pub/sub, после чего нажмите кнопку Done.

2.2 Загрузите json ключ сервисного аккаунта:

В Google Cloud Platform перейдите в раздел Service accounts, найдите нужный вам аккаунт (тот, который вы только что создали) в списке и нажмите на значок More actions.

  1. Нажмите Manage keys.
  1. Нажмите Add key > Create new key.
  1. Во всплывающем окне Create private key в разделе Key type, выберите JSON и нажмите Create.
  1. Нажмите Create. JSON ключ будет загружен.

Сохраните файл ключа JSON, который позже будет загружен в AppsFlyer.

:::примечание Вы должны сохранить ключ; позже его нельзя будет получить. Если вы не сохраните его, вам придется создать совершенно новый ключ. Пожалуйста, поделитесь этим JSON-файлом с командой Appodeal. Он понадобится нам для подключения Google Play Console к нашему аккаунту Appsflyer. :::

Шаг 3. Настройка разрешений доступа к API в Google Play Console

Необходимые условия: Доступ к Google Play Console.

примечание

После установки учетных данных и разрешений учетной записи службы может пройти некоторое время (иногда даже 24 часа). чтобы получить возможность их использовать. Это может привести к появлению ошибок на последующих шагах.

Чтобы предоставить доступ к API в Google Play Console:.

  1. В Консоли Google Play перейдите в раздел Users and permissions, найдите созданный вами аккаунт службы и нажмите Invite new users.
  1. Введите Email address, который вы скопировали при настройке учетной записи службы в шаге 2.1.3.
  1. В разделе Permissions перейдите на вкладку Account permissions и выберите следующее:
  • View app information and download bulk reports(read-only)

  • View financial data, orders, and cancellation survey responses.

  • Manage orders and subscriptions.

  1. Нажмите Invite user.
  2. В всплывающем окне нажмите Send invite.

Шаг 4. Отправка уведомлений Google Play непосредственно в AppsFlyer

Необходимые условия: Доступ к Google Play Console и пользовательскому интерфейсу AppsFlyer.

  1. В разделе Google Play Console > Home выберите просмотр вашего приложения. Откроется приборная панель.
  1. Перейдите в раздел Monetize with Play > Monetization setup и в разделе Google Play Billing section убедитесь, что Enable real-time notification.
  1. В поле Topic name вставьте адрес AppsFlyer: projects/appsflyer-ars/topics/subscription-events.
  1. Для Notification content, выберите Subscriptions, voided purchases, and all one-time products.
  1. Нажмите Save changes.
примечание

Для того чтобы изменения вступили в силу, может потребоваться время (иногда даже 24 часа). Поэтому подождите, прежде чем тестировать.

Шаг 5. Свяжитесь с нами

После выполнения всех шагов свяжитесь с нашей службой поддержки по электронной почте support@appodeal.com или в чате, предоставив следующую информацию:

  1. Приложение, для которого вы хотите включить функцию roi360.
  2. JSON-файл учетной записи сервиса из Шага 2.2;

Дополнительно. Шаг 6 Настройка обратного вызова AppodealPurchaseCallback

После включения и настройки автоматической верификации покупок, когда в вашем приложении будет совершена покупка через библиотеку Google Billing, Appodeal SDK будет автоматически определять, верефицировать и отправлять данные о покупке в приложении/подписке в Appodeal Dashboard. Если вы хотите получать информацию о покупке в своем приложении, вам просто нужно вызвать метод:

Appodeal.setPurchaseListener(object: AppodealPurchaseListener{
override fun onPurchaseReceived(successPurchases: List<Map<String, Any>>) {
Log.d("Appodeal App", "onPurchaseReceived: $successPurchases");
}

override fun onPurchaseFailed(reason: Throwable, failedPurchases: List<Map<String, Any>>?) {
Log.d("Appodeal App", "Message: ${reason.message} failedPurchases: $failedPurchases");
}
})

Объект покупки, который вы получаете в onPurchaseReceived/onPurchaseFailed, представляет собой список объектов

  • для InApps покупки:
ПараметрОписание
purchase_tokenТокен полученной покупки
product_idsСписок идентификаторов покупки
product_typeТип покупки inapp/subs
purchase_timeВременная метка покупки
package_nameПакет приложения, в котором была совершена покупка
one_time_purchase_offer_detailsMap деталей покупки, содержит «formatted_price», long «price_amount_micros», «price_currency_code»
quantityКоличество элементов покупки
order_idИдентификатор заказа полученной покупки
region_codeКод страны полученной покупки
  • для Subscription покупки:
ПараметрОписание
purchase_tokenТокен полученной подписки
product_idsСписок идентификаторов подписки
product_typeТип покупки inapp/subs
purchase_timeTimestamp покупки
subscription_offer_detailsСписок карт, содержащих детали предложений подписки, такие как «base_plan_id», «offer_tags», «offer_token», «pricing_phases»
package_nameПакет приложения, в котором была совершена покупка
one_time_purchase_offer_detailsMap деталей покупки, содержит «formatted_price», long «price_amount_micros», «price_currency_code»
latest_order_idИдентификатор заказа полученной подписки
subscription_stateТекущее состояние описания, например: active
start_timeДата начала подписки
expiry_timeДата истечения срока действия подписки

На этом подключение автоматических покупок полностью завершено.

примечание

Отчеты о покупках будут автоматически загружаться в Личный кабинет 2 раза в день

Ручная верификация и отправка информации о покупке

к сведению

Отслеживание покупок в приложении будет работать только при подключении к Adjust или AppsFlyer. Чтобы подключить их, следуйте этому руководству для Adjust и этому руководству для AppsFlyer.

Можно отслеживать информацию о покупках в приложении и отправлять информацию на серверы Appodeal для аналитики. Это позволяет группировать пользователей по факту покупки. Это поможет вам настроить рекламу для таких пользователей или просто отключить ее, если это необходимо. Чтобы эта настройка работала правильно, отправьте информацию о покупке через Appodeal SDK.

Шаг 1. Отслеживание Покупок В Приложении

Чтобы отслеживать покупки в приложении, Appodeal SDK потребуется информация о покупке, предоставляемая Google Play Billing Library

Добавьте следующую зависимость в файл build.gradle на уровне модуля:

buildscript {
dependencies {
// ... остальные зависимости проекта
implementation("com.android.billingclient:billing:5.0.0")
// или
implementation("com.android.billingclient:billing-ktx:5.0.0")
}
}

Получите объекты Purchase и SkuDetails из Google Play Billing Library используя это руководство. Получите цену и валюту из SkuDetails.

Создайте и подтвердите покупку в приложении используя метод ниже:

// Объект покупки возвращается Google API в обратном вызове onPurchasesUpdated()
fun validatePurchase(purchase: Purchase) {
// Создаем новую InAppPurchase с типом
val inAppPurchase: InAppPurchase = InAppPurchase.newBuilder(type = InAppPurchase.Type.InApp)
.withPublicKey("YOUR_PUBLIC_KEY")
.withSignature(purchase.signature)
.withPurchaseData(purchase.originalJson)
.withPurchaseToken(purchase.purchaseToken)
.withPurchaseTimestamp(purchase.purchaseTime)
.withDeveloperPayload(purchase.developerPayload)
.withOrderId(purchase.orderId)
.withSku(...) // Идентификатор единицы хранения из Google API
.withPrice(...) // Цена
.withCurrency(...) // Валюта
.withAdditionalParams(...) // Appodeal In-app event при необходимости
.build()
// Валидация покупки
Appodeal.validateInAppPurchase(context = context, purchase = inAppPurchase, callback = object : InAppPurchaseValidateCallback {
override fun onInAppPurchaseValidateSuccess(purchase: InAppPurchase, errors: List<ServiceError>?) {
// Валидация покупки в приложении была успешно подтверждена как минимум одним подключенным сервисом
}
override fun onInAppPurchaseValidateFail(purchase: InAppPurchase, errors: List<ServiceError>) {
// Валидация покупки в приложении была завершена с ошибкой всеми подключенными сервисами
}
})
}
к сведению

Убедитесь, что если вы создали продукт в приложении в разделе Google Play Console → Монетизация, то используете:

  • InAppPurchase.Type.InApp - для покупки в приложении
  • InAppPurchase.Type.Subs - для подписки в приложении
ParameterDescriptionUsage
purchaseTypeТип покупки. Должен быть InAppPurchase.Type.InApp или InAppPurchase.Type.Subs.Adjust/AppsFlyer
publicKeyПубличный ключ из Google Developer Console.AppsFlyer
signatureПодпись транзакции (возвращается из Google API после завершения покупки).Adjust/AppsFlyer
purchaseDataПродукт, приобретенный в формате JSON (возвращается из Google API после завершения покупки).AppsFlyer
purchaseTokenТокен приобретенного продукта (возвращается из Google API после завершения покупки).Adjust
purchaseTimestampОтметка времени покупки продукта (возвращается из Google API после завершения покупки).Adjust
developerPayloadПолезная нагрузка разработчика в приобретенном продукте (возвращается из Google API после завершения покупки).Adjust
orderIdУникальный идентификатор заказа для транзакции приобретенного продукта (возвращается из Google API после завершения покупки).Adjust
skuИдентификатор единицы хранения из Google API.Adjust
priceДоход от события в приложении.Adjust/AppsFlyer/Appodeal
currencyВалюта события в приложении.Adjust/AppsFlyer/Appodeal
additionalParametersДополнительные параметры внутриигрового события.
Проверка покупки в приложении выполняется по FIFO-очереди в одном потоке.
примечание

Если вы используете ваш собственный Adjust аккаунт вам необходимо выполнить Шаг 2 из этого руководства по Отслеживанию событий и создать необходимые события на стороне Adjust.

Шаг 2. Создайте Файл Json В Google Cloud

  1. Войдите в Google Cloud со своими учетными данными;
  2. Выберите Google Play Console Developer project в левом верхнем углу, как показано ниже.
примечание

Убедитесь, что на этом шаге выбран Google Play Console Developer project, а не конкретный проект вашего приложения. Google Play Console позволяет связывать только облачные проекты Google Play Console Developer (позже на шаге 3).

  1. Выберите CredentialsCreate CredentialsService Account;
  2. Выберите Viewer в качестве роли для Service Account и нажмите Done;
  3. Перейдите в ваш service account и нажмите keys → Add key → выберите JSON → отправьте нам файл JSON на электронную почту support@appodeal.com или в чате.

Шаг 3. Добавьте Необходимые Разрешения В Google Play Console

  1. Перейдите в ** Google Play Console** и авторизуйтесь;

  2. Перейдите в Google Play Console → Manage developer accounts → Выберите Developer account →
    Setup → API Access и выберите свой проект Google Play Console Developer из шага 2, где вы создали свой Service Account;

Если вы не видите Google Play Console Developer project в списке, обновите веб-страницу.

подсказка

Если проблема не устранена, убедитесь, что ваша учетная запись разработчика Google Play (адрес электронной почты) является владельцем проекта Google Cloud. Вы можете прочитать больше здесь.

  1. Внизу будет список ваших Service Accounts, которые доступны в этом проекте Google Cloud. Выберите тот, с которого был отправлен JSON;

Нажмите Refresh, если вы не видите свою учетную запись Service Account.

  1. Выберите View Play Console Permissions. В разделе App Permissions выберите необходимые приложения, в которых будут использоваться внутренние события;

  2. Перейдите в раздел Account Permissions и выберите все разрешения для Financial Data:

  • View financial data
  • Manage Orders, subscriptions

Шаг 4. Свяжитесь С Нами

После выполнения всех шагов свяжитесь с нашей службой поддержки по электронной почте support@appodeal.com или в чате со следующей информацией:

  1. JSON-файл вашего Service Account;
  2. Логика реализации покупок в вашем приложении (когда и где вы вызываете метод валидации покупок и валидируете покупки);
  3. Предоставьте нам доступ для тестирования покупки через Google Developer console по электронной почте support@appodeal.com;
  4. Ваш apk файл в архиве zip для тестирования.

Шаг 5. Тестирование

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

  1. Перейдите по пути App Settings → Attribution Settings → и измените Adjust Environment с Production на Sandbox, чтобы протестировать валидацию покупок и не забудьте нажать Save в конце страницы;
  1. Подключите ваше устройство к компьютеру с открытой консолью (Android Studio logcat) и отсортируйте логи по слову purchase;
  1. Теперь вы можете открыть свое приложение и совершить пробную покупку. Если в консоли отображается надпись Valid Purchase, значит, валидация прошла успешно;

  2. Если валидация не прошла успешно, то повторите все шаги, описанные выше, и убедитесь, что предоставленный JSON файл корректный и все шаги выполнены;

  3. После тестирования, смените ваш Adjust Environment на Production по пути App Settings → Attribution Settings.