AI-generated Key Takeaways
- 
          The SubscriptionPurchaseV2 resource indicates the status of a user's subscription purchase and provides detailed information about it. 
- 
          Subscriptions can exist in various states including pending, active, paused, in grace period, on hold, canceled, and expired. 
- 
          The CanceledStateContext provides information on why a subscription was canceled, such as user, system, developer, or replacement initiation. 
- 
          Subscription purchases can be tested, have acknowledgement states, and include external account identifiers. 
- 
          The resource provides details on different plan types, offer information, deferred item changes, and signup promotions. 
- Resource: SubscriptionPurchaseV2
- SubscriptionState
- PausedStateContext
- CanceledStateContext
- UserInitiatedCancellation
- CancelSurveyResult
- CancelSurveyReason
- SystemInitiatedCancellation
- DeveloperInitiatedCancellation
- ReplacementCancellation
- TestPurchase
- AcknowledgementState
- ExternalAccountIdentifiers
- SubscribeWithGoogleInfo
- SubscriptionPurchaseLineItem
- AutoRenewingPlan
- SubscriptionItemPriceChangeDetails
- PriceChangeMode
- PriceChangeState
- InstallmentPlan
- PendingCancellation
- PriceStepUpConsentDetails
- ConsentState
- PrepaidPlan
- OfferDetails
- DeferredItemReplacement
- DeferredItemRemoval
- SignupPromotion
- OneTimeCode
- VanityCode
- Methods
Resource: SubscriptionPurchaseV2
Indicates the status of a user's subscription purchase.
| JSON representation | 
|---|
| { "kind": string, "regionCode": string, "lineItems": [ { object ( | 
| Fields | |
|---|---|
| kind | 
 This kind represents a SubscriptionPurchaseV2 object in the androidpublisher service. | 
| regionCode | 
 ISO 3166-1 alpha-2 billing country/region code of the user at the time the subscription was granted. | 
| lineItems[] | 
 Item-level info for a subscription purchase. The items in the same purchase should be either all with AutoRenewingPlan or all with PrepaidPlan. | 
| startTime | 
 Time at which the subscription was granted. Not set for pending subscriptions (subscription was created but awaiting payment during signup). Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| subscriptionState | 
 The current state of the subscription. | 
| latestOrderId | 
 Deprecated: Use lineItems.latest_successful_order_id instead. The order id of the latest order associated with the purchase of the subscription. For autoRenewing subscription, this is the order id of signup order if it is not renewed yet, or the last recurring order id (success, pending, or declined order). For prepaid subscription, this is the order id associated with the queried purchase token. | 
| linkedPurchaseToken | 
 The purchase token of the old subscription if this subscription is one of the following: * Re-signup of a canceled but non-lapsed subscription * Upgrade/downgrade from a previous subscription. * Convert from prepaid to auto renewing subscription. * Convert from an auto renewing subscription to prepaid. * Topup a prepaid subscription. | 
| pausedStateContext | 
 Additional context around paused subscriptions. Only present if the subscription currently has subscriptionState SUBSCRIPTION_STATE_PAUSED. | 
| canceledStateContext | 
 Additional context around canceled subscriptions. Only present if the subscription currently has subscriptionState SUBSCRIPTION_STATE_CANCELED or SUBSCRIPTION_STATE_EXPIRED. | 
| testPurchase | 
 Only present if this subscription purchase is a test purchase. | 
| acknowledgementState | 
 The acknowledgement state of the subscription. | 
| externalAccountIdentifiers | 
 User account identifier in the third-party service. | 
| subscribeWithGoogleInfo | 
 User profile associated with purchases made with 'Subscribe with Google'. | 
SubscriptionState
The potential states a subscription can be in, for example whether it is active or canceled. The items within a subscription purchase can either be all auto renewing plans or prepaid plans.
| Enums | |
|---|---|
| SUBSCRIPTION_STATE_UNSPECIFIED | Unspecified subscription state. | 
| SUBSCRIPTION_STATE_PENDING | Subscription was created but awaiting payment during signup. In this state, all items are awaiting payment. | 
| SUBSCRIPTION_STATE_ACTIVE | Subscription is active. - (1) If the subscription is an auto renewing plan, at least one item is autoRenewEnabled and not expired. - (2) If the subscription is a prepaid plan, at least one item is not expired. | 
| SUBSCRIPTION_STATE_PAUSED | Subscription is paused. The state is only available when the subscription is an auto renewing plan. In this state, all items are in paused state. | 
| SUBSCRIPTION_STATE_IN_GRACE_PERIOD | Subscription is in grace period. The state is only available when the subscription is an auto renewing plan. In this state, all items are in grace period. | 
| SUBSCRIPTION_STATE_ON_HOLD | Subscription is on hold (suspended). The state is only available when the subscription is an auto renewing plan. In this state, all items are on hold. | 
| SUBSCRIPTION_STATE_CANCELED | Subscription is canceled but not expired yet. The state is only available when the subscription is an auto renewing plan. All items have autoRenewEnabled set to false. | 
| SUBSCRIPTION_STATE_EXPIRED | Subscription is expired. All items have expiryTime in the past. | 
| SUBSCRIPTION_STATE_PENDING_PURCHASE_CANCELED | Pending transaction for subscription is canceled. If this pending purchase was for an existing subscription, use linkedPurchaseToken to get the current state of that subscription. | 
PausedStateContext
Information specific to a subscription in paused state.
| JSON representation | 
|---|
| { "autoResumeTime": string } | 
| Fields | |
|---|---|
| autoResumeTime | 
 Time at which the subscription will be automatically resumed. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
CanceledStateContext
Information specific to a subscription in the SUBSCRIPTION_STATE_CANCELED or SUBSCRIPTION_STATE_EXPIRED state.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field cancellation_reason. The reason why a subscription was canceled.cancellation_reasoncan be only one of the following: | |
| userInitiatedCancellation | 
 Subscription was canceled by user. | 
| systemInitiatedCancellation | 
 Subscription was canceled by the system, for example because of a billing problem. | 
| developerInitiatedCancellation | 
 Subscription was canceled by the developer. | 
| replacementCancellation | 
 Subscription was replaced by a new subscription. | 
UserInitiatedCancellation
Information specific to cancellations initiated by users.
| JSON representation | 
|---|
| {
  "cancelSurveyResult": {
    object ( | 
| Fields | |
|---|---|
| cancelSurveyResult | 
 Information provided by the user when they complete the subscription cancellation flow (cancellation reason survey). | 
| cancelTime | 
 The time at which the subscription was canceled by the user. The user might still have access to the subscription after this time. Use lineItems.expiry_time to determine if a user still has access. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
CancelSurveyResult
Result of the cancel survey when the subscription was canceled by the user.
| JSON representation | 
|---|
| {
  "reason": enum ( | 
| Fields | |
|---|---|
| reason | 
 The reason the user selected in the cancel survey. | 
| reasonUserInput | 
 Only set for CANCEL_SURVEY_REASON_OTHERS. This is the user's freeform response to the survey. | 
CancelSurveyReason
The reason the user selected in the cancel survey.
| Enums | |
|---|---|
| CANCEL_SURVEY_REASON_UNSPECIFIED | Unspecified cancel survey reason. | 
| CANCEL_SURVEY_REASON_NOT_ENOUGH_USAGE | Not enough usage of the subscription. | 
| CANCEL_SURVEY_REASON_TECHNICAL_ISSUES | Technical issues while using the app. | 
| CANCEL_SURVEY_REASON_COST_RELATED | Cost related issues. | 
| CANCEL_SURVEY_REASON_FOUND_BETTER_APP | The user found a better app. | 
| CANCEL_SURVEY_REASON_OTHERS | Other reasons. | 
SystemInitiatedCancellation
This type has no fields.
Information specific to cancellations initiated by Google system.
DeveloperInitiatedCancellation
This type has no fields.
Information specific to cancellations initiated by developers.
ReplacementCancellation
This type has no fields.
Information specific to cancellations caused by subscription replacement.
TestPurchase
This type has no fields.
Whether this subscription purchase is a test purchase.
AcknowledgementState
The possible acknowledgement states for a subscription.
| Enums | |
|---|---|
| ACKNOWLEDGEMENT_STATE_UNSPECIFIED | Unspecified acknowledgement state. | 
| ACKNOWLEDGEMENT_STATE_PENDING | The subscription is not acknowledged yet. | 
| ACKNOWLEDGEMENT_STATE_ACKNOWLEDGED | The subscription is acknowledged. | 
ExternalAccountIdentifiers
User account identifier in the third-party service.
| JSON representation | 
|---|
| { "externalAccountId": string, "obfuscatedExternalAccountId": string, "obfuscatedExternalProfileId": string } | 
| Fields | |
|---|---|
| externalAccountId | 
 User account identifier in the third-party service. Only present if account linking happened as part of the subscription purchase flow. | 
| obfuscatedExternalAccountId | 
 An obfuscated version of the id that is uniquely associated with the user's account in your app. Present for the following purchases: * If account linking happened as part of the subscription purchase flow. * It was specified using https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedaccountid when the purchase was made. | 
| obfuscatedExternalProfileId | 
 An obfuscated version of the id that is uniquely associated with the user's profile in your app. Only present if specified using https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedprofileid when the purchase was made. | 
SubscribeWithGoogleInfo
Information associated with purchases made with 'Subscribe with Google'.
| JSON representation | 
|---|
| { "profileId": string, "profileName": string, "emailAddress": string, "givenName": string, "familyName": string } | 
| Fields | |
|---|---|
| profileId | 
 The Google profile id of the user when the subscription was purchased. | 
| profileName | 
 The profile name of the user when the subscription was purchased. | 
| emailAddress | 
 The email address of the user when the subscription was purchased. | 
| givenName | 
 The given name of the user when the subscription was purchased. | 
| familyName | 
 The family name of the user when the subscription was purchased. | 
SubscriptionPurchaseLineItem
Item-level info for a subscription purchase.
| JSON representation | 
|---|
| { "productId": string, "expiryTime": string, "latestSuccessfulOrderId": string, // Union field | 
| Fields | |
|---|---|
| productId | 
 The purchased product ID (for example, 'monthly001'). | 
| expiryTime | 
 Time at which the subscription expired or will expire unless the access is extended (ex. renews). Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| latestSuccessfulOrderId | 
 The order id of the latest successful order associated with this item. Not present if the item is not owned by the user yet (e.g. the item being deferred replaced to). | 
| Union field plan_type. The subscription plan type.plan_typecan be only one of the following: | |
| autoRenewingPlan | 
 The item is auto renewing. | 
| prepaidPlan | 
 The item is prepaid. | 
| offerDetails | 
 The offer details for this item. | 
| Union field deferred_item_change. The field is present when a item has a deferred change. It can either be removed or replaced.deferred_item_changecan be only one of the following: | |
| deferredItemReplacement | 
 Information for deferred item replacement. | 
| deferredItemRemoval | 
 Information for deferred item removal. | 
| signupPromotion | 
 Promotion details about this item. Only set if a promotion was applied during signup. | 
AutoRenewingPlan
Information related to an auto renewing plan.
| JSON representation | 
|---|
| { "autoRenewEnabled": boolean, "recurringPrice": { object ( | 
| Fields | |
|---|---|
| autoRenewEnabled | 
 If the subscription is currently set to auto-renew, e.g. the user has not canceled the subscription | 
| recurringPrice | 
 The current recurring price of the auto renewing plan. Note that the price does not take into account discounts and does not include taxes for tax-exclusive pricing, please call  | 
| priceChangeDetails | 
 The information of the last price change for the item since subscription signup. | 
| installmentDetails | 
 The installment plan commitment and state related info for the auto renewing plan. | 
| priceStepUpConsentDetails | 
 The information of the latest price step-up consent. | 
SubscriptionItemPriceChangeDetails
Price change related information of a subscription item.
| JSON representation | 
|---|
| { "newPrice": { object ( | 
| Fields | |
|---|---|
| newPrice | 
 New recurring price for the subscription item. | 
| priceChangeMode | 
 Price change mode specifies how the subscription item price is changing. | 
| priceChangeState | 
 State the price change is currently in. | 
| expectedNewPriceChargeTime | 
 The renewal time at which the price change will become effective for the user. This is subject to change(to a future time) due to cases where the renewal time shifts like pause. This field is only populated if the price change has not taken effect. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
PriceChangeMode
The mode of the price change.
| Enums | |
|---|---|
| PRICE_CHANGE_MODE_UNSPECIFIED | Price change mode unspecified. This value should never be set. | 
| PRICE_DECREASE | If the subscription price is decreasing. | 
| PRICE_INCREASE | If the subscription price is increasing and the user needs to accept it. | 
| OPT_OUT_PRICE_INCREASE | If the subscription price is increasing with opt out mode. | 
PriceChangeState
The state of the price change.
| Enums | |
|---|---|
| PRICE_CHANGE_STATE_UNSPECIFIED | Price change state unspecified. This value should not be used. | 
| OUTSTANDING | Waiting for the user to agree for the price change. | 
| CONFIRMED | The price change is confirmed to happen for the user. | 
| APPLIED | The price change is applied, i.e. the user has started being charged the new price. | 
| CANCELED | The price change was canceled. | 
InstallmentPlan
Information to a installment plan.
| JSON representation | 
|---|
| {
  "initialCommittedPaymentsCount": integer,
  "subsequentCommittedPaymentsCount": integer,
  "remainingCommittedPaymentsCount": integer,
  "pendingCancellation": {
    object ( | 
| Fields | |
|---|---|
| initialCommittedPaymentsCount | 
 Total number of payments the user is initially committed for. | 
| subsequentCommittedPaymentsCount | 
 Total number of payments the user will be committed for after each commitment period. Empty means the installment plan will fall back to a normal auto-renew subscription after initial commitment. | 
| remainingCommittedPaymentsCount | 
 Total number of committed payments remaining to be paid for in this renewal cycle. | 
| pendingCancellation | 
 If present, this installment plan is pending to be canceled. The cancellation will happen only after the user finished all committed payments. | 
PendingCancellation
This type has no fields.
This is an indicator of whether there is a pending cancellation on the virtual installment plan. The cancellation will happen only after the user finished all committed payments.
PriceStepUpConsentDetails
Information related to a price step-up that requires user consent.
| JSON representation | 
|---|
| { "state": enum ( | 
| Fields | |
|---|---|
| state | 
 Output only. The state of the price step-up consent. | 
| consentDeadlineTime | 
 The deadline by which the user must provide consent. If consent is not provided by this time, the subscription will be canceled. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
| newPrice | 
 The new price which requires user consent. | 
ConsentState
The state of the price step-up consent.
| Enums | |
|---|---|
| CONSENT_STATE_UNSPECIFIED | Unspecified consent state. | 
| PENDING | The user has not yet provided consent. | 
| CONFIRMED | The user has consented, and the new price is waiting to take effect. | 
| COMPLETED | The user has consented, and the new price has taken effect. | 
PrepaidPlan
Information related to a prepaid plan.
| JSON representation | 
|---|
| { "allowExtendAfterTime": string } | 
| Fields | |
|---|---|
| allowExtendAfterTime | 
 If present, this is the time after which top up purchases are allowed for the prepaid plan. Will not be present for expired prepaid plans. Uses RFC 3339, where generated output will always be Z-normalized and use 0, 3, 6 or 9 fractional digits. Offsets other than "Z" are also accepted. Examples:  | 
OfferDetails
Offer details information related to a purchase line item.
| JSON representation | 
|---|
| { "offerTags": [ string ], "basePlanId": string, "offerId": string } | 
| Fields | |
|---|---|
| offerTags[] | 
 The latest offer tags associated with the offer. It includes tags inherited from the base plan. | 
| basePlanId | 
 The base plan ID. Present for all base plan and offers. | 
| offerId | 
 The offer ID. Only present for discounted offers. | 
DeferredItemReplacement
Information related to deferred item replacement.
| JSON representation | 
|---|
| { "productId": string } | 
| Fields | |
|---|---|
| productId | 
 The productId going to replace the existing productId. | 
DeferredItemRemoval
This type has no fields.
Information related to deferred item replacement.
SignupPromotion
The promotion applied on this item when purchased.
| JSON representation | 
|---|
| { // Union field | 
| Fields | |
|---|---|
| Union field promotion_type. The type of promotion applied to the item.promotion_typecan be only one of the following: | |
| oneTimeCode | 
 A one-time code was applied. | 
| vanityCode | 
 A vanity code was applied. | 
OneTimeCode
This type has no fields.
A single use promotion code.
VanityCode
A multiple use, predefined promotion code.
| JSON representation | 
|---|
| { "promotionCode": string } | 
| Fields | |
|---|---|
| promotionCode | 
 The promotion code. | 
| Methods | |
|---|---|
| 
 | Cancel a subscription purchase for the user. | 
| 
 | Get metadata about a subscription | 
| 
 | Revoke a subscription purchase for the user. | 
Error codes
The operations of this resource, return the following HTTP error codes:
| Error code | Reason | Resolution | 
|---|---|---|
| 5xx | Generic error in the Google Play server. | Retry your request. If the problem persists contact your Google Play account manager or submit a support request. Consider checking the Play Status Dashboard for any known outages. | 
| 409 | Concurrency update error. There was an attempt to update an object that is being updated. For example, a purchase
      is getting acknowledged by calling the Play Billing Library's  | Retry your request. | 
| 410 | The subscription purchase is no longer available for query because it has been expired for too long. | Thrown when querying a subscription that has been expired for more than 60 days. You should no longer query these subscriptions. |