Покупки в приложении
Отслеживание покупок в приложении будет работать только при подключении к Adjust или AppsFlyer. Чтобы подключить их, следуйте этому руководству для Adjust и этому руководству для AppsFlyer.
Можно отслеживать информацию о покупках в приложении и отправлять информацию на серверы Appodeal для аналитики. Это позволяет группировать пользователей по факту покупки. Это поможет вам настроить рекламу для таких пользователей или просто отключить ее, если это необходимо. Чтобы эта настройка работала правильно, отправьте информацию о покупке через Appodeal SDK.
Шаг 1. Отслеживание Покупок В Приложении
Чтобы отслеживать покупки в приложении, Appodeal SDK потребуется информация о покупке, предоставляемая Google Play Billing Library
Добавьте следующую зависимость в файл build.gradle на уровне модуля:
- Kotlin
- Groovy
buildscript {
dependencies {
// ... остальные зависимости проекта
implementation("com.android.billingclient:billing:5.0.0")
// или
implementation("com.android.billingclient:billing-ktx:5.0.0")
}
}
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.
Создайте и подтвердите покупку в приложении используя метод ниже:
- Kotlin
- Java
// Объект покупки возвращается 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 API в обратном вызове onPurchasesUpdated()
public void validatePurchase(Purchase purchase) {
// Создаем новую InAppPurchase с типом
InAppPurchase inAppPurchase = InAppPurchase.newBuilder("PURCHASE_TYPE")
.withPublicKey("YOUR_PUBLIC_KEY")
.withSignature(purchase.getSignature())
.withPurchaseData(purchase.getOriginalJson())
.withPurchaseToken(purchase.getPurchaseToken())
.withPurchaseTimestamp(purchase.purchaseTime)
.withDeveloperPayload(purchase.getDeveloperPayload())
.withOrderId(purchase.getOrderId())
.withSku(...) // Идентификатор единицы хранения из Google API
.withPrice(...) // Цена
.withCurrency(...) // Валюта
.withAdditionalParams(...) // Appodeal In-app event при необходимости
.build()
// Валидация покупки
Appodeal.validateInAppPurchase(this, inAppPurchase, new InAppPurchaseValidateCallback() {
@Override
public void onInAppPurchaseValidateSuccess(@NonNull InAppPurchase purchase, @Nullable List<ServiceError> errors) {
// Валидация покупки в приложении была успешно подтверждена как минимум одним подключенным сервисом }
}
@Override
public void onInAppPurchaseValidateFail(@NonNull InAppPurchase purchase, @NonNull List<ServiceError> errors) {
// Валидация покупки в приложении была завершена с ошибкой всеми подключенными сервисами
}
});
}
Убедитесь, что если вы создали продукт в приложении в разделе Google Play Console → Монетизация, то используете:
- InAppPurchase.Type.InApp - для покупки в приложении
- InAppPurchase.Type.Subs - для подписки в приложении
Parameter | Description | Usage |
---|---|---|
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 | Дополнительные параметры внутриигрового события. |
Если вы используете ваш собственный Adjust аккаунт вам необходимо выполнить Шаг 2 из этого руководства по Отслеживанию событий и создать необходимые события на стороне Adjust.
Шаг 2. Создайте Файл Json В Google Cloud
- Войдите в Google Cloud со своими учетными данными;
- Выберите Google Play Console Developer project в левом верхнем углу, как показано ниже.
Убедитесь, что на этом шаге выбран Google Play Console Developer project, а не конкретный проект вашего приложения. Google Play Console позволяет связывать только облачные проекты Google Play Console Developer (позже на шаге 3).
- Выберите Credentials → Create Credentials → Service Account;
- Выберите Viewer в качестве роли для Service Account и нажмите Done;
- Перейдите в ваш service account и нажмите keys → Add key → выберите JSON → отправьте нам файл JSON на электронную почту support@appodeal.com или в чате.
Шаг 3. Добавьте Необходимые Разрешения В Google Play Console
-
Перейдите в ** Google Play Console** и авторизуйтесь;
-
Перейдите в 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. Вы можете прочитать больше здесь.
- Внизу будет список ваших Service Accounts, которые доступны в этом проекте Google Cloud. Выберите тот, с которого был отправлен JSON;
Нажмите Refresh, если вы не видите свою учетную запись Service Account.
-
Выберите View Play Console Permissions. В разделе App Permissions выберите необходимые приложения, в которых будут использоваться внутренние события;
-
Перейдите в раздел Account Permissions и выберите все разрешения для Financial Data:
- View financial data
- Manage Orders, subscriptions
Шаг 4. Свяжитесь С Нами
После выполнения всех шагов свяжитесь с нашей службой поддержки по электронной почте support@appodeal.com или в чате со следующей информацией:
- JSON-файл вашего Service Account;
- Логика реализации покупок в вашем приложении (когда и где вы вызываете метод валидации покупок и валидируете покупки);
- Предоставьте нам доступ для тестирования покупки через Google Developer console по электронной почте support@appodeal.com;
- Ваш apk файл в архиве zip для тестирования.