Cafebazaar In-app purchase Unity plugin
To build BazaarIAB.jar
from the java source code:
- Open a command prompt
- Navigate to JavaPlugin folder
- Type
gradlew createJar
- After the build is succeeded you can find
BazaarIAB.jar
in the build folder
This plugin has not any prefab to use, it will manage the required objects.
The BazaarIAB
is the interface that let you call billing functions, all methods are static so is it not required to instantiate this class. Before calling any other function try to initialize the plugin by calling the init
with the public key provided by Cafebazaar developer portal.
This call will check to see if billing is supported and fire the billingSupportedEvent
if it is. If billing is not supported the billingNotSupportedEvent
will fire and you should not call any other methods.
There is IABEventManager
class that you can subscribe to all plugin events.
After you find out that the billing is supported, you can call queryInventory
by providing all of your available skus. When the queryInventorySucceededEvent
fires it will contain a list of all the current purchases, subscriptions and a list of all your project sku details. You can use this information to setup your store. The list is also handy when you want to consume a purchase. Any BazaarPurchases
returned are available for consumption.
Add the plugin activity in the Application section of the AndroidManifest.xml
:
<meta-data android:name="billing.service" android:value="bazaar.BazaarIabService" />
<activity android:name="com.bazaar.BazaarIABProxyActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen" />
Also add the required permissions to your manifest:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="com.farsitel.bazaar.permission.PAY_THROUGH_BAZAAR" />
Methods are inside BazaarIAB
class.
// Initializes the billing system
public static void init(string publicKey)
// Get current version of plugin
public static string GetVersion()
// Toggles high detail logging on/off
public static void enableLogging(bool shouldEnable)
// Unbinds and shuts down the billing service
public static void unbindService()
// Returns whether subscriptions are supported on the current device
public static bool areSubscriptionsSupported()
// Sends a request to get all completed purchases and product information as setup in the Bazaar dashboard about the provided skus (requires user to be logged in otherwise you will get error)
public static void queryInventory(string[] skus)
// Sends a request to get all product information as setup in the CafeBazaar portal about the provided skus (do not required user to be loggedin)
public static void querySkuDetails(string[] skus)
// Sends a request to get all completed purchases (requires user to be logged in otherwise you will get error)
public static void queryPurchases()
// Sends out a request to purchase the product
public static void purchaseProduct(string sku)
public static void purchaseProduct(string sku, string developerPayload)
// Sends out a request to consume the product
public static void consumeProduct(string sku)
// Sends out a request to consume all of the provided products
public static void consumeProducts(string[] skus)
You can access events from IABEventManager
class.
// Fired after init is called when billing is supported on the device
public static event Action billingSupportedEvent;
// Fired after init is called when billing is not supported on the device
public static event Action<string> billingNotSupportedEvent;
// Fired when the inventory and purchase history query has returned
public static event Action<List<BazaarPurchase>,List<BazaarSkuInfo>> queryInventorySucceededEvent;
// Fired when the inventory and purchase history query fails
public static event Action<string> queryInventoryFailedEvent;
// Fired when the SkuDetails query has returned
public static event Action<List<BazaarSkuInfo>> querySkuDetailsSucceededEvent;
// Fired when the SkuDetails query fails
public static event Action<string> querySkuDetailsFailedEvent;
// Fired when the purchase history query has returned
public static event Action<List<BazaarPurchase>> queryPurchasesSucceededEvent;
// Fired when the purchase history query fails
public static event Action<string> queryPurchasesFailedEvent;
// Fired when a purchase succeeds
public static event Action<BazaarPurchase> purchaseSucceededEvent;
// Fired when a purchase fails
public static event Action<string> purchaseFailedEvent;
// Fired when a call to consume a product succeeds
public static event Action<BazaarPurchase> consumePurchaseSucceededEvent;
// Fired when a call to consume a product fails
public static event Action<string> consumePurchaseFailedEvent;
- mohsen-srn for pointing out the AndroidManifest.xml issue in newer Unity versions.
- Hossynkoala for fixing white keyboard issue in AndroidManifest.
- Mahdad-Baghani help with finding nullReference exception in Unity 2019.3.0f3.
- AhM0D fixed a crash when there is no Cafebazaar app installed on older devices.