Difference between revisions of "Iab"

From GiderosMobile
Line 10: Line 10:
 
** Event.AVAILABLE ''--iab is available''
 
** Event.AVAILABLE ''--iab is available''
 
* IAB:requestProducts() ''--request information for products provided in setProducts method''
 
* IAB:requestProducts() ''--request information for products provided in setProducts method''
** Event.PRODUCT_COMPLETE
+
** Event.PRODUCTS_COMPLETE
 
*** event.productId
 
*** event.productId
 
*** event.title
 
*** event.title
 
*** event.description
 
*** event.description
 
*** event.price
 
*** event.price
** Event.PRODUCT_ERROR
+
** Event.PRODUCTS_ERROR
 
*** event.error
 
*** event.error
 
* IAB:purchase(prodId) ''--purchase product by providing your internal product id, raises two events:''
 
* IAB:purchase(prodId) ''--purchase product by providing your internal product id, raises two events:''

Revision as of 05:15, 30 November 2019

Interface usage is quite simple:

  • IAB.new(iabframework) -- initialize specified IAB framework

Available frameworks: 'amazon', 'google', 'ios'

  • IAB:setUp(value1, value2, ..., valueN) -- provide all the keys/devids/appids/etc needed for the framework, which you will get in same order on Native part in Map object
  • IAB:setProducts({internalId1 = "storeId1", internalId2 = "storeId2", ..., internalIdn = "storeIdn"}) -- provide list of products you will be using (key is your internal products id, value is store specific product id)
  • IAB:setConsumables({"internalId1", "internalId2", ..., "internalIdn"}) -- which of your products are consumables, that people can buy many times (provide internal product ids)
  • IAB:isAvailable() --check if IAB is available, raises event:
    • Event.AVAILABLE --iab is available
  • IAB:requestProducts() --request information for products provided in setProducts method
    • Event.PRODUCTS_COMPLETE
      • event.productId
      • event.title
      • event.description
      • event.price
    • Event.PRODUCTS_ERROR
      • event.error
  • IAB:purchase(prodId) --purchase product by providing your internal product id, raises two events:
    • Event.PURCHASE_COMPLETE
      • event.productId
      • event.receiptId
    • Event.PURCHASE_ERROR
      • event.error
  • iab:restore() --raise purchase events for each previously purchases entitled (not consumed) items, raises two events:
    • Event.RESTORE_COMPLETE
    • Event.RESTORE_COMPLETE
      • event.error
Code example:
local test
if application:getDeviceInfo() == "Android" then
    test = IAB.new("google")
    test:setUp("keys")
elseif application:getDeviceInfo() == "iOS" then
    test = IAB.new("storekit")
    test:setUp("keys")
end
 
--and here comes completely same code for both frameworks to request products/buy stuff etc

test:addEventListener(Event.AVAILABLE, function(e)
	--provide setup stuff (framework specific)
	test:setUp("value1", "value2", "value3")
	test:purchase("product1") --purchase something
end)

test:addEventListener(Event.PURCHASE_COMPLETE, function(e)
	--unlock your purchase here
	print(e.productId, e.receiptId)
	test:confirm(e.productId)
end)

test:isAvailable()
test:restore()