Difference between revisions of "GoogleBilling"

From GiderosMobile
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
__NOTOC__
 
__NOTOC__
'''Supported platforms:''' android<br/>
+
<languages />
'''Available since:''' Gideros 2012.09<br/>
+
<!-- GIDEROSOBJ:GoogleBilling -->
 +
'''<translate>Supported platforms</translate>:''' [[File:Platform android.png]]<br/>
 +
'''<translate>Available since</translate>:''' Gideros 2012.09<br/>
 
=== <translate>Description</translate> ===
 
=== <translate>Description</translate> ===
 
<translate><br />
 
<translate><br />
 
The [[Special:MyLanguage/GoogleBilling|GoogleBilling]] class is defined in the module &quot;googlebilling&quot;. Therefore, you need to call<br />
 
The [[Special:MyLanguage/GoogleBilling|GoogleBilling]] class is defined in the module &quot;googlebilling&quot;. Therefore, you need to call<br />
[[Special:MyLanguage/require(&quot;googlebilling&quot;)|require(&quot;googlebilling&quot;)]] before using it. Loading the Google Billing module <br />
+
''require(&quot;googlebilling&quot;)'' before using it. Loading the Google Billing module <br />
also creates a global variable [[Special:MyLanguage/googlebilling|googlebilling]] of type [[Special:MyLanguage/GoogleBilling|GoogleBilling]] for direct use. <br />
+
also creates a global variable ''googlebilling'' of type [[Special:MyLanguage/GoogleBilling|GoogleBilling]] for direct use. <br />
 
  <br />
 
  <br />
 
&lt;h3&gt;GoogleBilling Events and Response Codes&lt;/h3&gt;<br />
 
&lt;h3&gt;GoogleBilling Events and Response Codes&lt;/h3&gt;<br />
Line 14: Line 16:
 
[[Special:MyLanguage/Event.CONFIRM_NOTIFICATION_COMPLETE|Event.CONFIRM_NOTIFICATION_COMPLETE]] and [[Special:MyLanguage/Event.PURCHASE_STATE_CHANGE|Event.PURCHASE_STATE_CHANGE]].<br />
 
[[Special:MyLanguage/Event.CONFIRM_NOTIFICATION_COMPLETE|Event.CONFIRM_NOTIFICATION_COMPLETE]] and [[Special:MyLanguage/Event.PURCHASE_STATE_CHANGE|Event.PURCHASE_STATE_CHANGE]].<br />
 
<br />
 
<br />
[[Special:MyLanguage/Event.*_COMPLETE|Event.*_COMPLETE]] events contains a field [[Special:MyLanguage/event.responseCode|event.responseCode]] which provides status information <br />
+
''Event.*_COMPLETE'' events contains a field ''event.responseCode'' which provides status information <br />
 
and error information about a request. Response code can be one of these values:<br />
 
and error information about a request. Response code can be one of these values:<br />
 
<br />
 
<br />
Line 20: Line 22:
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.OK|GoogleBilling.OK]]: Indicates that the request was sent to the server successfully. When this code is returned&lt;/li&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.OK|GoogleBilling.OK]]: Indicates that the request was sent to the server successfully. When this code is returned&lt;/li&gt;<br />
 
&lt;/ul&gt;<br />
 
&lt;/ul&gt;<br />
in response to a [[Special:MyLanguage/checkBillingSupported|checkBillingSupported]] function, indicates that billing is supported.<br />
+
in response to a ''checkBillingSupported'' function, indicates that billing is supported.<br />
 
&lt;ul&gt;<br />
 
&lt;ul&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.USER_CANCELED|GoogleBilling.USER_CANCELED]]: Indicates that the user pressed the back button on the checkout page instead of buying the item.&lt;/li&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.USER_CANCELED|GoogleBilling.USER_CANCELED]]: Indicates that the user pressed the back button on the checkout page instead of buying the item.&lt;/li&gt;<br />
Line 31: Line 33:
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.ITEM_UNAVAILABLE|GoogleBilling.ITEM_UNAVAILABLE]]: Indicates that Google Play cannot find the requested item in the application&#039;s product list.&lt;/li&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.ITEM_UNAVAILABLE|GoogleBilling.ITEM_UNAVAILABLE]]: Indicates that Google Play cannot find the requested item in the application&#039;s product list.&lt;/li&gt;<br />
 
&lt;/ul&gt;<br />
 
&lt;/ul&gt;<br />
This can happen if the product ID is misspelled in your [[Special:MyLanguage/requestPurchase|requestPurchase]] function or if an item is unpublished in the application&#039;s product list.<br />
+
This can happen if the product ID is misspelled in your ''requestPurchase'' function or if an item is unpublished in the application&#039;s product list.<br />
 
