Открытый SDK для интеграции покупок в приложении на Android

Реализуйте покупки в приложении за 30 минут.

Готовый бэкенд для Android покупок в приложении

Интеграция покупок в приложении требует создания бэкенд-инфраструктуры и сервера для событий подписки. Это может занять сотни часов работы и быть сложно поддерживать.
import StoreKit
class Store: ObservableObject {
    private var productIDs = ["stone"]
    @Published var products = [Product]()
    init() {
        Task {
            await requestProducts()
        }
    }  
    @MainActor
    func requestProducts() async {
        do {
            products = try await Product.products(for: productIDs)
        } catch {
            print(error)
    }
  }
}
Section(header: Text("To buy")) {
 }
ForEach(store.products, id: .id) {
  product in
    HStack {
      Text(product.displayName)
      Spacer()
      Button("(product.displayPrice)") {
    }
  }
}
@Published var purchasedNonConsumables = [Product]()
@MainActor
func purchase(_ product: Product) async throws -> Transaction ? {
  let result =
    try await product.purchase()
  switch result {
    case .success(.verified(let transaction)):
      purchasedNonConsumables.append(product)
      await transaction.finish()
      return transaction
    default:
      return nil
  }
}
Button("(product.displayPrice)") {
 Task {
  try await store.purchase(product)
  }
}
ProductView(
 icon: "❀",
 quantity: "(store.purchasedNonConsumables.count)"
 )
 func listenForTransactions() -> Task < Void, Error > {
  return Task.detached {
    for await result in Transaction.updates {
      switch result {
        case let.verified(transaction):
          guard
          let product = self.products.first(where: {
            $0.id == transaction.productID
          })
          else {
            continue
          }
          self.purchasedNonConsumables.append(product)
          await transaction.finish()
        default:
          continue
      }
    }
  }
}
var transacitonListener: Task<Void, Error>?
init() {
   transacitonListener = listenForTransactions()
   Task {
     await requestProducts()
 }
}
@MainActor
private func handle(transactionVerification result: VerificationResult <Transaction> ) async {
  switch result {
    case let.verified(transaction):
      guard
      let product = self.products.first(where: {
        $0.id == transaction.productID
      })
      else {
        return
      }
      self.purchasedNonConsumables.insert(product)
      await transaction.finish()
    default:
      return
  }
}
SDK Adapty позволяет интегрировать подписки в приложении в ваше iOS приложение с нашей готовой инфраструктурой, которая обрабатывает все события подписки и предлагает функции для увеличения дохода.
// Your app's code
Adapty.activate(this, "YOUR_APP_KEY")
 
// Make a purchase, Adapty handles the rest
Adapty.makePurchase(activity, product) { result ->
	when (result) {
		is AdaptyResult.Success -> {
			// successful purchase
		}
		is AdaptyResult.Error -> {
			// handle the error
		}
	}
}
От интеграции до обслуживания – Adapty создан для упрощения работы с IAP.
Запросить демонстрацию

Почему стоит выбрать SDK Adapty?

Корректное состояние подписки в любой момент

Будьте уверены, что вы всегда получите корректное состояние подписчика на всех платформах.

Валидация чеков на серверной стороне

Не беспокойтесь о корректности и безопасности валидации покупок.

Обработка всех видов состояний подписок

Бесплатные пробные версии, обновления, промо-оферы, семейный доступ, продления и многое другое.

Платформа, готовая для предприятий, с коротким циклом релиза

>99.99% надежность SLA и регулярные обновления продукта.
Настройка платформ
Установка SDK Adapty
Adapty.activate(
   "PUBLIC_SDK_KEY",
   customerUserId: "YOUR_USER_ID"
)
Обработка событий покупки

Быстрая и простая интеграция

Потратьте всего пару часов на интеграцию SDK Adapty в ваше iOS приложение, а мы позаботимся об остальном.

Всего 5 методов SDK для реализации Android покупок в приложении

Adapty.makePurchase(activity, product) { result ->
    when (result) {
        is AdaptyResult.Success -> {
            val info = result.value
            //NOTE: info is null in case of cross-grade with DEFERRED proration mode
            val profile = info?.profile
 
            if (profile?.accessLevels?.get("YOUR_ACCESS_LEVEL")?.isActive == true) {
                // grant access to premium features
            }
        }
        is AdaptyResult.Error -> {
            val error = result.error
            // handle the error
        }
    }
}
// Your app's code
Adapty.restorePurchases { [weak self] result in
    switch result {
        case let .success(profile):
            if info.profile.accessLevels["YOUR_ACCESS_LEVEL"]?.isActive ?? false {
	            // successful access restore
            }
        case let .failure(error):
            // handle the error
    }
}
&nbsp
// Your app's code
Adapty.identify("YOUR_USER_ID") { error ->
    if (error == null) {
        // successful identify
    }
}
 
 
 
 
 
 
// Your app's code
val builder = AdaptyProfileParameters.Builder()
    .with("Profile_Parameters")
 
Adapty.updateProfile(builder.build()) { error ->
    if (error != null) {
        // handle the error
    }
}
 
 
 
// Your app's code
Adapty.updateAttribution(attribution, AdaptyAttributionSource.CUSTOM) { error ->
    if (error != null) {
        //handle error
    }
}
 
 
 
 
 
 
Попробовать бесплатно

Люди из самых разных бизнесов обращаются к Adapty, чтобы увеличить свои доходы

Что вы получите с Adapty?

SDK Adapty предоставляет огромные возможности для увеличения дохода приложения

Аналитика в реальном времени для вашего Android приложения

Полагайтесь на данные с 99.5% точностью с App Store Connect.
Начать
App Icon Gravity
Gravity Fit
Здоровье и фитнес
“Прозрачные и продвинутые аналитические панели помогают нам принимать решения быстрее, не используя дополнительные инструменты. Это экономит нам много времени и, следовательно, денег.”
Екатерина К.,
PM в Gravity Fit
Accuracy Adapty Appstore
ABC testing

A/B тестирование пейволлов

Найдите самый прибыльный пейволл и увеличьте доход вашего приложения.
Изучить A/B тестирование
MentalGrowth
MentalGrowth
Приложение для здоровья и благополучия
“Быстрая аналитика Adapty и легкая в запуске функция A/B тестирования позволили нам быстро валидировать гипотезы и добиться отличных результатов.”
Вадим Немченко,
Менеджер продукта в MentalGrowth

Удаленная конфигурация для пейволлов

Изменяйте свой пейволл удаленно без необходимости в повторной релизе приложения.
Попробуйте это сейчас
Smitten
Smitten - Знакомства
Стиль жизни
“Наша команда по росту и доходам может быстро реализовывать и управлять пейволлами, предложениями продуктов и тестировать ценовые уровни на многих разных рынках.”
Кайл Смит,
Руководитель данных в Smitten Dating
Table Json Table Locale

Нам доверяют

На основании 500+ отзывов
G2 Award: Leader (EMEA), winter 2025
G2 Award: Leader (EMEA), winter 2025
G2 Award: Leader (EMEA), winter 2025
G2 Award: Leader (EMEA), winter 2025
G2 Award: Leader (EMEA), winter 2025