private val iapHelper: IapHelper = IapHelper.getInstance(context)
Set the IAP operation mode
IAP supports three operational modes. One is for enabling billing for product purchases and the other two are for testing IAP functions without billing app users for product purchases.
If setOperationMode() is not called, operation mode is set to OPERATION_MODE_PRODUCTION by default (testing is not supported, but beta release and normal publication are supported).
CautionEnsure the operation mode is set to OPERATION_MODE_PRODUCTION before submitting for Beta test or normal publication. In other words, OPERATION_MODE_TEST or OPERATION_MODE_TEST_FAILURE must be set only if the app status in Seller Portal is Registering or Updating.
Mode
Description
OPERATION_MODE_PRODUCTION
startPayment() requests are processed as specified, financial transactions do occur for successful requests, and actual results are returned (successful or failed).
Note: For all other IAP SDK requests:
Only products purchased in OPERATION_MODE_PRODUCTION mode are considered owned products.
OPERATION_MODE_TEST
startPayment() requests are processed as specified, except financial transactions do not occur (license testers are not billed for product purchases), and successful results are always returned. For details of the payment window shown in OPERATION_MODE_TEST mode, see below.
Note: For all other IAP SDK requests:
Only products purchased in OPERATION_MODE_TEST mode are considered owned products.
In order to purchase in-app products, testers must be registered as a License Tester in the seller's Seller Portal profile. In this mode, license testers always get your in-app products for free. All other users see an error message if they try to purchase an in-app product.
OPERATION_MODE_TEST_FAILURE
All IAP SDK requests fail. It is meant to be a negative testing to ensure that your app can handle errors such as improper input and user actions.
NoteIf OPERATION_MODE_TEST is set, the pop-up below is displayed and Sandbox is shown at the top right of the payment window to indicate that the app user will not be billed for product purchases.
Request
public void setOperationMode( OperationMode _mode )
Parameters
Parameter
Type
Description
_mode
OperationMode
(Required) The IAP operating mode that controls the processing of IAP SDK API requests: OPERATION_MODE_PRODUCTION OPERATION_MODE_TEST OPERATION_MODE_TEST_FAILURE
RequirementYou must call getOwnedList() whenever launching the application in order to check for unconsumed items or subscription availability.
getOwnedList() returns a list of in-app products that the app user currently has from previous purchases:
Items that were purchased with a single charge to the user's payment method. They are either consumable or non-consumable:
Consumable items that have not yet been used and not yet reported as consumed
Non-consumable items
Subscriptions currently in a free trial or an active subscription period
Includes canceled subscriptions until their active subscription period has ended
If the subscription price is changed, includes information such as new price, renewal date, and user consent
getOwnedList() also returns product data and processing results specified by the OnGetOwnedListListener interface.
NoteFor consumable item purchases, mark the item as consumed by calling the consumePurchasedItems() method so that the user can buy the item again after they have consumed it.
For non-consumable item and subscription purchases, acknowledge delivery of the content by calling the acknowledgePurchases() method. Make sure that the purchase hasn't been previously acknowledged by checking the acknowledgedStatus field.
We recommend acknowledging all listed in-app products in one method call in order to avoid system overload or malfunction.
Request
public boolean getOwnedList
(
String _productType,
OnGetOwnedListListener _onGetOwnedListListener
)
Parameters
Parameter
Type
Description
_productType
String
(Required) Type of in-app products to be returned: item: Both consumable and non-consumable items subscription: Auto-recurring subscriptions all: Consumable and non-consumable items and auto-recurring subscriptions
_onGetOwnedListListener
(Required) Name of the OnGetOwnedListListener interface that specifies the product data and processing results to be returned
NoteThe obfuscated account ID and profile ID sent in the purchase request are returned in the response for getOwnedList() and iap/v6/receipt APIs.
Return value
true - The request was sent to server successfully and the result will be sent to OnGetOwnedListListener interface listener.
false - The request was not sent to server and was not processed.
Object that contains in-app products owned by the app user
OwnedProductVo
Getter
Return Type
Description
getItemId()
String
Unique ID of the in-app product
getItemName()
String
Title of the in-app product
getItemPrice()
Double
Current local price in the local currency of the in-app product (for example, 7.99)
getItemPriceString()
String
Local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £7.99)
Price + currency symbol (for example, 66815₫)
getCurrencyUnit()
String
Symbol of the local currency (for example, €, £, or $)
getCurrencyCode()
String
Currency code (3 characters) of the local currency (for example, EUR, GBP, USD)
getItemDesc()
String
Description of the in-app product
getType()
String
Type of in-app product: "item": Consumable or Non-consumable "subscription": Auto-recurring subscription
getIsConsumable()
boolean
Deprecated since IAP 6.5.0
The distinction between consumable and non-consumable item types has been deprecated. The ability to register non-consumable item types in Seller Portal will end in 2025.
NoteFor in-app items with no distinction between consumables and non-consumables, your app must determine if an item can be repurchased (is consumable or non-consumable) instead of calling getIsConsumable().
In-app items with no distinction between consumables and non-consumables (considered consumable by default) and consumePurchasedItems() or acknowledgePurchases() has not been called
In-app items with no distinction between consumables and non-consumables (considered consumable by default) and acknowledgePurchases() has been called,
or
Subscriptions
getPaymentId()
String
Unique identifier assigned by Samsung IAP to the confirmed payment of the in-app product
getPurchaseId()
String
Unique identifier assigned by Samsung IAP to the purchase transaction of the in-app product
getPurchaseDate()
String
Date and time of the product purchase and payment transaction (YYYY‑MM‑DD HH:mm:ss)
getSubscriptionEndDate()
String
For subscriptions only, the date and time that the subscription's current subscription period expires (YYYY‑MM‑DD HH:mm:ss)
getPassThroughParam()
String
Deprecated since IAP 6.4.0 Unique identifier that your app assigned to the product purchase and payment transaction If a pass-through parameter was not assigned, empty string ("") is returned.
getSubscriptionPriceChange()
SubscriptionPriceChangeVo
Subscription price change information
getAcknowledgedStatus()
AcknowledgedStatus
UNSUPPORTED: Failed to acknowledge due to unsupported version of Galaxy Store
NOT_ACKNOWLEDGED: Not acknowledged yet
ACKNOWLEDGED: Acknowledged
getJsonString()
String
Full JSON payload
getObfuscatedAccountId()
String
Obfuscated account id which you sent when you called startPayment() or changeSubscriptionPlan()
getObfuscatedProfileId()
String
Obfuscated profile id which you sent when you called startPayment() or changeSubscriptionPlan()
SubscriptionPriceChangeVo
Getter
Return Type
Description
getAppName()
String
Application name
getItemName()
String
Title of the in-app product
getSubscriptionDurationMultiplier()
String
The numeric multiple of the time basis unit that determines the subscription time period
The multiplier is combined with the value returned by getSubscriptionDurationUnit().
getSubscriptionDurationUnit()
String
The time basis unit of each subscription period ("YEAR", "MONTH", "WEEK")
Note: These units are always returned in uppercase letters.
getStartDate()
String
Date and time when new prices will affect subscribers (YYYY‑MM‑DD HH:mm:ss)
getOriginalLocalPrice()
Double
Original local price of the in-app product (for example, 7.99)
getOriginalLocalPriceString()
String
Local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £7.99)
Price + currency symbol (for example, 66815₫)
getNewLocalPrice()
Double
New local price of the in-app product (for example, 9.99)
getNewLocalPriceString()
String
Local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £9.99)
Price + currency symbol (for example, 70000₫)
isConsented()
boolean
Indicates if the user has consented to a price change (see getPriceChangeMode() below)
true: The user has consented to the price change.
false: The user has not consented to the price change.
If consent is required, Samsung recommends you include a pop-up, notification, or setting that allows the existing subscriber to renew their subscription (see Price Increase Notifications for an example notification).
Your message should also provide the deeplink to the subscription detail page from which users can access the consent page (on a Samsung mobile device):
PRICE_INCREASE_USER_AGREEMENT_REQUIRED: Price increases which require an existing subscriber's consent Users must explicitly accept the higher price before the subscription can be renewed.
PRICE_INCREASE_NO_USER_AGREEMENT_REQUIRED: Price increases without requiring existing subscribers to take any action Unless users opt out, they will be charged the new price when the next regular subscription payment is due.
PRICE_DECREASE: Price decreases applied to existing subscribers when the next regular subscription payment is due
Code snippet
Java
iapHelper.getOwnedList(HelperDefine.PRODUCT_TYPE_ALL, (errorVo, ownedList) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
for (OwnedProductVo item : ownedList) {
// TODO: Your app must determine if the in-app item is consumable
// If the in-app item is consumable, consume the item:
iapHelper.consumePurchasedItems(item.getPurchaseId(), (errorVo, consumeList) -> {
// TODO: Handle the result
});
// else acknowledge the non-consumable item or subscription
if (item.getAcknowledgedStatus() == HelperDefine.AcknowledgedStatus.NOT_ACKNOWLEDGED) {
iapHelper.acknowledgePurchases(item.getPurchaseId(), (errorVo, acknowledgedList) -> {
// TODO: Handle the result
});
}
// Check if the subscription price has changed and user consent is required
SubscriptionPriceChangeVo subscriptionPriceChangeVo = item.getSubscriptionPriceChange();
if (subscriptionPriceChangeVo != null &&
subscriptionPriceChangeVo.getPriceChangeMode() == HelperDefine.PriceChangeMode.PRICE_INCREASE_USER_AGREEMENT_REQUIRED &&
!subscriptionPriceChangeVo.isConsented()) {
// TODO: Induce user consent
}
}
} else {
// TODO: Handle the error
}
});
Kotlin
iapHelper.getOwnedList(IapHelper.PRODUCT_TYPE_ALL)
{ errorVo: ErrorVo, ownedList: ArrayList<OwnedProductVo> ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
for (item in ownedList) {
// TODO: Your app must determine if the in-app item is consumable
// If the in-app item is consumable, consume the consumable item
iapHelper.consumePurchasedItems(item.purchaseId) { errorVo: ErrorVo, consumeList: ArrayList<ConsumeVo> ->
// TODO: Handle the result
}
// else acknowledge the non-consumable item or subscription
if (item.acknowledgedStatus == HelperDefine.AcknowledgedStatus.NOT_ACKNOWLEDGED) {
iapHelper.acknowledgePurchases(item.purchaseId) { errorVo: ErrorVo, acknowledgedList: ArrayList<AcknowledgeVo> ->
// TODO: Handle the result
}
}
// Check if the subscription price has changed and user consent is required
val subscriptionPriceChangeVo = item.subscriptionPriceChange
if (subscriptionPriceChangeVo != null &&
subscriptionPriceChangeVo.priceChangeMode == HelperDefine.PriceChangeMode.PRICE_INCREASE_USER_AGREEMENT_REQUIRED &&
!subscriptionPriceChangeVo.isConsented {
// TODO: Induce user consent
}
}
} else {
// TODO: Handle the error
}
}
Get in-app product details
getProductsDetails() returns information for one, more, or all in-app products registered to the app.
Returns product data and processing results specified by the OnGetProductsDetailsListener interface.
Request
public void getProductsDetails
(
String _productIds,
OnGetProductsDetailsListener _onGetProductsDetailsListener
)
Parameters
Parameter
Type
Description
_productIds
String
(Required) One or more in-app product IDs specified by either:
Empty string ("") that designates all in-app products or
One or more unique in-app product ID values, comma delimited (for example, "coins,blocks,lives")
You can get the IDs from Seller Portal (Applications page > Click status of the app > In App Purchase tab > Item ID).
_onGetProductsDetailsListener
(Required) Name of the OnGetProductsDetailsListener interface that specifies the product data and processing results to be returned
Current local price in the local currency of the in-app product (for example, 7.99)
Note: When displayed, this string always includes the two digits to the right of the decimal point (and does not display the currency symbol). For example, if the local price is 8 euros, the value "8.00" is displayed. If you don't want to display the decimal point and the two digits to the right of the decimal point when the price is a whole number, use getItemPriceString() instead.
getItemPriceString()
String
Local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £7.99)
Price + currency symbol (for example, 66815₫)
Note: When displayed, if the price is a whole number, the decimal point and the two digits to the right of the decimal point are not displayed. For example, if the local price is 8 euros, the value "€8" is displayed. If you want to display the two digits to the right of the decimal point (even if the price is a whole number), use getItemPrice() instead.
getCurrencyUnit()
String
Symbol of the local currency (for example, €, £, or $)
getCurrencyCode()
String
Currency code (3 characters) of the local currency (for example, EUR, GBP, USD)
getItemDesc()
String
Description of the in-app product
getType()
String
Type of in-app product: "item": Consumable or Non-consumable "subscription": Auto-recurring subscription
getIsConsumable()
boolean
Deprecated since IAP 6.5.0
The distinction between consumable and non-consumable item types has been deprecated. The ability to register non-consumable item types in Seller Portal will end in 2025.
NoteFor in-app items with no distinction between consumables and non-consumables, your app must determine if an item can be repurchased (is consumable or non-consumable) instead of calling getIsConsumable().
true:
Consumable in-app items
or
In-app items with no distinction between consumables and non-consumables (considered consumable by default)
false:
Non-consumable in-app items
or
Subscriptions
getSubscriptionDurationUnit()
String
For subscriptions only, the time basis unit of each subscription period ("YEAR", "MONTH", "WEEK").
Note: The units must be uppercase.
getSubscriptionDurationMultiplier()
String
For subscriptions only, the numeric multiple of the time basis unit that determines the subscription's time period (for example, 1YEAR, 2MONTH, 4WEEK)
The multiplier is combined with the value returned by getSubscriptionDurationUnit().
getTieredSubscriptionYN()
String
For subscriptions only, whether or not the subscription has two-tiered pricing "Y": The subscription has one or more lower-price subscription periods followed by regular-price periods "N": The subscription only has regular-price subscription periods
getTieredPrice()
String
For two-tiered subscriptions only, the lower-tier price in local currency (for example, 7.99)
getTieredPriceString()
String
For two-tiered subscriptions only, the local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £7.99)
Price + currency symbol (for example, 66815₫)
getTieredSubscriptionDurationUnit()
String
For two-tiered subscriptions only, the time basis unit of each subscription period ("YEAR", "MONTH", "WEEK").
Note: The units must be uppercase.
getTieredSubscriptionDurationMultiplier()
String
For two-tiered subscriptions only, the numeric multiple of the time basis unit that determines the subscription's time period (for example, 1YEAR, 2MONTH, 4WEEK)
The multiplier is combined with the value returned by getTieredSubscriptionDurationUnit().
getTieredSubscriptionCount()
String
If the subscription has both lower and regular tier subscription prices, the number of lower-tier subscription periods.
getShowStartDate()
String
Start date and time that the product will be available for purchase (YYYY-MM-DD HH:mm:ss)
getShowEndDate()
String
End date and time after which the product will not be available for purchase (YYYY-MM-DD HH:mm:ss)
getItemImageUrl()
String
URL of the product's image and thumbnail
getItemDownloadUrl()
String
URL to download the product
getFreeTrialPeriod()
String
Duration of the subscription's pre-subscription free trial period (in days) : 7 to 999 days
getJsonString()
String
Full JSON payload
Code snippet
Java
iapHelper.getProductsDetails("Nuclear, Claymore, SpeedUp", (errorVo, productList) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
for (ProductVo item : productList) {
// TODO: Get details of the in-app item
}
} else {
// TODO: Handle the error
}
});
Kotlin
iapHelper.getProductsDetails("Nuclear, Claymore, SpeedUp")
{ errorVo: ErrorVo, productList: ArrayList<ProductVo> ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
for (item in productList) {
// TODO: Get details of the in-app item
}
} else {
// TODO: Handle the error
}
}
Purchase an in-app product
startPayment() initiates the purchase and payment transaction of the specified in-app product and can notify the end user if the purchase succeeded or failed. Returns the product data and transaction results and data specified in the OnPaymentListener interface.
CautionWhen the IAP operating mode is OPERATION_MODE_PRODUCTION and the app is being distributed in the Galaxy Store, successful processing results in financial transactions (the app user will be billed for product purchases).
(Required) Unique identifier value of the in-app product to be purchased.
_obfuscatedAccountId
String
(Optional) Obfuscated value that can only be associated with the customer's account in your app (up to 64 bytes).
Galaxy Store uses this value to detect fraudulent payments. If personally identifiable information is stored as cleartext in this parameter, the purchase may be blocked. It is recommended that you use encryption or a one-way hash to create the obfuscated value.
_obfuscatedProfileId
String
(Optional) Obfuscated value that can only be associated with the customer's profile in your app (up to 64 bytes). If you set this value, you must also set the _obfuscatedAccountId.
If your app allows users to have more than one profile within a single account, use this parameter to enter the obfuscated profile ID.
Galaxy Store uses this value to detect fraudulent payments. If personally identifiable information is stored as cleartext in this parameter, the purchase may be blocked. It is recommended that you use encryption or a one-way hash to create the obfuscated value.
_onPaymentListener
(Required) Name of the OnPaymentListener interface that specifies the purchase and payment transaction data, product data, and processing results to be returned.
NoteThe obfuscated account ID and profile ID sent in the request are returned in the response for startPayment(), getOwnedList() and iap/v6/receipt APIs.
passThroughParam, which is a unique identifier that your app assigned to the product purchase and payment transaction, has been deprecated since IAP SDK v6.4.0.
Instead, you can use the purchaseID returned from getOwnedList() and startPayment(). To verify the purchase, call the iap/v6/receipt API with the purchaseID.
Return value
true: The request was sent to server successfully and the result will be sent to OnPaymentListener interface listener.
false: The request was not sent to server and was not processed.
Current local price in the local currency of the in-app product (for example, 7.99)
Note: When displayed, this string always includes the two digits to the right of the decimal point (and does not display the currency symbol). For example, if the local price is 8 euros, the value "8.00" is displayed. If you don't want to display the decimal point and the two digits to the right of the decimal point when the price is a whole number, use getItemPriceString() instead.
getItemPriceString()
String
Local currency symbol and price (in the local currency format):
Currency symbol + price (for example, £7.99)
Price + currency symbol (for example, 66815₫)
Note: When displayed, if the price is a whole number, the decimal point and the two digits to the right of the decimal point are not displayed. For example, if the local price is 8 euros, the value "€8" is displayed. If you want to display the two digits to the right of the decimal point (even if the price is a whole number), use getItemPrice() instead.
getCurrencyUnit()
String
Symbol of the local currency (for example, €, £, or $)
getCurrencyCode()
String
Currency code (3 characters) of the local currency (for example, EUR, GBP, USD)
getItemDesc()
String
Description of the in-app product
getType()
String
Type of in-app product: "item": Consumable or Non-consumable "subscription": Auto-recurring subscription
getIsConsumable()
boolean
Deprecated since IAP 6.5.0
The distinction between consumable and non-consumable item types has been deprecated. The ability to register non-consumable item types in Seller Portal will end in 2025.
NoteFor in-app items with no distinction between consumables and non-consumables, your app must determine if an item can be repurchased (is consumable or non-consumable) instead of calling getIsConsumable().
true:
Consumable in-app items
or
In-app items with no distinction between consumables and non-consumables (considered consumable by default)
false:
Non-consumable in-app items
or
Subscriptions
getPaymentId()
String
Unique identifier assigned by Samsung IAP to the payment transaction of the in-app product
getPurchaseId()
String
Unique identifier assigned by Samsung IAP to the purchase transaction of the in-app product
getPurchaseDate()
String
Date and time of the product purchase (YYYY-MM-DD HH:mm:ss)
getVerifyUrl()
String
Deprecated since IAP 6.0 See Verify a purchase to get the IAP server URL to verify the purchase using the purchase ID returned by getPurchaseId()
getPassThroughParam()
String
Deprecated since IAP 6.4.0 Unique identifier that your app assigned to the product purchase and payment transaction If a pass-through parameter was not assigned, an empty string ("") is returned.
getMinorStatus()
MinorStatus
UNIDENTIFIED: The country does not have a legal obligation to report minors or the buyer's age status is not known
NOT_MINOR: The buyer is not a minor
MINOR: The buyer is a minor
getItemImageUrl()
String
URL of the product’s image and thumbnail
getItemDownloadUrl()
String
URL to download the product
getOrderId()
String
Unique identifier of the order
getJsonString()
String
Full JSON payload
getObfuscatedAccountId()
String
Obfuscated account id which you sent when you called startPayment() or changeSubscriptionPlan()
getObfuscatedProfileId()
String
Obfuscated profile id which you sent when you called startPayment() or changeSubscriptionPlan()
Code snippet
Java
iapHelper.startPayment("Nuclear","b2JmdXNjYXRlZEFjY291bnRJZA==", "b2JmdXNjYXRlZFByb2ZpbGVJZA==", (errorVo, purchaseVo) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
if (purchaseVo != null) {
// TODO: Your app must determine if the in-app item is consumable
// If the in-app item is consumable, consume the item:
iapHelper.consumePurchasedItems(purchaseVo.getPurchaseId(), (errorVo, arrayList) -> {
// TODO: Handle the result
}
// else acknowledge the non-consumable item or subscription
iapHelper.acknowledgePurchases(purchaseVo.getPurchaseId(), (errorVo, arrayList) -> {
// TODO: Handle the result
}
}
} else {
// TODO: Handle the error
}
});
Kotlin
iapHelper.startPayment("Nuclear","b2JmdXNjYXRlZEFjY291bnRJZA==", "b2JmdXNjYXRlZFByb2ZpbGVJZA==" ) { errorVo: ErrorVo, purchaseVo: PurchaseVo? ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
if (purchaseVo != null) {
// TODO: Your app must determine if the in-app item is consumable
// If the in-app item is consumable, consume the consumable item
iapHelper.consumePurchasedItems(purchaseVo.purchaseId) { errorVo: ErrorVo, arrayList: ArrayList<ConsumeVo> ->
// TODO: Handle the result
}
// else acknowledge the non-consumable item or subscription
iapHelper.acknowledgePurchases(purchaseVo.purchaseId) { errorVo: ErrorVo, arrayList: ArrayList<AcknowledgeVo> ->
// TODO: Handle the result
}
}
} else {
// TODO: Handle the error
}
}
NoteWhen you try to purchase a product in your app, you will see the pop-up windows similar to the ones shown below. You must be signed in to your Samsung account.
Notify Samsung IAP that the purchase was processed
After your app has granted entitlement to the user with a successful transaction, your app needs to notify Samsung IAP that the purchase was successfully processed.
The following sections describe the process for acknowledging different types of purchases.
Consumable items
consumePurchasedItems() reports one or more purchased consumable items as consumed, which makes the items available for another purchase. The app user may or may not have used the items. Returns item data and processing results specified by the OnConsumePurchasedItemsListener interface.
NoteWe recommend reporting purchased consumable items immediately after verifying their purchase and reporting all unreported products in one consumePurchasedItems() or acknowledgePurchases() method call in order to avoid system overload or malfuction.
Request
public boolean consumePurchasedItems
(
String _purchaseIds,
OnConsumePurchasedItemsListener _onConsumePurchasedItemsListener
)
Parameters
Parameter
Type
Description
_purchaseIds
String
(Required) One or more unique identifier values (comma delimited) of the purchase and payment transactions of consumable in-app items that are to be reported as consumed
_onConsumePurchasedItemsListener
(Required) Name of the OnConsumePurchasedItemsListener interface that specifies the item data and processing results to be returned
Return value
true: The request was sent to server successfully and the result will be sent to OnConsumePurchasedItemsListener interface listener.
false: The request was not sent to server and was not processed.
Note: Even if some items fail to consume due to unexpected errors, they are included in the _consumeList, and the result of each item can be checked with ConsumeVo.getStatusCode().
Non-consumable items and subscriptions
acknowledgePurchases() acknowledges that the user has been granted entitlement for one or more purchased non-consumable items or subscriptions. Returns non-consumable item/subscription data and processing results specified by the OnAcknowledgePurchasesListener interface.
Request
public boolean acknowledgePurchases
(
String _purchaseIds,
OnAcknowledgePurchasesListener _onAcknowledgePurchasesListener
)
Parameters
Parameter
Type
Description
_purchaseIds
String
(Required) One or more unique identifier values (comma delimited) of the purchase and payment transactions of acknowledging purchased non-consumable items and subscriptions
_onAcknowledgePurchasesListener
(Required) Name of the OnAcknowledgePurchasesListener interface that specifies the non-consumable item/subscription data and processing results to be returned
Return value
true: The request was sent to the server successfully and the result will be sent to the OnAcknowledgePurchasesListener interface listener.
false: The request was not sent to server and was not processed.
List of acknowledged non-consumable items and subscriptions
Note: Even if some non-consumable items/subscriptions fail to acknowledge due to unexpected errors, they are included in the acknowledgedList, and the result of each non-consumable item/subscription can be checked with AcknowledgeVo.getStatusCode().
ConsumeVo/AcknowledgeVo
Getter
Return Type
Description
getPurchaseId()
String
Unique identifier assigned by Samsung IAP to the purchase transaction of the non-consumable item/subscription
getStatusCode()
int
Status code 0 : Success 1 : Invalid purchaseID 2 : Failed order 3 : Invalid product type 4 : Already consumed/acknowledged 5 : Unauthorized user 9 : Unexpected service error
getStatusString()
String
Status message 0 : "success" 1 : "Can't find order with this purchaseID." 2 : "This is not successful order." 3 : "This type of item is not consumable/non-consumable." 4 : "This purchase has been consumed/acknowledged already." 5 : "Can't consume/acknowledge this purchase because the user is not authorized to consume this order." 9 : "service error"
getJsonString()
String
Full JSON payload
Code snippet
Java (ConsumeVo)
final String PURCHASEID = "d215d9abcd17b12578a21c0ea7d8821747b64939732a3243b538d8bcae245590";
iapHelper.consumePurchasedItems(PURCHASEID, (errorVo, consumeList) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
for (ConsumeVo item : consumeList) {
// TODO: Get details of the consumption
}
} else {
// TODO: Handle the error
}
});
Kotlin (AcknowledgeVo)
val PURCHASEID: String = "d215d9abcd17b12578a21c0ea7d8821747b64939732a3243b538d8bcae245590"
iapHelper.acknowledgePurchases(PURCHASEID)
{ errorVo: ErrorVo, acknowledgedList: ArrayList<AcknowledgeVo> ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
for (item in acknowledgedList) {
// TODO: Get details of the acnowledge
}
} else {
// TODO: Handle the error
}
}
Get promotion eligibility for subscription
getPromotionEligibility() returns the pricing options of a subscription, such as free trials and introductory prices, applicable to the customer. This allows you to inform each customer about promotions they are eligible for when they are making a purchase. Customers can also check for available promotions before payment, thereby encouraging them to make a purchase.
Request
public boolean getPromotionEligibility
(
String _itemIds,
OnGetPromotionEligibilityListener onGetPromotionEligibilityListener
)
Parameters
Parameter
Type
Description
_itemIds
String
(Required) One or more unique in-app subscription ID values. Multiple values are comma-delimited. For example, "coins,blocks,lives"
_onGetPromotionEligibilityListener
(Required) Defines the onGetPromotionEligibility() callback method that sends a pricing policy
Return value
true: The request was sent to the server successfully and the result will be sent to the OnGetPromotionEligibilityListener interface listener.
false: The request was not sent to server and was not processed.
"FreeTrial" - A set period of time that the user can use the subscription for free. See Free trial period for more information about this type of subscription.
"TieredPrice" - A subscription that charges an introductory price for a limited amount of time. See Lower-Tier or introductory subscription for more information about this type of subscription.
"RegularPrice" - A subscription that charges a set price for each subscription period. See Regular or regular-tier subscription for more information about this type of subscription.
Code snippet
Java
iapHelper.getPromotionEligibility("Nuclear, Claymore, SpeedUp", (errorVo, pricingList) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
for (PromotionEligibilityVo pricing : pricingList) {
// TODO: Get the pricing options of the subscription
}
} else {
// TODO: Handle the error
}
});
Kotlin
iapHelper.getPromotionEligibility("Nuclear, Claymore, SpeedUp")
{ errorVo: ErrorVo, pricingList: ArrayList<PromotionEligibilityVo> ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
for (item in pricingList) {
// TODO: Get the pricing options of the subscription
}
} else {
// TODO: Handle the error
}
}
A change may be an upgrade (from a lower priced tier to a higher priced tier or changing between two equally priced tiers) or a downgrade (from a higher priced tier to a lower priced tier).
You must specify a prorationMode to choose how to apply changes to the payment and current subscription period.
(Required) Subscription ID currently subscribed to
newItemId
String
(Required) Subscription ID to subscribe to
prorationMode
ProrationMode
(Required) There are four modes that can be set when a subscription is changed:
INSTANT_PRORATED_DATE: The subscription is upgraded or downgraded immediately. Any time remaining is adjusted based on the price difference and credited toward the new subscription by pushing forward the next billing date. There is no any additional payment.
INSTANT_PRORATED_CHARGE: For upgraded subscriptions only. The subscription is upgraded immediately but the billing cycle remains the same. The price difference for the remaining period is then charged to the user.
INSTANT_NO_PRORATION: For upgraded subscriptions only. The subscription is upgraded immediately and the new price is charged when the subscription renews. The billing cycle remains the same.
DEFERRED: The subscription is upgraded or downgraded when the subscription renews. When the subscription renews, the new price is charged. A downgrade is always executed with this mode.
(Optional) Obfuscated value that can only be associated with the customer's account in your app (up to 64 bytes).
Galaxy Store uses this value to detect fraudulent payments. If personally identifiable information is stored as cleartext in this parameter, the purchase may be blocked. It is recommended that you use encryption or a one-way hash to create the obfuscated value.
_obfuscatedProfileId
String
(Optional) Obfuscated value that can only be associated with the customer's profile in your app (up to 64 bytes). If you set this value, you must also set the _obfuscatedAccountId.
If your app allows users to have more than one profile within a single account, use this parameter to enter the obfuscated profile ID.
Galaxy Store uses this value to detect fraudulent payments. If personally identifiable information is stored as cleartext in this parameter, the purchase may be blocked. It is recommended that you use encryption or a one-way hash to create the obfuscated value.
onChangeSubscriptionPlanListener
(Required) Name of the OnChangeSubscriptionPlanListener interface that specifies the purchase and payment transaction data, subscription data, and processing results to be returned.
NoteThe obfuscated account ID and profile ID sent in the request are returned in the response for changeSubscriptionPlan(), getOwnedList() and iap/v6/receipt APIs.
passThroughParam, which is a unique identifier that your app assigned to the product purchase and payment transaction, has been deprecated since IAP SDK v6.4.0.
Instead, you can use the purchaseID returned from getOwnedList() and startPayment(). To verify the purchase, call the iap/v6/receipt API with the purchaseID.
Return value
true - The request was sent to server successfully and the result will be sent to OnChangeSubscriptionPlanListener interface listener.
false - The request was not sent to server and was not processed.
iapHelper.changeSubscriptionPlan(
"oldItem",
"newItem",
HelperDefine.ProrationMode.INSTANT_PRORATED_DATE,
"b2JmdXNjYXRlZEFjY291bnRJZA==",
"b2JmdXNjYXRlZFByb2ZpbGVJZA==",
(errorVo, purchaseVo) -> {
if (errorVo.getErrorCode() == IapHelper.IAP_ERROR_NONE) {
if (purchaseVo != null) {
// TODO: Check details about your newly purchased subscription
}
} else {
// TODO: Handle the error
}
});
Kotlin
iapHelper.changeSubscriptionPlan(
"oldItem",
"newItem",
HelperDefine.ProrationMode.INSTANT_PRORATED_DATE,
"b2JmdXNjYXRlZEFjY291bnRJZA==",
"b2JmdXNjYXRlZFByb2ZpbGVJZA==")
{ errorVo: ErrorVo, purchaseVo: PurchaseVo? ->
if (errorVo.errorCode == IapHelper.IAP_ERROR_NONE) {
if (purchaseVo != null) {
// TODO: Check details about your newly purchased subscription
}
} else {
// TODO: Handle the error
}
}
ErrorVo and Response code
ErrorVo
Getter
Return Type
Description
getErrorCode()
int
Response code (for example, -1003) For details, see Response Code
getErrorString()
String
Error message (for example, Already purchased.)
getErrorDetailsString()
String
Additional information about the result (for example, IS9224/6050/NwCbCAxypi)
isShowDialog()
boolean
true: The error message dialog is displayed after a failed process. false: The error message dialog is not displayed after a failed process.
Response code
Reponse Code (Value)
Description
IAP_ERROR_NONE (0)
Success
IAP_PAYMENT_IS_CANCELED (1)
Payment canceled
IAP_ERROR_INITIALIZATION (-1000)
Failure during IAP initialization
Note: Details of possible errors:
10000 : IAP Client app is invalid.
10001 : Samsung Checkout app is invalid.
10011 : Service initialization failed. Try again.
IAP_ERROR_NEED_APP_UPGRADE (-1001)
IAP upgrade is required
IAP_ERROR_COMMON (-1002)
Error while running IAP
Note: Details of possible errors:
1005 : When the subscription is changed, the old subscription does not exist
1006 : When the subscription is changed, the old subscription is not subscribed
1012 : When the subscription is changed, the specified subscription is not a subscription type
1014 : Subscription change has already been requested
7002 : Blocked as a suspicious transaction
9000 : getOwnedList() fails when OPERATION_MODE_TEST_FAILURE is set
9005 : consumePurchasedItems() fails when OPERATION_MODE_TEST_FAILURE is set
9006 : PassThroughParam is not Base64-encoded
9007 : PassThroughParam exceeded max length
9010 : The item is not consumed yet
9013 : getProductsDetails() fails when OPERATION_MODE_TEST_FAILURE is set
9014 : startPayment() fails when OPERATION_MODE_TEST_FAILURE is set
9122 : Invalid MCC
9132 : Invalid token or User ID
9154 : Invalid product ID
9226 : PurchaseID is null or invalid in consumePurchasedItems()
9440 : Device under honeycomb is not available
9441 : Service is temporarily unavailable
9701 : Certification fail
100001 : Request result does not return normally due to unexpected error
100008 : Disagree Runtime Permission
100010 : startPayment() fails when OPERATION_MODE_TEST is set and the user is not a license tester
IAP_ERROR_ALREADY_PURCHASED (-1003)
Error when a non-consumable item is re-purchased or a subscription is re-purchased before its expiration date.
Note: Details of possible errors:
9224 : A non-consumable item is re-purchased or a subscription is re-purchased before its expiration date
IAP_ERROR_WHILE_RUNNING (-1004)
Error when a payment request is made without any information.
IAP_ERROR_PRODUCT_DOES_NOT_EXIST (-1005)
Error when the requested product is not available
Note: Details of possible errors:
9202 : The requested product is not valid in the country or device where the app was distributed. Please check the app distribution condition in Seller Portal.
9207 : The requested itemID does not exist in the current operation mode. Please check ItemID.
IAP_ERROR_CONFIRM_INBOX (-1006)
Error when the app does not receive the purchase result after making a purchase request to the server. In this case, confirmation the product that requested for purchase is needed because the purchase may have been completed successfully.
IAP_ERROR_ITEM_GROUP_DOES_NOT_EXIST (-1007)
Error when the product group ID does not exist.
Note: Details of possible errors:
9201 : There is no registered product information. Please check in-App Purchase activation and product registration in Seller Portal
IAP_ERROR_NETWORK_NOT_AVAILABLE (-1008)
Error when network is not available.
IAP_ERROR_IOEXCEPTION_ERROR (-1009)
IOException
IAP_ERROR_SOCKET_TIMEOUT (-1010)
SocketTimeoutException
IAP_ERROR_CONNECT_TIMEOUT (-1011)
ConnectTimeoutException
IAP_ERROR_NOT_EXIST_LOCAL_PRICE (-1012)
The product is not for sale in the country.
Note: Details of possible errors:
9134 : Local price doesn't exist (Unsupported MCC)
IAP_ERROR_NOT_AVAILABLE_SHOP (-1013)
IAP is not serviced in the country.
Note: Details of possible errors:
9259 : MCC is valid, but Galaxy Store is not supported
IAP_ERROR_INVALID_ACCESS_TOKEN (-1015)
Access token for Samsung account is not valid.
NoteIn the error code, the first set of digits displayed before the initial slash should correspond to one of the numbers in the description of the response codes above. For example, in the first pop-up window, 9224 appears in the description for the response code IAP_ERROR_ALREADY_PURCHASED. In the second pop-up window, 9014 appears in the description for the response code IAP_ERROR_COMMON.
Manage Your Cookies
We use cookies to improve your experience on our website and to show you relevant
advertising. Manage you settings for our cookies below.
Essential Cookies
These cookies are essential as they enable you to move around the website. This
category cannot be disabled.
Company
Domain
Samsung Electronics
.samsungdeveloperconference.com
Analytical/Performance Cookies
These cookies collect information about how you use our website. for example which
pages you visit most often. All information these cookies collect is used to improve
how the website works.
Company
Domain
LinkedIn
.linkedin.com
Meta (formerly Facebook)
.samsungdeveloperconference.com
Google Inc.
.samsungdeveloperconference.com
Functionality Cookies
These cookies allow our website to remember choices you make (such as your user name, language or the region your are in) and
tailor the website to provide enhanced features and content for you.
Company
Domain
LinkedIn
.ads.linkedin.com, .linkedin.com
Advertising Cookies
These cookies gather information about your browser habits. They remember that
you've visited our website and share this information with other organizations such
as advertisers.
Company
Domain
LinkedIn
.linkedin.com
Meta (formerly Facebook)
.samsungdeveloperconference.com
Google Inc.
.samsungdeveloperconference.com
Preferences Submitted
You have successfully updated your cookie preferences.