&lt;ul&gt;<br />
 
&lt;ul&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.DEVELOPER_ERROR|GoogleBilling.DEVELOPER_ERROR]]: Indicates that an application is trying to make an in-app billing request but the application has not declared the&lt;/li&gt;<br />
 
&lt;li&gt;[[Special:MyLanguage/GoogleBilling.DEVELOPER_ERROR|GoogleBilling.DEVELOPER_ERROR]]: Indicates that an application is trying to make an in-app billing request but the application has not declared the&lt;/li&gt;<br />
Line 42: Line 44:
 
<br />
 
<br />
 
&lt;h3&gt;# Event.CHECK_BILLING_SUPPORTED_COMPLETE&lt;/h3&gt;<br />
 
&lt;h3&gt;# Event.CHECK_BILLING_SUPPORTED_COMPLETE&lt;/h3&gt;<br />
Dispatched when [[Special:MyLanguage/checkBillingSuported|checkBillingSuported]] function completes. It contains [[Special:MyLanguage/event.responseCode|event.responseCode]] and [[Special:MyLanguage/event.productType|event.productType]] fields.<br />
+
Dispatched when ''checkBillingSuported'' function completes. It contains ''event.responseCode'' and ''event.productType'' fields.<br />
 
<br />
 
<br />
 
&lt;h3&gt;# Event.REQUEST_PURCHASE_COMPLETE&lt;/h3&gt;<br />
 
&lt;h3&gt;# Event.REQUEST_PURCHASE_COMPLETE&lt;/h3&gt;<br />
Dispatched when [[Special:MyLanguage/requestPurchase|requestPurchase]] function completes. It contains [[Special:MyLanguage/event.responseCode|event.responseCode]], [[Special:MyLanguage/event.productId|event.productId]], [[Special:MyLanguage/event.productType|event.productType]] and [[Special:MyLanguage/event.developerPayload|event.developerPayload]] fields.<br />
+
Dispatched when ''requestPurchase'' function completes. It contains ''event.responseCode'', ''event.productId'', ''event.productType'' and ''event.developerPayload'' fields.<br />
 
<br />
 
<br />
 
&lt;h3&gt;# Event.RESTORE_TRANSACTIONS_COMPLETE&lt;/h3&gt;<br />
 
&lt;h3&gt;# Event.RESTORE_TRANSACTIONS_COMPLETE&lt;/h3&gt;<br />
Dispatched when [[Special:MyLanguage/restoreTransactions|restoreTransactions]] function completes. It contains [[Special:MyLanguage/event.responseCode|event.responseCode]] fields.<br />
+
Dispatched when ''restoreTransactions'' function completes. It contains ''event.responseCode'' fields.<br />
 
<br />
 
<br />
 
&lt;h3&gt;# Event.CONFIRM_NOTIFICATION_COMPLETE&lt;/h3&gt;<br />
 
&lt;h3&gt;# Event.CONFIRM_NOTIFICATION_COMPLETE&lt;/h3&gt;<br />
Dispatched when [[Special:MyLanguage/confirmNotification|confirmNotification]] function completes. It contains [[Special:MyLanguage/event.responseCode|event.responseCode]] and [[Special:MyLanguage/event.notificationId|event.notificationId]] fields.<br />
+
Dispatched when ''confirmNotification'' function completes. It contains ''event.responseCode'' and ''event.notificationId'' fields.<br />
 
<br />
 
<br />
 
&lt;h3&gt;# Event.PURCHASE_STATE_CHANGE&lt;/h3&gt;<br />
 
&lt;h3&gt;# Event.PURCHASE_STATE_CHANGE&lt;/h3&gt;<br />
Dispatched when information about a transaction is received. It contains [[Special:MyLanguage/event.purchaseState|event.purchaseState]], [[Special:MyLanguage/event.productId|event.productId]], [[Special:MyLanguage/event.notificationId|event.notificationId]], [[Special:MyLanguage/event.purchaseTime|event.purchaseTime]] and [[Special:MyLanguage/event.developerPayload|event.developerPayload]] fields.<br />
+
Dispatched when information about a transaction is received. It contains ''event.purchaseState'', ''event.productId'', ''event.notificationId'', ''event.purchaseTime'' and ''event.developerPayload'' fields.<br />
 
<br /></translate>
 
<br /></translate>
 
{|-
 
{|-
 
| style="width: 50%; vertical-align:top;"|
 
| style="width: 50%; vertical-align:top;"|
 
=== <translate>Methods</translate> ===
 
=== <translate>Methods</translate> ===
[[Special:MyLanguage/GoogleBilling:checkBillingSupported|GoogleBilling:checkBillingSupported]] <br/>
+
[[Special:MyLanguage/GoogleBilling:checkBillingSupported|GoogleBilling:checkBillingSupported]] <br/><!-- GIDEROSMTD:GoogleBilling:checkBillingSupported(productType)  -->
[[Special:MyLanguage/GoogleBilling:confirmNotification|GoogleBilling:confirmNotification]] <br/>
+
[[Special:MyLanguage/GoogleBilling:confirmNotification|GoogleBilling:confirmNotification]] <br/><!-- GIDEROSMTD:GoogleBilling:confirmNotification(notificationId)  -->
[[Special:MyLanguage/GoogleBilling:requestPurchase|GoogleBilling:requestPurchase]] <br/>
+
[[Special:MyLanguage/GoogleBilling:requestPurchase|GoogleBilling:requestPurchase]] <br/><!-- GIDEROSMTD:GoogleBilling:requestPurchase(productId,productType,developerPayload)  -->
[[Special:MyLanguage/GoogleBilling:restoreTransactions|GoogleBilling:restoreTransactions]] <br/>
+
[[Special:MyLanguage/GoogleBilling:restoreTransactions|GoogleBilling:restoreTransactions]] <br/><!-- GIDEROSMTD:GoogleBilling:restoreTransactions()  -->
[[Special:MyLanguage/GoogleBilling:setApiVersion|GoogleBilling:setApiVersion]] <br/>
+
[[Special:MyLanguage/GoogleBilling:setApiVersion|GoogleBilling:setApiVersion]] <br/><!-- GIDEROSMTD:GoogleBilling:setApiVersion(apiVersion)  -->
[[Special:MyLanguage/GoogleBilling:setPublicKey|GoogleBilling:setPublicKey]] <br/>
+
[[Special:MyLanguage/GoogleBilling:setPublicKey|GoogleBilling:setPublicKey]] <br/><!-- GIDEROSMTD:GoogleBilling:setPublicKey(publicKey)  -->
 
| style="width: 50%; vertical-align:top;"|
 
| style="width: 50%; vertical-align:top;"|
 
=== <translate>Events</translate> ===
 
=== <translate>Events</translate> ===
[[Special:MyLanguage/Event.CHECK_BILLING_SUPPORTED_COMPLETE|Event.CHECK_BILLING_SUPPORTED_COMPLETE]]<br/>
+
[[Special:MyLanguage/Event.CHECK_BILLING_SUPPORTED_COMPLETE|Event.CHECK_BILLING_SUPPORTED_COMPLETE]]<br/><!-- GIDEROSEVT:Event.CHECK_BILLING_SUPPORTED_COMPLETE checkBillingSupportedComplete-->
[[Special:MyLanguage/Event.CONFIRM_NOTIFICATION_COMPLETE|Event.CONFIRM_NOTIFICATION_COMPLETE]]<br/>
+
[[Special:MyLanguage/Event.CONFIRM_NOTIFICATION_COMPLETE|Event.CONFIRM_NOTIFICATION_COMPLETE]]<br/><!-- GIDEROSEVT:Event.CONFIRM_NOTIFICATION_COMPLETE confirmNotificationComplete-->
[[Special:MyLanguage/Event.PURCHASE_STATE_CHANGE|Event.PURCHASE_STATE_CHANGE]]<br/>
+
[[Special:MyLanguage/Event.PURCHASE_STATE_CHANGE|Event.PURCHASE_STATE_CHANGE]]<br/><!-- GIDEROSEVT:Event.PURCHASE_STATE_CHANGE purchaseStateChange-->
[[Special:MyLanguage/Event.REQUEST_PURCHASE_COMPLETE|Event.REQUEST_PURCHASE_COMPLETE]]<br/>
+
[[Special:MyLanguage/Event.REQUEST_PURCHASE_COMPLETE|Event.REQUEST_PURCHASE_COMPLETE]]<br/><!-- GIDEROSEVT:Event.REQUEST_PURCHASE_COMPLETE requestPurchaseComplete-->
[[Special:MyLanguage/Event.RESTORE_TRANSACTIONS_COMPLETE|Event.RESTORE_TRANSACTIONS_COMPLETE]]<br/>
+
[[Special:MyLanguage/Event.RESTORE_TRANSACTIONS_COMPLETE|Event.RESTORE_TRANSACTIONS_COMPLETE]]<br/><!-- GIDEROSEVT:Event.RESTORE_TRANSACTIONS_COMPLETE restoreTransactionsComplete-->
 
=== <translate>Constants</translate> ===
 
=== <translate>Constants</translate> ===
[[Special:MyLanguage/GoogleBilling.BILLING_UNAVAILABLE|GoogleBilling.BILLING_UNAVAILABLE]]<br/>
+
[[Special:MyLanguage/GoogleBilling.BILLING_UNAVAILABLE|GoogleBilling.BILLING_UNAVAILABLE]]<br/><!-- GIDEROSCST:GoogleBilling.BILLING_UNAVAILABLE billingUnavailable-->
[[Special:MyLanguage/GoogleBilling.CANCELED|GoogleBilling.CANCELED]]<br/>
+
[[Special:MyLanguage/GoogleBilling.CANCELED|GoogleBilling.CANCELED]]<br/><!-- GIDEROSCST:GoogleBilling.CANCELED canceled-->
[[Special:MyLanguage/GoogleBilling.DEVELOPER_ERROR|GoogleBilling.DEVELOPER_ERROR]]<br/>
+
[[Special:MyLanguage/GoogleBilling.DEVELOPER_ERROR|GoogleBilling.DEVELOPER_ERROR]]<br/><!-- GIDEROSCST:GoogleBilling.DEVELOPER_ERROR developerError-->
[[Special:MyLanguage/GoogleBilling.ERROR|GoogleBilling.ERROR]]<br/>
+
[[Special:MyLanguage/GoogleBilling.ERROR|GoogleBilling.ERROR]]<br/><!-- GIDEROSCST:GoogleBilling.ERROR error-->
[[Special:MyLanguage/GoogleBilling.EXPIRED|GoogleBilling.EXPIRED]]<br/>
+
[[Special:MyLanguage/GoogleBilling.EXPIRED|GoogleBilling.EXPIRED]]<br/><!-- GIDEROSCST:GoogleBilling.EXPIRED expired-->
[[Special:MyLanguage/GoogleBilling.INAPP|GoogleBilling.INAPP]]<br/>
+
[[Special:MyLanguage/GoogleBilling.INAPP|GoogleBilling.INAPP]]<br/><!-- GIDEROSCST:GoogleBilling.INAPP inapp-->
[[Special:MyLanguage/GoogleBilling.ITEM_UNAVAILABLE|GoogleBilling.ITEM_UNAVAILABLE]]<br/>
+
[[Special:MyLanguage/GoogleBilling.ITEM_UNAVAILABLE|GoogleBilling.ITEM_UNAVAILABLE]]<br/><!-- GIDEROSCST:GoogleBilling.ITEM_UNAVAILABLE itemUnavailable-->
[[Special:MyLanguage/GoogleBilling.OK|GoogleBilling.OK]]<br/>
+
[[Special:MyLanguage/GoogleBilling.OK|GoogleBilling.OK]]<br/><!-- GIDEROSCST:GoogleBilling.OK ok-->
[[Special:MyLanguage/GoogleBilling.PURCHASED|GoogleBilling.PURCHASED]]<br/>
+
[[Special:MyLanguage/GoogleBilling.PURCHASED|GoogleBilling.PURCHASED]]<br/><!-- GIDEROSCST:GoogleBilling.PURCHASED purchased-->
[[Special:MyLanguage/GoogleBilling.REFUNDED|GoogleBilling.REFUNDED]]<br/>
+
[[Special:MyLanguage/GoogleBilling.REFUNDED|GoogleBilling.REFUNDED]]<br/><!-- GIDEROSCST:GoogleBilling.REFUNDED refunded-->
[[Special:MyLanguage/GoogleBilling.SERVICE_UNAVAILABLE|GoogleBilling.SERVICE_UNAVAILABLE]]<br/>
+
[[Special:MyLanguage/GoogleBilling.SERVICE_UNAVAILABLE|GoogleBilling.SERVICE_UNAVAILABLE]]<br/><!-- GIDEROSCST:GoogleBilling.SERVICE_UNAVAILABLE serviceUnavailable-->
[[Special:MyLanguage/GoogleBilling.SUBS|GoogleBilling.SUBS]]<br/>
+
[[Special:MyLanguage/GoogleBilling.SUBS|GoogleBilling.SUBS]]<br/><!-- GIDEROSCST:GoogleBilling.SUBS subs-->
[[Special:MyLanguage/GoogleBilling.USER_CANCELED|GoogleBilling.USER_CANCELED]]<br/>
+
[[Special:MyLanguage/GoogleBilling.USER_CANCELED|GoogleBilling.USER_CANCELED]]<br/><!-- GIDEROSCST:GoogleBilling.USER_CANCELED userCanceled-->
 
|}
 
|}

Latest revision as of 15:32, 13 September 2018


Supported platforms: Platform android.png
Available since: Gideros 2012.09

Description


The GoogleBilling class is defined in the module "googlebilling". Therefore, you need to call
require("googlebilling") before using it. Loading the Google Billing module
also creates a global variable googlebilling of type GoogleBilling for direct use.


<h3>GoogleBilling Events and Response Codes</h3>

GoogleBilling class dispatches 5 events: Event.CHECK_BILLING_SUPPORTED_COMPLETE,
Event.REQUEST_PURCHASE_COMPLETE,Event.RESTORE_TRANSACTIONS_COMPLETE,
Event.CONFIRM_NOTIFICATION_COMPLETE and Event.PURCHASE_STATE_CHANGE.

Event.*_COMPLETE events contains a field event.responseCode which provides status information
and error information about a request. Response code can be one of these values:

<ul>
<li>GoogleBilling.OK: Indicates that the request was sent to the server successfully. When this code is returned</li>
</ul>
in response to a checkBillingSupported function, indicates that billing is supported.
<ul>
<li>GoogleBilling.USER_CANCELED: Indicates that the user pressed the back button on the checkout page instead of buying the item.</li>
<li>GoogleBilling.SERVICE_UNAVAILABLE: Indicates that the network connection is down.</li>
<li>GoogleBilling.BILLING_UNAVAILABLE: Indicates that in-app billing is not available because the API version that</li>
</ul>
you specified is not recognized by the Google Play application or the user is ineligible for in-app billing
(for example, the user resides in a country that prohibits in-app purchases).
<ul>
<li>GoogleBilling.ITEM_UNAVAILABLE: Indicates that Google Play cannot find the requested item in the application's product list.</li>
</ul>
This can happen if the product ID is misspelled in your requestPurchase function or if an item is unpublished in the application's product list.
<ul>
<li>GoogleBilling.DEVELOPER_ERROR: Indicates that an application is trying to make an in-app billing request but the application has not declared the</li>
</ul>
com.android.vending.BILLING permission in its manifest. Can also indicate that an application is not properly signed,
or that you sent a malformed request, such as a request with missing Bundle keys or a request that uses an unrecognized request type.
<ul>
<li>GoogleBilling.ERROR: Indicates an unexpected server error. For example, this error is triggered if you try to purchase an item from yourself, which is not allowed by Google Wallet.</li>
</ul>

<h3># Event.CHECK_BILLING_SUPPORTED_COMPLETE</h3>
Dispatched when checkBillingSuported function completes. It contains event.responseCode and event.productType fields.

<h3># Event.REQUEST_PURCHASE_COMPLETE</h3>
Dispatched when requestPurchase function completes. It contains event.responseCode, event.productId, event.productType and event.developerPayload fields.

<h3># Event.RESTORE_TRANSACTIONS_COMPLETE</h3>
Dispatched when restoreTransactions function completes. It contains event.responseCode fields.

<h3># Event.CONFIRM_NOTIFICATION_COMPLETE</h3>
Dispatched when confirmNotification function completes. It contains event.responseCode and event.notificationId fields.

<h3># Event.PURCHASE_STATE_CHANGE</h3>
Dispatched when information about a transaction is received. It contains event.purchaseState, event.productId, event.notificationId, event.purchaseTime and event.developerPayload fields.

Methods

GoogleBilling:checkBillingSupported
GoogleBilling:confirmNotification
GoogleBilling:requestPurchase
GoogleBilling:restoreTransactions
GoogleBilling:setApiVersion
GoogleBilling:setPublicKey

Events

Event.CHECK_BILLING_SUPPORTED_COMPLETE
Event.CONFIRM_NOTIFICATION_COMPLETE
Event.PURCHASE_STATE_CHANGE
Event.REQUEST_PURCHASE_COMPLETE
Event.RESTORE_TRANSACTIONS_COMPLETE

Constants

GoogleBilling.BILLING_UNAVAILABLE
GoogleBilling.CANCELED
GoogleBilling.DEVELOPER_ERROR
GoogleBilling.ERROR
GoogleBilling.EXPIRED
GoogleBilling.INAPP
GoogleBilling.ITEM_UNAVAILABLE
GoogleBilling.OK
GoogleBilling.PURCHASED
GoogleBilling.REFUNDED
GoogleBilling.SERVICE_UNAVAILABLE
GoogleBilling.SUBS
GoogleBilling.USER_CANCELED