{
  "resources": {
    "monetization": {
      "methods": {
        "convertRegionPrices": {
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/pricing:convertRegionPrices",
          "request": {
            "$ref": "ConvertRegionPricesRequest"
          },
          "path": "androidpublisher/v3/applications/{packageName}/pricing:convertRegionPrices",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Calculates the region prices, using today's exchange rate and country-specific pricing patterns, based on the price in the request for a set of regions.",
          "response": {
            "$ref": "ConvertRegionPricesResponse"
          },
          "id": "androidpublisher.monetization.convertRegionPrices",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "description": "Required. The app package name.",
              "type": "string",
              "location": "path",
              "required": true
            }
          }
        }
      },
      "resources": {
        "onetimeproducts": {
          "resources": {
            "purchaseOptions": {
              "resources": {
                "offers": {
                  "methods": {
                    "batchUpdate": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchUpdate",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId"
                      ],
                      "parameters": {
                        "purchaseOptionId": {
                          "type": "string",
                          "description": "Required. The parent purchase option (ID) for which the offers should be updated. May be specified as '-' to update offers from multiple purchase options.",
                          "location": "path",
                          "required": true
                        },
                        "packageName": {
                          "description": "Required. The parent app (package name) of the updated offers. Must be equal to the package_name field on all the updated OneTimeProductOffer resources.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The product ID of the parent one-time product, if all updated offers belong to the same product. If this request spans multiple one-time products, set this field to \"-\"."
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.batchUpdate",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "BatchUpdateOneTimeProductOffersResponse"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Creates or updates one or more one-time product offers.",
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchUpdate",
                      "request": {
                        "$ref": "BatchUpdateOneTimeProductOffersRequest"
                      }
                    },
                    "batchUpdateStates": {
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Updates a batch of one-time product offer states.",
                      "request": {
                        "$ref": "BatchUpdateOneTimeProductOfferStatesRequest"
                      },
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchUpdateStates",
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.batchUpdateStates",
                      "httpMethod": "POST",
                      "parameters": {
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) of the updated one-time product offers.",
                          "type": "string"
                        },
                        "productId": {
                          "type": "string",
                          "description": "Required. The product ID of the parent one-time product, if all updated offers belong to the same one-time product. If this batch update spans multiple one-time products, set this field to \"-\".",
                          "location": "path",
                          "required": true
                        },
                        "purchaseOptionId": {
                          "type": "string",
                          "description": "Required. The purchase option ID of the parent purchase option, if all updated offers belong to the same purchase option. If this batch update spans multiple purchase options, set this field to \"-\".",
                          "location": "path",
                          "required": true
                        }
                      },
                      "response": {
                        "$ref": "BatchUpdateOneTimeProductOfferStatesResponse"
                      },
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchUpdateStates"
                    },
                    "batchGet": {
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchGet",
                      "request": {
                        "$ref": "BatchGetOneTimeProductOffersRequest"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Reads one or more one-time product offers.",
                      "response": {
                        "$ref": "BatchGetOneTimeProductOffersResponse"
                      },
                      "parameters": {
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) of the updated offers. Must be equal to the package_name field on all the updated OneTimeProductOffer resources.",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "description": "Required. The product ID of the parent one-time product, if all updated offers belong to the same product. If this request spans multiple one-time products, set this field to \"-\".",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "purchaseOptionId": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent purchase option (ID) for which the offers should be updated. May be specified as '-' to update offers from multiple purchase options.",
                          "type": "string"
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.batchGet",
                      "httpMethod": "POST",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchGet"
                    },
                    "cancel": {
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId",
                        "offerId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:cancel",
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Cancels a one-time product offer.",
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:cancel",
                      "request": {
                        "$ref": "CancelOneTimeProductOfferRequest"
                      },
                      "parameters": {
                        "packageName": {
                          "description": "Required. The parent app (package name) of the offer to cancel.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The parent one-time product (ID) of the offer to cancel."
                        },
                        "purchaseOptionId": {
                          "description": "Required. The parent purchase option (ID) of the offer to cancel.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "description": "Required. The offer ID of the offer to cancel.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.cancel",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "OneTimeProductOffer"
                      }
                    },
                    "deactivate": {
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.deactivate",
                      "httpMethod": "POST",
                      "parameters": {
                        "purchaseOptionId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The parent purchase option (ID) of the offer to deactivate."
                        },
                        "offerId": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The offer ID of the offer to deactivate.",
                          "type": "string"
                        },
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) of the offer to deactivate.",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The parent one-time product (ID) of the offer to deactivate."
                        }
                      },
                      "response": {
                        "$ref": "OneTimeProductOffer"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Deactivates a one-time product offer.",
                      "request": {
                        "$ref": "DeactivateOneTimeProductOfferRequest"
                      },
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:deactivate",
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:deactivate",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId",
                        "offerId"
                      ]
                    },
                    "activate": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:activate",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId",
                        "offerId"
                      ],
                      "response": {
                        "$ref": "OneTimeProductOffer"
                      },
                      "parameters": {
                        "packageName": {
                          "description": "Required. The parent app (package name) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "description": "Required. The parent one-time product (ID) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "purchaseOptionId": {
                          "description": "Required. The parent purchase option (ID) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The offer ID of the offer to activate.",
                          "type": "string"
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.activate",
                      "httpMethod": "POST",
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers/{offerId}:activate",
                      "request": {
                        "$ref": "ActivateOneTimeProductOfferRequest"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Activates a one-time product offer."
                    },
                    "list": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId"
                      ],
                      "parameters": {
                        "productId": {
                          "description": "Required. The parent one-time product (ID) for which the offers should be read. May be specified as '-' to read all offers under an app.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "purchaseOptionId": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent purchase option (ID) for which the offers should be read. May be specified as '-' to read all offers under a one-time product or an app. Must be specified as '-' if product_id is specified as '-'.",
                          "type": "string"
                        },
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) for which the offers should be read.",
                          "location": "path",
                          "required": true
                        },
                        "pageSize": {
                          "location": "query",
                          "type": "integer",
                          "format": "int32",
                          "description": "Optional. The maximum number of offers to return. The service may return fewer than this value. If unspecified, at most 50 offers will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000."
                        },
                        "pageToken": {
                          "description": "Optional. A page token, received from a previous `ListOneTimeProductsOffers` call. Provide this to retrieve the subsequent page. When paginating, product_id, package_name and purchase_option_id provided to `ListOneTimeProductsOffersRequest` must match the call that provided the page token.",
                          "type": "string",
                          "location": "query"
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.list",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "ListOneTimeProductOffersResponse"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Lists all offers under a given app, product, or purchase option.",
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers"
                    },
                    "batchDelete": {
                      "parameters": {
                        "purchaseOptionId": {
                          "description": "Required. The parent purchase option (ID) for which the offers should be deleted. May be specified as '-' to update offers from multiple purchase options.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) of the offers to delete. Must be equal to the package_name field on all the OneTimeProductOffer resources.",
                          "type": "string"
                        },
                        "productId": {
                          "type": "string",
                          "description": "Required. The product ID of the parent one-time product, if all offers to delete belong to the same product. If this request spans multiple one-time products, set this field to \"-\".",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.offers.batchDelete",
                      "httpMethod": "POST",
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Deletes one or more one-time product offers.",
                      "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchDelete",
                      "request": {
                        "$ref": "BatchDeleteOneTimeProductOffersRequest"
                      },
                      "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions/{purchaseOptionId}/offers:batchDelete",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "purchaseOptionId"
                      ]
                    }
                  }
                }
              },
              "methods": {
                "batchUpdateStates": {
                  "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions:batchUpdateStates",
                  "parameterOrder": [
                    "packageName",
                    "productId"
                  ],
                  "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.batchUpdateStates",
                  "httpMethod": "POST",
                  "parameters": {
                    "packageName": {
                      "type": "string",
                      "description": "Required. The parent app (package name) of the updated purchase options.",
                      "location": "path",
                      "required": true
                    },
                    "productId": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The product ID of the parent one-time product, if all updated purchase options belong to the same one-time product. If this batch update spans multiple one-time products, set this field to \"-\".",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "BatchUpdatePurchaseOptionStatesResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Activates or deactivates purchase options across one or multiple one-time products.",
                  "request": {
                    "$ref": "BatchUpdatePurchaseOptionStatesRequest"
                  },
                  "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions:batchUpdateStates"
                },
                "batchDelete": {
                  "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions:batchDelete",
                  "parameterOrder": [
                    "packageName",
                    "productId"
                  ],
                  "id": "androidpublisher.monetization.onetimeproducts.purchaseOptions.batchDelete",
                  "httpMethod": "POST",
                  "parameters": {
                    "packageName": {
                      "type": "string",
                      "description": "Required. The parent app (package name) of the purchase options to delete.",
                      "location": "path",
                      "required": true
                    },
                    "productId": {
                      "description": "Required. The product ID of the parent one-time product, if all purchase options to delete belong to the same one-time product. If this batch delete spans multiple one-time products, set this field to \"-\".",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Deletes purchase options across one or multiple one-time products. By default this operation will fail if there are any existing offers under the deleted purchase options. Use the force parameter to override the default behavior.",
                  "request": {
                    "$ref": "BatchDeletePurchaseOptionsRequest"
                  },
                  "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}/purchaseOptions:batchDelete"
                }
              }
            }
          },
          "methods": {
            "batchGet": {
              "parameterOrder": [
                "packageName"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchGet",
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchGet",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Reads one or more one-time products.",
              "response": {
                "$ref": "BatchGetOneTimeProductsResponse"
              },
              "parameters": {
                "productIds": {
                  "type": "string",
                  "description": "Required. A list of up to 100 product IDs to retrieve. All IDs must be different.",
                  "repeated": true,
                  "location": "query"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) for which the products should be retrieved. Must be equal to the package_name field on all requests."
                }
              },
              "id": "androidpublisher.monetization.onetimeproducts.batchGet",
              "httpMethod": "GET"
            },
            "get": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Reads a single one-time product.",
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}",
              "id": "androidpublisher.monetization.onetimeproducts.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) of the product to retrieve."
                },
                "productId": {
                  "type": "string",
                  "description": "Required. The product ID of the product to retrieve.",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "OneTimeProduct"
              },
              "parameterOrder": [
                "packageName",
                "productId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}"
            },
            "batchUpdate": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchUpdate",
              "parameterOrder": [
                "packageName"
              ],
              "id": "androidpublisher.monetization.onetimeproducts.batchUpdate",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) for which the one-time products should be updated. Must be equal to the package_name field on all the OneTimeProduct resources."
                }
              },
              "response": {
                "$ref": "BatchUpdateOneTimeProductsResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates or updates one or more one-time products.",
              "request": {
                "$ref": "BatchUpdateOneTimeProductsRequest"
              },
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchUpdate"
            },
            "list": {
              "id": "androidpublisher.monetization.onetimeproducts.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "description": "Required. The parent app (package name) for which the one-time product should be read.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "pageSize": {
                  "description": "Optional. The maximum number of one-time product to return. The service may return fewer than this value. If unspecified, at most 50 one-time products will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                  "type": "integer",
                  "format": "int32",
                  "location": "query"
                },
                "pageToken": {
                  "location": "query",
                  "description": "Optional. A page token, received from a previous `ListOneTimeProducts` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListOneTimeProducts` must match the call that provided the page token.",
                  "type": "string"
                }
              },
              "response": {
                "$ref": "ListOneTimeProductsResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all one-time products under a given app.",
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts",
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts",
              "parameterOrder": [
                "packageName"
              ]
            },
            "patch": {
              "parameterOrder": [
                "packageName",
                "productId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/onetimeproducts/{productId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates or updates a one-time product.",
              "request": {
                "$ref": "OneTimeProduct"
              },
              "path": "androidpublisher/v3/applications/{packageName}/onetimeproducts/{productId}",
              "id": "androidpublisher.monetization.onetimeproducts.patch",
              "httpMethod": "PATCH",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Required. Immutable. Package name of the parent app.",
                  "type": "string"
                },
                "regionsVersion.version": {
                  "type": "string",
                  "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available.",
                  "location": "query"
                },
                "latencyTolerance": {
                  "enum": [
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
                  ],
                  "location": "query",
                  "enumDescriptions": [
                    "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                    "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                    "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
                  ],
                  "description": "Optional. The latency tolerance for the propagation of this product upsert. Defaults to latency-sensitive.",
                  "type": "string"
                },
                "updateMask": {
                  "location": "query",
                  "type": "string",
                  "format": "google-fieldmask",
                  "description": "Required. The list of fields to be updated."
                },
                "productId": {
                  "type": "string",
                  "description": "Required. Immutable. Unique product ID of the product. Unique within the parent app. Product IDs must start with a number or lowercase letter, and can contain numbers (0-9), lowercase letters (a-z), underscores (_), and periods (.).",
                  "location": "path",
                  "required": true
                },
                "allowMissing": {
                  "type": "boolean",
                  "description": "Optional. If set to true, and the one-time product with the given package_name and product_id doesn't exist, the one-time product will be created. If a new one-time product is created, update_mask is ignored.",
                  "location": "query"
                }
              },
              "response": {
                "$ref": "OneTimeProduct"
              }
            },
            "delete": {
              "id": "androidpublisher.monetization.onetimeproducts.delete",
              "httpMethod": "DELETE",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The parent app (package name) of the one-time product to delete.",
                  "type": "string"
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The one-time product ID of the one-time product to delete.",
                  "type": "string"
                },
                "latencyTolerance": {
                  "type": "string",
                  "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
                  "enumDescriptions": [
                    "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                    "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                    "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
                  ],
                  "location": "query",
                  "enum": [
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
                  ]
                }
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes a one-time product.",
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts/{productId}",
              "parameterOrder": [
                "packageName",
                "productId"
              ]
            },
            "batchDelete": {
              "parameters": {
                "packageName": {
                  "description": "Required. The parent app (package name) for which the one-time products should be deleted. Must be equal to the package_name field on all the OneTimeProduct resources.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.monetization.onetimeproducts.batchDelete",
              "httpMethod": "POST",
              "path": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchDelete",
              "request": {
                "$ref": "BatchDeleteOneTimeProductsRequest"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes one or more one-time products.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/oneTimeProducts:batchDelete",
              "parameterOrder": [
                "packageName"
              ]
            }
          }
        },
        "subscriptions": {
          "resources": {
            "basePlans": {
              "methods": {
                "deactivate": {
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:deactivate",
                  "parameterOrder": [
                    "packageName",
                    "productId",
                    "basePlanId"
                  ],
                  "id": "androidpublisher.monetization.subscriptions.basePlans.deactivate",
                  "httpMethod": "POST",
                  "parameters": {
                    "basePlanId": {
                      "description": "Required. The unique base plan ID of the base plan to deactivate.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "packageName": {
                      "description": "Required. The parent app (package name) of the base plan to deactivate.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "productId": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The parent subscription (ID) of the base plan to deactivate."
                    }
                  },
                  "response": {
                    "$ref": "Subscription"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Deactivates a base plan. Once deactivated, the base plan will become unavailable to new subscribers, but existing subscribers will maintain their subscription",
                  "request": {
                    "$ref": "DeactivateBasePlanRequest"
                  },
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:deactivate"
                },
                "activate": {
                  "parameters": {
                    "basePlanId": {
                      "description": "Required. The unique base plan ID of the base plan to activate.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "packageName": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The parent app (package name) of the base plan to activate."
                    },
                    "productId": {
                      "type": "string",
                      "description": "Required. The parent subscription (ID) of the base plan to activate.",
                      "location": "path",
                      "required": true
                    }
                  },
                  "id": "androidpublisher.monetization.subscriptions.basePlans.activate",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "Subscription"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Activates a base plan. Once activated, base plans will be available to new subscribers.",
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:activate",
                  "request": {
                    "$ref": "ActivateBasePlanRequest"
                  },
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:activate",
                  "parameterOrder": [
                    "packageName",
                    "productId",
                    "basePlanId"
                  ]
                },
                "batchUpdateStates": {
                  "parameterOrder": [
                    "packageName",
                    "productId"
                  ],
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans:batchUpdateStates",
                  "request": {
                    "$ref": "BatchUpdateBasePlanStatesRequest"
                  },
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans:batchUpdateStates",
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Activates or deactivates base plans across one or multiple subscriptions. Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput.",
                  "response": {
                    "$ref": "BatchUpdateBasePlanStatesResponse"
                  },
                  "id": "androidpublisher.monetization.subscriptions.basePlans.batchUpdateStates",
                  "httpMethod": "POST",
                  "parameters": {
                    "packageName": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. The parent app (package name) of the updated base plans."
                    },
                    "productId": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The product ID of the parent subscription, if all updated base plans belong to the same subscription. If this batch update spans multiple subscriptions, set this field to \"-\". Must be set.",
                      "type": "string"
                    }
                  }
                },
                "migratePrices": {
                  "response": {
                    "$ref": "MigrateBasePlanPricesResponse"
                  },
                  "parameters": {
                    "packageName": {
                      "location": "path",
                      "required": true,
                      "type": "string",
                      "description": "Required. Package name of the parent app. Must be equal to the package_name field on the Subscription resource."
                    },
                    "productId": {
                      "type": "string",
                      "description": "Required. The ID of the subscription to update. Must be equal to the product_id field on the Subscription resource.",
                      "location": "path",
                      "required": true
                    },
                    "basePlanId": {
                      "type": "string",
                      "description": "Required. The unique base plan ID of the base plan to update prices on.",
                      "location": "path",
                      "required": true
                    }
                  },
                  "id": "androidpublisher.monetization.subscriptions.basePlans.migratePrices",
                  "httpMethod": "POST",
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:migratePrices",
                  "request": {
                    "$ref": "MigrateBasePlanPricesRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Migrates subscribers from one or more legacy price cohorts to the current price. Requests result in Google Play notifying affected subscribers. Only up to 250 simultaneous legacy price cohorts are supported.",
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}:migratePrices",
                  "parameterOrder": [
                    "packageName",
                    "productId",
                    "basePlanId"
                  ]
                },
                "delete": {
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}",
                  "parameterOrder": [
                    "packageName",
                    "productId",
                    "basePlanId"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Deletes a base plan. Can only be done for draft base plans. This action is irreversible.",
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}",
                  "parameters": {
                    "packageName": {
                      "type": "string",
                      "description": "Required. The parent app (package name) of the base plan to delete.",
                      "location": "path",
                      "required": true
                    },
                    "productId": {
                      "description": "Required. The parent subscription (ID) of the base plan to delete.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    },
                    "basePlanId": {
                      "type": "string",
                      "description": "Required. The unique offer ID of the base plan to delete.",
                      "location": "path",
                      "required": true
                    }
                  },
                  "id": "androidpublisher.monetization.subscriptions.basePlans.delete",
                  "httpMethod": "DELETE"
                },
                "batchMigratePrices": {
                  "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans:batchMigratePrices",
                  "parameterOrder": [
                    "packageName",
                    "productId"
                  ],
                  "id": "androidpublisher.monetization.subscriptions.basePlans.batchMigratePrices",
                  "httpMethod": "POST",
                  "parameters": {
                    "packageName": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The parent app (package name) for which the subscriptions should be created or updated. Must be equal to the package_name field on all the Subscription resources.",
                      "type": "string"
                    },
                    "productId": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The product ID of the parent subscription, if all updated offers belong to the same subscription. If this batch update spans multiple subscriptions, set this field to \"-\". Must be set.",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "BatchMigrateBasePlanPricesResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Batch variant of the MigrateBasePlanPrices endpoint. Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput.",
                  "request": {
                    "$ref": "BatchMigrateBasePlanPricesRequest"
                  },
                  "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans:batchMigratePrices"
                }
              },
              "resources": {
                "offers": {
                  "methods": {
                    "batchUpdate": {
                      "response": {
                        "$ref": "BatchUpdateSubscriptionOffersResponse"
                      },
                      "parameters": {
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) of the updated subscription offers. Must be equal to the package_name field on all the updated SubscriptionOffer resources.",
                          "type": "string"
                        },
                        "productId": {
                          "description": "Required. The product ID of the parent subscription, if all updated offers belong to the same subscription. If this request spans multiple subscriptions, set this field to \"-\". Must be set.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) for which the offers should be updated. May be specified as '-' to update offers from multiple base plans.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.batchUpdate",
                      "httpMethod": "POST",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchUpdate",
                      "request": {
                        "$ref": "BatchUpdateSubscriptionOffersRequest"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Updates a batch of subscription offers. Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput.",
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchUpdate",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId"
                      ]
                    },
                    "batchUpdateStates": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchUpdateStates",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId"
                      ],
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.batchUpdateStates",
                      "httpMethod": "POST",
                      "parameters": {
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) of the updated subscription offers. Must be equal to the package_name field on all the updated SubscriptionOffer resources.",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "type": "string",
                          "description": "Required. The product ID of the parent subscription, if all updated offers belong to the same subscription. If this request spans multiple subscriptions, set this field to \"-\". Must be set.",
                          "location": "path",
                          "required": true
                        },
                        "basePlanId": {
                          "type": "string",
                          "description": "Required. The parent base plan (ID) for which the offers should be updated. May be specified as '-' to update offers from multiple base plans.",
                          "location": "path",
                          "required": true
                        }
                      },
                      "response": {
                        "$ref": "BatchUpdateSubscriptionOfferStatesResponse"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Updates a batch of subscription offer states. Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput.",
                      "request": {
                        "$ref": "BatchUpdateSubscriptionOfferStatesRequest"
                      },
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchUpdateStates"
                    },
                    "patch": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId",
                        "offerId"
                      ],
                      "parameters": {
                        "basePlanId": {
                          "location": "path",
                          "required": true,
                          "description": "Required. Immutable. The ID of the base plan to which this offer is an extension.",
                          "type": "string"
                        },
                        "updateMask": {
                          "type": "string",
                          "format": "google-fieldmask",
                          "description": "Required. The list of fields to be updated.",
                          "location": "query"
                        },
                        "packageName": {
                          "type": "string",
                          "description": "Required. Immutable. The package name of the app the parent subscription belongs to.",
                          "location": "path",
                          "required": true
                        },
                        "regionsVersion.version": {
                          "location": "query",
                          "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available.",
                          "type": "string"
                        },
                        "latencyTolerance": {
                          "enum": [
                            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
                          ],
                          "location": "query",
                          "enumDescriptions": [
                            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
                          ],
                          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
                          "type": "string"
                        },
                        "offerId": {
                          "description": "Required. Immutable. Unique ID of this subscription offer. Must be unique within the base plan.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "allowMissing": {
                          "description": "Optional. If set to true, and the subscription offer with the given package_name, product_id, base_plan_id and offer_id doesn't exist, an offer will be created. If a new offer is created, update_mask is ignored.",
                          "type": "boolean",
                          "location": "query"
                        },
                        "productId": {
                          "description": "Required. Immutable. The ID of the parent subscription this offer belongs to.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.patch",
                      "httpMethod": "PATCH",
                      "response": {
                        "$ref": "SubscriptionOffer"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Updates an existing subscription offer.",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "request": {
                        "$ref": "SubscriptionOffer"
                      }
                    },
                    "batchGet": {
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Reads one or more subscription offers.",
                      "request": {
                        "$ref": "BatchGetSubscriptionOffersRequest"
                      },
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchGet",
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.batchGet",
                      "httpMethod": "POST",
                      "parameters": {
                        "basePlanId": {
                          "type": "string",
                          "description": "Required. The parent base plan (ID) for which the offers should be read. May be specified as '-' to read offers from multiple base plans.",
                          "location": "path",
                          "required": true
                        },
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) for which the subscriptions should be created or updated. Must be equal to the package_name field on all the requests.",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "type": "string",
                          "description": "Required. The product ID of the parent subscription, if all updated offers belong to the same subscription. If this request spans multiple subscriptions, set this field to \"-\". Must be set.",
                          "location": "path",
                          "required": true
                        }
                      },
                      "response": {
                        "$ref": "BatchGetSubscriptionOffersResponse"
                      },
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers:batchGet"
                    },
                    "deactivate": {
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId",
                        "offerId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}:deactivate",
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Deactivates a subscription offer. Once deactivated, existing subscribers will maintain their subscription, but the offer will become unavailable to new subscribers.",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}:deactivate",
                      "request": {
                        "$ref": "DeactivateSubscriptionOfferRequest"
                      },
                      "parameters": {
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The parent app (package name) of the offer to deactivate."
                        },
                        "productId": {
                          "description": "Required. The parent subscription (ID) of the offer to deactivate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "description": "Required. The unique offer ID of the offer to deactivate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) of the offer to deactivate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.deactivate",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "SubscriptionOffer"
                      }
                    },
                    "activate": {
                      "response": {
                        "$ref": "SubscriptionOffer"
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.activate",
                      "httpMethod": "POST",
                      "parameters": {
                        "packageName": {
                          "description": "Required. The parent app (package name) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "description": "Required. The parent subscription (ID) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "type": "string",
                          "description": "Required. The unique offer ID of the offer to activate.",
                          "location": "path",
                          "required": true
                        },
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) of the offer to activate.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "request": {
                        "$ref": "ActivateSubscriptionOfferRequest"
                      },
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}:activate",
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Activates a subscription offer. Once activated, subscription offers will be available to new subscribers.",
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}:activate",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId",
                        "offerId"
                      ]
                    },
                    "get": {
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId",
                        "offerId"
                      ],
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Reads a single offer",
                      "response": {
                        "$ref": "SubscriptionOffer"
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.get",
                      "httpMethod": "GET",
                      "parameters": {
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) of the offer to get.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The unique offer ID of the offer to get."
                        },
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) of the offer to get.",
                          "type": "string"
                        },
                        "productId": {
                          "description": "Required. The parent subscription (ID) of the offer to get.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      }
                    },
                    "create": {
                      "parameters": {
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) for which the offer should be created. Must be equal to the package_name field on the Subscription resource.",
                          "type": "string"
                        },
                        "regionsVersion.version": {
                          "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available.",
                          "type": "string",
                          "location": "query"
                        },
                        "offerId": {
                          "type": "string",
                          "description": "Required. The ID to use for the offer. For the requirements on this format, see the documentation of the offer_id field on the SubscriptionOffer resource.",
                          "location": "query"
                        },
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) for which the offer should be created. Must be equal to the base_plan_id field on the SubscriptionOffer resource.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "description": "Required. The parent subscription (ID) for which the offer should be created. Must be equal to the product_id field on the SubscriptionOffer resource.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.create",
                      "httpMethod": "POST",
                      "response": {
                        "$ref": "SubscriptionOffer"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Creates a new subscription offer. Only auto-renewing base plans can have subscription offers. The offer state will be DRAFT until it is activated.",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers",
                      "request": {
                        "$ref": "SubscriptionOffer"
                      },
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId"
                      ]
                    },
                    "list": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId"
                      ],
                      "parameters": {
                        "packageName": {
                          "location": "path",
                          "required": true,
                          "description": "Required. The parent app (package name) for which the subscriptions should be read.",
                          "type": "string"
                        },
                        "pageSize": {
                          "type": "integer",
                          "format": "int32",
                          "description": "The maximum number of subscriptions to return. The service may return fewer than this value. If unspecified, at most 50 subscriptions will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                          "location": "query"
                        },
                        "pageToken": {
                          "location": "query",
                          "type": "string",
                          "description": "A page token, received from a previous `ListSubscriptionsOffers` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListSubscriptionOffers` must match the call that provided the page token."
                        },
                        "basePlanId": {
                          "description": "Required. The parent base plan (ID) for which the offers should be read. May be specified as '-' to read all offers under a subscription or an app. Must be specified as '-' if product_id is specified as '-'.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "location": "path",
                          "required": true,
                          "type": "string",
                          "description": "Required. The parent subscription (ID) for which the offers should be read. May be specified as '-' to read all offers under an app."
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.list",
                      "httpMethod": "GET",
                      "response": {
                        "$ref": "ListSubscriptionOffersResponse"
                      },
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Lists all offers under a given subscription.",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers"
                    },
                    "delete": {
                      "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "parameters": {
                        "basePlanId": {
                          "type": "string",
                          "description": "Required. The parent base plan (ID) of the offer to delete.",
                          "location": "path",
                          "required": true
                        },
                        "offerId": {
                          "type": "string",
                          "description": "Required. The unique offer ID of the offer to delete.",
                          "location": "path",
                          "required": true
                        },
                        "packageName": {
                          "type": "string",
                          "description": "Required. The parent app (package name) of the offer to delete.",
                          "location": "path",
                          "required": true
                        },
                        "productId": {
                          "description": "Required. The parent subscription (ID) of the offer to delete.",
                          "type": "string",
                          "location": "path",
                          "required": true
                        }
                      },
                      "id": "androidpublisher.monetization.subscriptions.basePlans.offers.delete",
                      "httpMethod": "DELETE",
                      "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}/basePlans/{basePlanId}/offers/{offerId}",
                      "parameterOrder": [
                        "packageName",
                        "productId",
                        "basePlanId",
                        "offerId"
                      ],
                      "scopes": [
                        "https://www.googleapis.com/auth/androidpublisher"
                      ],
                      "description": "Deletes a subscription offer. Can only be done for draft offers. This action is irreversible."
                    }
                  }
                }
              }
            }
          },
          "methods": {
            "get": {
              "parameterOrder": [
                "packageName",
                "productId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}",
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Reads a single subscription.",
              "response": {
                "$ref": "Subscription"
              },
              "id": "androidpublisher.monetization.subscriptions.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Required. The parent app (package name) of the subscription to get.",
                  "location": "path",
                  "required": true
                },
                "productId": {
                  "type": "string",
                  "description": "Required. The unique product ID of the subscription to get.",
                  "location": "path",
                  "required": true
                }
              }
            },
            "create": {
              "parameterOrder": [
                "packageName"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions",
              "request": {
                "$ref": "Subscription"
              },
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates a new subscription. Newly added base plans will remain in draft state until activated.",
              "response": {
                "$ref": "Subscription"
              },
              "id": "androidpublisher.monetization.subscriptions.create",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "description": "Required. The parent app (package name) for which the subscription should be created. Must be equal to the package_name field on the Subscription resource.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "productId": {
                  "location": "query",
                  "type": "string",
                  "description": "Required. The ID to use for the subscription. For the requirements on this format, see the documentation of the product_id field on the Subscription resource."
                },
                "regionsVersion.version": {
                  "type": "string",
                  "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available.",
                  "location": "query"
                }
              }
            },
            "batchUpdate": {
              "id": "androidpublisher.monetization.subscriptions.batchUpdate",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Required. The parent app (package name) for which the subscriptions should be updated. Must be equal to the package_name field on all the Subscription resources.",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "BatchUpdateSubscriptionsResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates a batch of subscriptions. Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput.",
              "request": {
                "$ref": "BatchUpdateSubscriptionsRequest"
              },
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions:batchUpdate",
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions:batchUpdate",
              "parameterOrder": [
                "packageName"
              ]
            },
            "batchGet": {
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions:batchGet",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Reads one or more subscriptions.",
              "response": {
                "$ref": "BatchGetSubscriptionsResponse"
              },
              "parameters": {
                "productIds": {
                  "type": "string",
                  "description": "Required. A list of up to 100 subscription product IDs to retrieve. All the IDs must be different.",
                  "repeated": true,
                  "location": "query"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) for which the subscriptions should be retrieved. Must be equal to the package_name field on all the requests."
                }
              },
              "id": "androidpublisher.monetization.subscriptions.batchGet",
              "httpMethod": "GET",
              "parameterOrder": [
                "packageName"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions:batchGet"
            },
            "list": {
              "id": "androidpublisher.monetization.subscriptions.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The parent app (package name) for which the subscriptions should be read.",
                  "type": "string"
                },
                "pageSize": {
                  "type": "integer",
                  "format": "int32",
                  "description": "The maximum number of subscriptions to return. The service may return fewer than this value. If unspecified, at most 50 subscriptions will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                  "location": "query"
                },
                "pageToken": {
                  "type": "string",
                  "description": "A page token, received from a previous `ListSubscriptions` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListSubscriptions` must match the call that provided the page token.",
                  "location": "query"
                },
                "showArchived": {
                  "type": "boolean",
                  "description": "Deprecated: subscription archiving is not supported.",
                  "deprecated": true,
                  "location": "query"
                }
              },
              "response": {
                "$ref": "ListSubscriptionsResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all subscriptions under a given app.",
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions",
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions",
              "parameterOrder": [
                "packageName"
              ]
            },
            "patch": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Immutable. Package name of the parent app.",
                  "type": "string"
                },
                "regionsVersion.version": {
                  "type": "string",
                  "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available.",
                  "location": "query"
                },
                "latencyTolerance": {
                  "enum": [
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                    "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
                  ],
                  "location": "query",
                  "enumDescriptions": [
                    "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                    "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                    "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
                  ],
                  "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
                  "type": "string"
                },
                "updateMask": {
                  "type": "string",
                  "format": "google-fieldmask",
                  "description": "Required. The list of fields to be updated.",
                  "location": "query"
                },
                "productId": {
                  "description": "Immutable. Unique product ID of the product. Unique within the parent app. Product IDs must be composed of lower-case letters (a-z), numbers (0-9), underscores (_) and dots (.). It must start with a lower-case letter or number, and be between 1 and 40 (inclusive) characters in length.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "allowMissing": {
                  "location": "query",
                  "type": "boolean",
                  "description": "Optional. If set to true, and the subscription with the given package_name and product_id doesn't exist, the subscription will be created. If a new subscription is created, update_mask is ignored."
                }
              },
              "id": "androidpublisher.monetization.subscriptions.patch",
              "httpMethod": "PATCH",
              "response": {
                "$ref": "Subscription"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates an existing subscription.",
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}",
              "request": {
                "$ref": "Subscription"
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}",
              "parameterOrder": [
                "packageName",
                "productId"
              ]
            },
            "delete": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes a subscription. A subscription can only be deleted if it has never had a base plan published.",
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}",
              "parameterOrder": [
                "packageName",
                "productId"
              ],
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) of the app of the subscription to delete."
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The unique product ID of the subscription to delete."
                }
              },
              "id": "androidpublisher.monetization.subscriptions.delete",
              "httpMethod": "DELETE",
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}"
            },
            "archive": {
              "path": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}:archive",
              "request": {
                "$ref": "ArchiveSubscriptionRequest"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deprecated: subscription archiving is not supported.",
              "response": {
                "$ref": "Subscription"
              },
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The parent app (package name) of the app of the subscription to delete."
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The unique product ID of the subscription to delete.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.monetization.subscriptions.archive",
              "httpMethod": "POST",
              "parameterOrder": [
                "packageName",
                "productId"
              ],
              "deprecated": true,
              "flatPath": "androidpublisher/v3/applications/{packageName}/subscriptions/{productId}:archive"
            }
          }
        }
      }
    },
    "apprecovery": {
      "methods": {
        "create": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/appRecoveries",
          "parameterOrder": [
            "packageName"
          ],
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Required. Package name of the app on which recovery action is performed.",
              "type": "string"
            }
          },
          "id": "androidpublisher.apprecovery.create",
          "httpMethod": "POST",
          "response": {
            "$ref": "AppRecoveryAction"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Create an app recovery action with recovery status as DRAFT. Note that this action does not execute the recovery action.",
          "path": "androidpublisher/v3/applications/{packageName}/appRecoveries",
          "request": {
            "$ref": "CreateDraftAppRecoveryRequest"
          }
        },
        "deploy": {
          "parameterOrder": [
            "packageName",
            "appRecoveryId"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:deploy",
          "path": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:deploy",
          "request": {
            "$ref": "DeployAppRecoveryRequest"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Deploy an already created app recovery action with recovery status DRAFT. Note that this action activates the recovery action for all targeted users and changes its status to ACTIVE.",
          "response": {
            "$ref": "DeployAppRecoveryResponse"
          },
          "parameters": {
            "appRecoveryId": {
              "description": "Required. ID corresponding to the app recovery action to deploy.",
              "format": "int64",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. Package name of the app for which recovery action is deployed."
            }
          },
          "id": "androidpublisher.apprecovery.deploy",
          "httpMethod": "POST"
        },
        "addTargeting": {
          "response": {
            "$ref": "AddTargetingResponse"
          },
          "parameters": {
            "appRecoveryId": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. ID corresponding to the app recovery action.",
              "format": "int64"
            },
            "packageName": {
              "type": "string",
              "description": "Required. Package name of the app for which recovery action is to be updated.",
              "location": "path",
              "required": true
            }
          },
          "id": "androidpublisher.apprecovery.addTargeting",
          "httpMethod": "POST",
          "path": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:addTargeting",
          "request": {
            "$ref": "AddTargetingRequest"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Incrementally update targeting for a recovery action. Note that only the criteria selected during the creation of recovery action can be expanded.",
          "flatPath": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:addTargeting",
          "parameterOrder": [
            "packageName",
            "appRecoveryId"
          ]
        },
        "cancel": {
          "response": {
            "$ref": "CancelAppRecoveryResponse"
          },
          "parameters": {
            "packageName": {
              "description": "Required. Package name of the app for which recovery action cancellation is requested.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "appRecoveryId": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. ID corresponding to the app recovery action.",
              "format": "int64"
            }
          },
          "id": "androidpublisher.apprecovery.cancel",
          "httpMethod": "POST",
          "path": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:cancel",
          "request": {
            "$ref": "CancelAppRecoveryRequest"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Cancel an already executing app recovery action. Note that this action changes status of the recovery action to CANCELED.",
          "flatPath": "androidpublisher/v3/applications/{packageName}/appRecoveries/{appRecoveryId}:cancel",
          "parameterOrder": [
            "packageName",
            "appRecoveryId"
          ]
        },
        "list": {
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/appRecoveries",
          "path": "androidpublisher/v3/applications/{packageName}/appRecoveries",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "List all app recovery action resources associated with a particular package name and app version.",
          "response": {
            "$ref": "ListAppRecoveriesResponse"
          },
          "id": "androidpublisher.apprecovery.list",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "type": "string",
              "description": "Required. Package name of the app for which list of recovery actions is requested.",
              "location": "path",
              "required": true
            },
            "versionCode": {
              "description": "Required. Version code targeted by the list of recovery actions.",
              "type": "string",
              "format": "int64",
              "location": "query"
            }
          }
        }
      }
    },
    "reviews": {
      "methods": {
        "get": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/reviews/{reviewId}",
          "parameterOrder": [
            "packageName",
            "reviewId"
          ],
          "response": {
            "$ref": "Review"
          },
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            },
            "reviewId": {
              "type": "string",
              "description": "Unique identifier for a review.",
              "location": "path",
              "required": true
            },
            "translationLanguage": {
              "location": "query",
              "description": "Language localization code.",
              "type": "string"
            }
          },
          "id": "androidpublisher.reviews.get",
          "httpMethod": "GET",
          "path": "androidpublisher/v3/applications/{packageName}/reviews/{reviewId}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Gets a single review."
        },
        "list": {
          "id": "androidpublisher.reviews.list",
          "httpMethod": "GET",
          "parameters": {
            "startIndex": {
              "location": "query",
              "type": "integer",
              "format": "uint32",
              "description": "The index of the first element to return."
            },
            "token": {
              "location": "query",
              "description": "Pagination token. If empty, list starts at the first review.",
              "type": "string"
            },
            "packageName": {
              "description": "Package name of the app.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "translationLanguage": {
              "type": "string",
              "description": "Language localization code.",
              "location": "query"
            },
            "maxResults": {
              "description": "How many results the list operation should return.",
              "type": "integer",
              "format": "uint32",
              "location": "query"
            }
          },
          "response": {
            "$ref": "ReviewsListResponse"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Lists all reviews.",
          "path": "androidpublisher/v3/applications/{packageName}/reviews",
          "flatPath": "androidpublisher/v3/applications/{packageName}/reviews",
          "parameterOrder": [
            "packageName"
          ]
        },
        "reply": {
          "parameterOrder": [
            "packageName",
            "reviewId"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/reviews/{reviewId}:reply",
          "path": "androidpublisher/v3/applications/{packageName}/reviews/{reviewId}:reply",
          "request": {
            "$ref": "ReviewsReplyRequest"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Replies to a single review, or updates an existing reply.",
          "response": {
            "$ref": "ReviewsReplyResponse"
          },
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            },
            "reviewId": {
              "type": "string",
              "description": "Unique identifier for a review.",
              "location": "path",
              "required": true
            }
          },
          "id": "androidpublisher.reviews.reply",
          "httpMethod": "POST"
        }
      }
    },
    "systemapks": {
      "resources": {
        "variants": {
          "methods": {
            "create": {
              "parameters": {
                "versionCode": {
                  "location": "path",
                  "required": true,
                  "format": "int64",
                  "description": "The version code of the App Bundle.",
                  "type": "string"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                }
              },
              "id": "androidpublisher.systemapks.variants.create",
              "httpMethod": "POST",
              "response": {
                "$ref": "Variant"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates an APK which is suitable for inclusion in a system image from an already uploaded Android App Bundle.",
              "path": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants",
              "request": {
                "$ref": "Variant"
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants",
              "parameterOrder": [
                "packageName",
                "versionCode"
              ]
            },
            "list": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Returns the list of previously created system APK variants.",
              "path": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants",
              "parameters": {
                "versionCode": {
                  "type": "string",
                  "format": "int64",
                  "description": "The version code of the App Bundle.",
                  "location": "path",
                  "required": true
                },
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.systemapks.variants.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "SystemApksListResponse"
              },
              "parameterOrder": [
                "packageName",
                "versionCode"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants"
            },
            "get": {
              "response": {
                "$ref": "Variant"
              },
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "versionCode": {
                  "description": "The version code of the App Bundle.",
                  "format": "int64",
                  "location": "path",
                  "required": true,
                  "type": "string"
                },
                "variantId": {
                  "type": "integer",
                  "format": "uint32",
                  "description": "The ID of a previously created system APK variant.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.systemapks.variants.get",
              "httpMethod": "GET",
              "path": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants/{variantId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Returns a previously created system APK variant.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants/{variantId}",
              "parameterOrder": [
                "packageName",
                "versionCode",
                "variantId"
              ]
            },
            "download": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants/{variantId}:download",
              "supportsMediaDownload": true,
              "useMediaDownloadService": true,
              "parameterOrder": [
                "packageName",
                "versionCode",
                "variantId"
              ],
              "id": "androidpublisher.systemapks.variants.download",
              "httpMethod": "GET",
              "parameters": {
                "variantId": {
                  "description": "The ID of a previously created system APK variant.",
                  "format": "uint32",
                  "location": "path",
                  "required": true,
                  "type": "integer"
                },
                "versionCode": {
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "format": "int64",
                  "description": "The version code of the App Bundle."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                }
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Downloads a previously created system APK which is suitable for inclusion in a system image.",
              "path": "androidpublisher/v3/applications/{packageName}/systemApks/{versionCode}/variants/{variantId}:download"
            }
          }
        }
      }
    },
    "purchases": {
      "resources": {
        "products": {
          "methods": {
            "acknowledge": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Acknowledges a purchase of an inapp item.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}:acknowledge",
              "request": {
                "$ref": "ProductPurchasesAcknowledgeRequest"
              },
              "parameters": {
                "token": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The token provided to the user's device when the inapp product was purchased."
                },
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application the inapp product was sold in (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The inapp product SKU (for example, 'com.some.thing.inapp1')."
                }
              },
              "id": "androidpublisher.purchases.products.acknowledge",
              "httpMethod": "POST",
              "parameterOrder": [
                "packageName",
                "productId",
                "token"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}:acknowledge"
            },
            "consume": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The package name of the application the inapp product was sold in (for example, 'com.some.thing')."
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The inapp product SKU (for example, 'com.some.thing.inapp1')."
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The token provided to the user's device when the inapp product was purchased."
                }
              },
              "id": "androidpublisher.purchases.products.consume",
              "httpMethod": "POST",
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}:consume",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Consumes a purchase for an inapp item.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}:consume",
              "parameterOrder": [
                "packageName",
                "productId",
                "token"
              ]
            },
            "get": {
              "response": {
                "$ref": "ProductPurchase"
              },
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application the inapp product was sold in (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "productId": {
                  "location": "path",
                  "required": true,
                  "description": "The inapp product SKU (for example, 'com.some.thing.inapp1').",
                  "type": "string"
                },
                "token": {
                  "type": "string",
                  "description": "The token provided to the user's device when the inapp product was purchased.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.purchases.products.get",
              "httpMethod": "GET",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Checks the purchase and consumption status of an inapp item.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/products/{productId}/tokens/{token}",
              "parameterOrder": [
                "packageName",
                "productId",
                "token"
              ]
            }
          }
        },
        "subscriptionsv2": {
          "methods": {
            "defer": {
              "parameterOrder": [
                "packageName",
                "token"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:defer",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Defers the renewal of a subscription.",
              "request": {
                "$ref": "DeferSubscriptionPurchaseRequest"
              },
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:defer",
              "id": "androidpublisher.purchases.subscriptionsv2.defer",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Required. The package of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The token provided to the user's device when the subscription was purchased."
                }
              },
              "response": {
                "$ref": "DeferSubscriptionPurchaseResponse"
              }
            },
            "cancel": {
              "response": {
                "$ref": "CancelSubscriptionPurchaseResponse"
              },
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Required. The package of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The token provided to the user's device when the subscription was purchased.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.purchases.subscriptionsv2.cancel",
              "httpMethod": "POST",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:cancel",
              "request": {
                "$ref": "CancelSubscriptionPurchaseRequest"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Cancel a subscription purchase for the user.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:cancel",
              "parameterOrder": [
                "packageName",
                "token"
              ]
            },
            "get": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "The package of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "type": "string"
                },
                "token": {
                  "description": "Required. The token provided to the user's device when the subscription was purchased.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.purchases.subscriptionsv2.get",
              "httpMethod": "GET",
              "response": {
                "$ref": "SubscriptionPurchaseV2"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Get metadata about a subscription",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}",
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}",
              "parameterOrder": [
                "packageName",
                "token"
              ]
            },
            "revoke": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Required. The package of the application for which this subscription was purchased (for example, 'com.some.thing')."
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The token provided to the user's device when the subscription was purchased.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.purchases.subscriptionsv2.revoke",
              "httpMethod": "POST",
              "response": {
                "$ref": "RevokeSubscriptionPurchaseResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Revoke a subscription purchase for the user.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:revoke",
              "request": {
                "$ref": "RevokeSubscriptionPurchaseRequest"
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptionsv2/tokens/{token}:revoke",
              "parameterOrder": [
                "packageName",
                "token"
              ]
            }
          }
        },
        "subscriptions": {
          "methods": {
            "get": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}",
              "deprecated": true,
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "response": {
                "$ref": "SubscriptionPurchase"
              },
              "id": "androidpublisher.purchases.subscriptions.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "subscriptionId": {
                  "type": "string",
                  "description": "The purchased subscription ID (for example, 'monthly001').",
                  "location": "path",
                  "required": true
                },
                "token": {
                  "description": "The token provided to the user's device when the subscription was purchased.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deprecated: Use purchases.subscriptionsv2.get instead. Checks whether a user's subscription purchase is valid and returns its expiry time."
            },
            "cancel": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:cancel",
              "id": "androidpublisher.purchases.subscriptions.cancel",
              "httpMethod": "POST",
              "parameters": {
                "subscriptionId": {
                  "location": "path",
                  "required": true,
                  "description": "Note: Since May 21, 2025, subscription_id is not required, and not recommended for subscription with add-ons. The purchased subscription ID (for example, 'monthly001').",
                  "type": "string"
                },
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The token provided to the user's device when the subscription was purchased."
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:cancel",
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Cancels a user's subscription purchase. The subscription remains valid until its expiration time. Newer version is available at purchases.subscriptionsv2.cancel for better client library support."
            },
            "refund": {
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "deprecated": true,
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:refund",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deprecated: Use orders.refund instead. Refunds a user's subscription purchase, but the subscription remains valid until its expiration time and it will continue to recur.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:refund",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "type": "string"
                },
                "subscriptionId": {
                  "location": "path",
                  "required": true,
                  "description": "\"The purchased subscription ID (for example, 'monthly001').",
                  "type": "string"
                },
                "token": {
                  "location": "path",
                  "required": true,
                  "description": "The token provided to the user's device when the subscription was purchased.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.purchases.subscriptions.refund",
              "httpMethod": "POST"
            },
            "revoke": {
              "deprecated": true,
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:revoke",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deprecated: Use purchases.subscriptionsv2.revoke instead. Refunds and immediately revokes a user's subscription purchase. Access to the subscription will be terminated immediately and it will stop recurring.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:revoke",
              "id": "androidpublisher.purchases.subscriptions.revoke",
              "httpMethod": "POST",
              "parameters": {
                "token": {
                  "description": "The token provided to the user's device when the subscription was purchased.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "subscriptionId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The purchased subscription ID (for example, 'monthly001')."
                },
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                }
              }
            },
            "acknowledge": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:acknowledge",
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "parameters": {
                "token": {
                  "type": "string",
                  "description": "The token provided to the user's device when the subscription was purchased.",
                  "location": "path",
                  "required": true
                },
                "subscriptionId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Note: Since May 21, 2025, subscription_id is not required, and not recommended for subscription with add-ons. The purchased subscription ID (for example, 'monthly001')."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing')."
                }
              },
              "id": "androidpublisher.purchases.subscriptions.acknowledge",
              "httpMethod": "POST",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Acknowledges a subscription purchase.",
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:acknowledge",
              "request": {
                "$ref": "SubscriptionPurchasesAcknowledgeRequest"
              }
            },
            "defer": {
              "parameterOrder": [
                "packageName",
                "subscriptionId",
                "token"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:defer",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Defers a user's subscription purchase until a specified future expiration time.",
              "request": {
                "$ref": "SubscriptionPurchasesDeferRequest"
              },
              "path": "androidpublisher/v3/applications/{packageName}/purchases/subscriptions/{subscriptionId}/tokens/{token}:defer",
              "id": "androidpublisher.purchases.subscriptions.defer",
              "httpMethod": "POST",
              "parameters": {
                "token": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The token provided to the user's device when the subscription was purchased."
                },
                "subscriptionId": {
                  "location": "path",
                  "required": true,
                  "description": "The purchased subscription ID (for example, 'monthly001').",
                  "type": "string"
                },
                "packageName": {
                  "description": "The package name of the application for which this subscription was purchased (for example, 'com.some.thing').",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "SubscriptionPurchasesDeferResponse"
              }
            }
          }
        },
        "productsv2": {
          "methods": {
            "getproductpurchasev2": {
              "response": {
                "$ref": "ProductPurchaseV2"
              },
              "id": "androidpublisher.purchases.productsv2.getproductpurchasev2",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "The package name of the application the inapp product was sold in (for example, 'com.some.thing').",
                  "type": "string"
                },
                "token": {
                  "description": "The token provided to the user's device when the inapp product was purchased.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/purchases/productsv2/tokens/{token}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Checks the purchase and consumption status of an inapp item.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/productsv2/tokens/{token}",
              "parameterOrder": [
                "packageName",
                "token"
              ]
            }
          }
        },
        "voidedpurchases": {
          "methods": {
            "list": {
              "path": "androidpublisher/v3/applications/{packageName}/purchases/voidedpurchases",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists the purchases that were canceled, refunded or charged-back.",
              "response": {
                "$ref": "VoidedPurchasesListResponse"
              },
              "id": "androidpublisher.purchases.voidedpurchases.list",
              "httpMethod": "GET",
              "parameters": {
                "maxResults": {
                  "location": "query",
                  "type": "integer",
                  "format": "uint32",
                  "description": "Defines how many results the list operation should return. The default number depends on the resource collection."
                },
                "endTime": {
                  "type": "string",
                  "format": "int64",
                  "description": "The time, in milliseconds since the Epoch, of the newest voided purchase that you want to see in the response. The value of this parameter cannot be greater than the current time and is ignored if a pagination token is set. Default value is current time. Note: This filter is applied on the time at which the record is seen as voided by our systems and not the actual voided time returned in the response.",
                  "location": "query"
                },
                "type": {
                  "location": "query",
                  "description": "The type of voided purchases that you want to see in the response. Possible values are: 0. Only voided in-app product purchases will be returned in the response. This is the default value. 1. Both voided in-app purchases and voided subscription purchases will be returned in the response. Note: Before requesting to receive voided subscription purchases, you must switch to use orderId in the response which uniquely identifies one-time purchases and subscriptions. Otherwise, you will receive multiple subscription orders with the same PurchaseToken, because subscription renewal orders share the same PurchaseToken.",
                  "type": "integer",
                  "format": "int32"
                },
                "packageName": {
                  "type": "string",
                  "description": "The package name of the application for which voided purchases need to be returned (for example, 'com.some.thing').",
                  "location": "path",
                  "required": true
                },
                "startTime": {
                  "type": "string",
                  "format": "int64",
                  "description": "The time, in milliseconds since the Epoch, of the oldest voided purchase that you want to see in the response. The value of this parameter cannot be older than 30 days and is ignored if a pagination token is set. Default value is current time minus 30 days. Note: This filter is applied on the time at which the record is seen as voided by our systems and not the actual voided time returned in the response.",
                  "location": "query"
                },
                "token": {
                  "location": "query",
                  "type": "string",
                  "description": "Defines the token of the page to return, usually taken from TokenPagination. This can only be used if token paging is enabled."
                },
                "startIndex": {
                  "description": "Defines the index of the first element to return. This can only be used if indexed paging is enabled.",
                  "type": "integer",
                  "format": "uint32",
                  "location": "query"
                },
                "includeQuantityBasedPartialRefund": {
                  "location": "query",
                  "type": "boolean",
                  "description": "Optional. Whether to include voided purchases of quantity-based partial refunds, which are applicable only to multi-quantity purchases. If true, additional voided purchases may be returned with voidedQuantity that indicates the refund quantity of a quantity-based partial refund. The default value is false."
                }
              },
              "parameterOrder": [
                "packageName"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/purchases/voidedpurchases"
            }
          }
        }
      }
    },
    "externaltransactions": {
      "methods": {
        "refundexternaltransaction": {
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Refunds or partially refunds an existing external transaction.",
          "path": "androidpublisher/v3/{+name}:refund",
          "request": {
            "$ref": "RefundExternalTransactionRequest"
          },
          "parameters": {
            "name": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. The name of the external transaction that will be refunded. Format: applications/{package_name}/externalTransactions/{external_transaction}",
              "pattern": "^applications/[^/]+/externalTransactions/[^/]+$"
            }
          },
          "id": "androidpublisher.externaltransactions.refundexternaltransaction",
          "httpMethod": "POST",
          "response": {
            "$ref": "ExternalTransaction"
          },
          "parameterOrder": [
            "name"
          ],
          "flatPath": "androidpublisher/v3/applications/{applicationsId}/externalTransactions/{externalTransactionsId}:refund"
        },
        "createexternaltransaction": {
          "parameterOrder": [
            "parent"
          ],
          "flatPath": "androidpublisher/v3/applications/{applicationsId}/externalTransactions",
          "path": "androidpublisher/v3/{+parent}/externalTransactions",
          "request": {
            "$ref": "ExternalTransaction"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Creates a new external transaction.",
          "response": {
            "$ref": "ExternalTransaction"
          },
          "parameters": {
            "parent": {
              "pattern": "^applications/[^/]+$",
              "description": "Required. The parent resource where this external transaction will be created. Format: applications/{package_name}",
              "location": "path",
              "required": true,
              "type": "string"
            },
            "externalTransactionId": {
              "location": "query",
              "description": "Required. The id to use for the external transaction. Must be unique across all other transactions for the app. This value should be 1-63 characters and valid characters are /a-zA-Z0-9_-/. Do not use this field to store any Personally Identifiable Information (PII) such as emails. Attempting to store PII in this field may result in requests being blocked.",
              "type": "string"
            }
          },
          "id": "androidpublisher.externaltransactions.createexternaltransaction",
          "httpMethod": "POST"
        },
        "getexternaltransaction": {
          "flatPath": "androidpublisher/v3/applications/{applicationsId}/externalTransactions/{externalTransactionsId}",
          "parameterOrder": [
            "name"
          ],
          "parameters": {
            "name": {
              "pattern": "^applications/[^/]+/externalTransactions/[^/]+$",
              "description": "Required. The name of the external transaction to retrieve. Format: applications/{package_name}/externalTransactions/{external_transaction}",
              "location": "path",
              "required": true,
              "type": "string"
            }
          },
          "id": "androidpublisher.externaltransactions.getexternaltransaction",
          "httpMethod": "GET",
          "response": {
            "$ref": "ExternalTransaction"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Gets an existing external transaction.",
          "path": "androidpublisher/v3/{+name}"
        }
      }
    },
    "inappproducts": {
      "methods": {
        "batchUpdate": {
          "response": {
            "$ref": "InappproductsBatchUpdateResponse"
          },
          "id": "androidpublisher.inappproducts.batchUpdate",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "type": "string",
              "description": "Package name of the app.",
              "location": "path",
              "required": true
            }
          },
          "request": {
            "$ref": "InappproductsBatchUpdateRequest"
          },
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts:batchUpdate",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Updates or inserts one or more in-app products (managed products or subscriptions). Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput. This method should no longer be used to update subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts:batchUpdate",
          "parameterOrder": [
            "packageName"
          ]
        },
        "insert": {
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Creates an in-app product (a managed product or a subscription). This method should no longer be used to create subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts",
          "request": {
            "$ref": "InAppProduct"
          },
          "parameters": {
            "autoConvertMissingPrices": {
              "location": "query",
              "type": "boolean",
              "description": "If true the prices for all regions targeted by the parent app that don't have a price specified for this in-app product will be auto converted to the target currency based on the default price. Defaults to false."
            },
            "packageName": {
              "type": "string",
              "description": "Package name of the app.",
              "location": "path",
              "required": true
            }
          },
          "id": "androidpublisher.inappproducts.insert",
          "httpMethod": "POST",
          "response": {
            "$ref": "InAppProduct"
          },
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts"
        },
        "patch": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "parameterOrder": [
            "packageName",
            "sku"
          ],
          "id": "androidpublisher.inappproducts.patch",
          "httpMethod": "PATCH",
          "parameters": {
            "autoConvertMissingPrices": {
              "type": "boolean",
              "description": "If true the prices for all regions targeted by the parent app that don't have a price specified for this in-app product will be auto converted to the target currency based on the default price. Defaults to false.",
              "location": "query"
            },
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            },
            "latencyTolerance": {
              "type": "string",
              "enumDescriptions": [
                "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
              ],
              "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
              "enum": [
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
              ],
              "location": "query"
            },
            "sku": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Unique identifier for the in-app product."
            }
          },
          "response": {
            "$ref": "InAppProduct"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Patches an in-app product (a managed product or a subscription). This method should no longer be used to update subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "request": {
            "$ref": "InAppProduct"
          },
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}"
        },
        "batchDelete": {
          "request": {
            "$ref": "InappproductsBatchDeleteRequest"
          },
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts:batchDelete",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Deletes in-app products (managed products or subscriptions). Set the latencyTolerance field on nested requests to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT to achieve maximum update throughput. This method should not be used to delete subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "id": "androidpublisher.inappproducts.batchDelete",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            }
          },
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts:batchDelete"
        },
        "batchGet": {
          "response": {
            "$ref": "InappproductsBatchGetResponse"
          },
          "id": "androidpublisher.inappproducts.batchGet",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            },
            "sku": {
              "repeated": true,
              "location": "query",
              "type": "string",
              "description": "Unique identifier for the in-app products."
            }
          },
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts:batchGet",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Reads multiple in-app products, which can be managed products or subscriptions. This method should not be used to retrieve subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts:batchGet",
          "parameterOrder": [
            "packageName"
          ]
        },
        "update": {
          "parameters": {
            "sku": {
              "description": "Unique identifier for the in-app product.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "allowMissing": {
              "type": "boolean",
              "description": "If set to true, and the in-app product with the given package_name and sku doesn't exist, the in-app product will be created.",
              "location": "query"
            },
            "autoConvertMissingPrices": {
              "location": "query",
              "description": "If true the prices for all regions targeted by the parent app that don't have a price specified for this in-app product will be auto converted to the target currency based on the default price. Defaults to false.",
              "type": "boolean"
            },
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            },
            "latencyTolerance": {
              "enumDescriptions": [
                "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
              ],
              "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
              "enum": [
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
              ],
              "location": "query",
              "type": "string"
            }
          },
          "id": "androidpublisher.inappproducts.update",
          "httpMethod": "PUT",
          "response": {
            "$ref": "InAppProduct"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Updates an in-app product (a managed product or a subscription). This method should no longer be used to update subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "request": {
            "$ref": "InAppProduct"
          },
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "parameterOrder": [
            "packageName",
            "sku"
          ]
        },
        "get": {
          "parameterOrder": [
            "packageName",
            "sku"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Gets an in-app product, which can be a managed product or a subscription. This method should no longer be used to retrieve subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "parameters": {
            "sku": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Unique identifier for the in-app product."
            },
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            }
          },
          "id": "androidpublisher.inappproducts.get",
          "httpMethod": "GET",
          "response": {
            "$ref": "InAppProduct"
          }
        },
        "list": {
          "id": "androidpublisher.inappproducts.list",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            },
            "startIndex": {
              "format": "uint32",
              "description": "Deprecated and ignored. Set the `token` parameter to retrieve the next page.",
              "deprecated": true,
              "location": "query",
              "type": "integer"
            },
            "token": {
              "location": "query",
              "description": "Pagination token. If empty, list starts at the first product.",
              "type": "string"
            },
            "maxResults": {
              "format": "uint32",
              "description": "Deprecated and ignored. The page size is determined by the server.",
              "deprecated": true,
              "location": "query",
              "type": "integer"
            }
          },
          "response": {
            "$ref": "InappproductsListResponse"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Lists all in-app products - both managed products and subscriptions. If an app has a large number of in-app products, the response may be paginated. In this case the response field `tokenPagination.nextPageToken` will be set and the caller should provide its value as a `token` request parameter to retrieve the next page. This method should no longer be used to retrieve subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information.",
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts",
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts",
          "parameterOrder": [
            "packageName"
          ]
        },
        "delete": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "id": "androidpublisher.inappproducts.delete",
          "httpMethod": "DELETE",
          "parameters": {
            "sku": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Unique identifier for the in-app product."
            },
            "packageName": {
              "description": "Package name of the app.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "latencyTolerance": {
              "type": "string",
              "enum": [
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
                "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
              ],
              "location": "query",
              "enumDescriptions": [
                "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
                "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
                "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
              ],
              "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
            }
          },
          "path": "androidpublisher/v3/applications/{packageName}/inappproducts/{sku}",
          "parameterOrder": [
            "packageName",
            "sku"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Deletes an in-app product (a managed product or a subscription). This method should no longer be used to delete subscriptions. See [this article](https://android-developers.googleblog.com/2023/06/changes-to-google-play-developer-api-june-2023.html) for more information."
        }
      }
    },
    "orders": {
      "methods": {
        "batchget": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/orders:batchGet",
          "parameterOrder": [
            "packageName"
          ],
          "response": {
            "$ref": "BatchGetOrdersResponse"
          },
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Required. The package name of the application for which this subscription or in-app item was purchased (for example, 'com.some.thing').",
              "type": "string"
            },
            "orderIds": {
              "location": "query",
              "repeated": true,
              "description": "Required. The list of order IDs to retrieve order details for. There must be between 1 and 1000 (inclusive) order IDs per request. If any order ID is not found or does not match the provided package, the entire request will fail with an error. The order IDs must be distinct.",
              "type": "string"
            }
          },
          "id": "androidpublisher.orders.batchget",
          "httpMethod": "GET",
          "path": "androidpublisher/v3/applications/{packageName}/orders:batchGet",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Get order details for a list of orders."
        },
        "get": {
          "response": {
            "$ref": "Order"
          },
          "parameters": {
            "packageName": {
              "description": "Required. The package name of the application for which this subscription or in-app item was purchased (for example, 'com.some.thing').",
              "type": "string",
              "location": "path",
              "required": true
            },
            "orderId": {
              "description": "Required. The order ID provided to the user when the subscription or in-app order was purchased.",
              "type": "string",
              "location": "path",
              "required": true
            }
          },
          "id": "androidpublisher.orders.get",
          "httpMethod": "GET",
          "path": "androidpublisher/v3/applications/{packageName}/orders/{orderId}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Get order details for a single order.",
          "flatPath": "androidpublisher/v3/applications/{packageName}/orders/{orderId}",
          "parameterOrder": [
            "packageName",
            "orderId"
          ]
        },
        "refund": {
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Refunds a user's subscription or in-app purchase order. Orders older than 3 years cannot be refunded.",
          "path": "androidpublisher/v3/applications/{packageName}/orders/{orderId}:refund",
          "parameterOrder": [
            "packageName",
            "orderId"
          ],
          "parameters": {
            "packageName": {
              "type": "string",
              "description": "The package name of the application for which this subscription or in-app item was purchased (for example, 'com.some.thing').",
              "location": "path",
              "required": true
            },
            "orderId": {
              "type": "string",
              "description": "The order ID provided to the user when the subscription or in-app order was purchased.",
              "location": "path",
              "required": true
            },
            "revoke": {
              "description": "Whether to revoke the purchased item. If set to true, access to the subscription or in-app item will be terminated immediately. If the item is a recurring subscription, all future payments will also be terminated. Consumed in-app items need to be handled by developer's app. (optional).",
              "type": "boolean",
              "location": "query"
            }
          },
          "id": "androidpublisher.orders.refund",
          "httpMethod": "POST",
          "flatPath": "androidpublisher/v3/applications/{packageName}/orders/{orderId}:refund"
        }
      }
    },
    "edits": {
      "resources": {
        "countryavailability": {
          "methods": {
            "get": {
              "parameters": {
                "track": {
                  "location": "path",
                  "required": true,
                  "description": "The track to read from.",
                  "type": "string"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.countryavailability.get",
              "httpMethod": "GET",
              "response": {
                "$ref": "TrackCountryAvailability"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Gets country availability.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/countryAvailability/{track}",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/countryAvailability/{track}",
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ]
            }
          }
        },
        "bundles": {
          "methods": {
            "list": {
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all current Android App Bundles of the app and edit.",
              "response": {
                "$ref": "BundlesListResponse"
              },
              "id": "androidpublisher.edits.bundles.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                }
              }
            },
            "upload": {
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles",
              "mediaUpload": {
                "accept": [
                  "application/octet-stream"
                ],
                "maxSize": "53687091200",
                "protocols": {
                  "resumable": {
                    "multipart": true,
                    "path": "/resumable/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles"
                  },
                  "simple": {
                    "path": "/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles",
                    "multipart": true
                  }
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/bundles",
              "supportsMediaUpload": true,
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Uploads a new Android App Bundle to this edit. If you are using the Google API client libraries, please increase the timeout of the http request before calling this endpoint (a timeout of 2 minutes is recommended). See [Timeouts and Errors](https://developers.google.com/api-client-library/java/google-api-java-client/errors) for an example in java.",
              "response": {
                "$ref": "Bundle"
              },
              "id": "androidpublisher.edits.bundles.upload",
              "httpMethod": "POST",
              "parameters": {
                "ackBundleInstallationWarning": {
                  "location": "query",
                  "deprecated": true,
                  "description": "Deprecated. The installation warning has been removed, it's not necessary to set this field anymore.",
                  "type": "boolean"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "deviceTierConfigId": {
                  "location": "query",
                  "description": "Device tier config (DTC) to be used for generating deliverables (APKs). Contains id of the DTC or \"LATEST\" for last uploaded DTC.",
                  "type": "string"
                }
              }
            }
          }
        },
        "listings": {
          "methods": {
            "patch": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language"
              ],
              "response": {
                "$ref": "Listing"
              },
              "id": "androidpublisher.edits.listings.patch",
              "httpMethod": "PATCH",
              "parameters": {
                "language": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German)."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "request": {
                "$ref": "Listing"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Patches a localized store listing."
            },
            "list": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Identifier of the edit."
                }
              },
              "id": "androidpublisher.edits.listings.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "ListingsListResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all localized store listings.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings",
              "parameterOrder": [
                "packageName",
                "editId"
              ]
            },
            "delete": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes a localized store listing.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language"
              ],
              "id": "androidpublisher.edits.listings.delete",
              "httpMethod": "DELETE",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                },
                "language": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German)."
                }
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}"
            },
            "deleteall": {
              "id": "androidpublisher.edits.listings.deleteall",
              "httpMethod": "DELETE",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                }
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes all store listings.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings",
              "parameterOrder": [
                "packageName",
                "editId"
              ]
            },
            "get": {
              "parameters": {
                "language": {
                  "location": "path",
                  "required": true,
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German).",
                  "type": "string"
                },
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.listings.get",
              "httpMethod": "GET",
              "response": {
                "$ref": "Listing"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Gets a localized store listing.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language"
              ]
            },
            "update": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language"
              ],
              "parameters": {
                "language": {
                  "location": "path",
                  "required": true,
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German).",
                  "type": "string"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.edits.listings.update",
              "httpMethod": "PUT",
              "response": {
                "$ref": "Listing"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates or updates a localized store listing.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}",
              "request": {
                "$ref": "Listing"
              }
            }
          }
        },
        "testers": {
          "methods": {
            "get": {
              "response": {
                "$ref": "Testers"
              },
              "id": "androidpublisher.edits.testers.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                },
                "track": {
                  "location": "path",
                  "required": true,
                  "description": "The track to read from.",
                  "type": "string"
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Gets testers. Note: Testers resource does not support email lists.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ]
            },
            "patch": {
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "request": {
                "$ref": "Testers"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Patches testers. Note: Testers resource does not support email lists.",
              "response": {
                "$ref": "Testers"
              },
              "id": "androidpublisher.edits.testers.patch",
              "httpMethod": "PATCH",
              "parameters": {
                "track": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "The track to update."
                },
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              }
            },
            "update": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ],
              "parameters": {
                "track": {
                  "type": "string",
                  "description": "The track to update.",
                  "location": "path",
                  "required": true
                },
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.testers.update",
              "httpMethod": "PUT",
              "response": {
                "$ref": "Testers"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates testers. Note: Testers resource does not support email lists.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/testers/{track}",
              "request": {
                "$ref": "Testers"
              }
            }
          }
        },
        "apks": {
          "methods": {
            "upload": {
              "mediaUpload": {
                "protocols": {
                  "resumable": {
                    "path": "/resumable/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks",
                    "multipart": true
                  },
                  "simple": {
                    "multipart": true,
                    "path": "/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks"
                  }
                },
                "accept": [
                  "application/octet-stream",
                  "application/vnd.android.package-archive"
                ],
                "maxSize": "10737418240"
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks",
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "id": "androidpublisher.edits.apks.upload",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "Apk"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Uploads an APK and adds to the current edit.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks",
              "supportsMediaUpload": true
            },
            "list": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all current APKs of the app and edit.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks",
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Identifier of the edit."
                }
              },
              "id": "androidpublisher.edits.apks.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "ApksListResponse"
              },
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks"
            },
            "addexternallyhosted": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/externallyHosted",
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "response": {
                "$ref": "ApksAddExternallyHostedResponse"
              },
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.apks.addexternallyhosted",
              "httpMethod": "POST",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/externallyHosted",
              "request": {
                "$ref": "ApksAddExternallyHostedRequest"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates a new APK without uploading the APK itself to Google Play, instead hosting the APK at a specified URL. This function is only available to organizations using Managed Play whose application is configured to restrict distribution to the organizations."
            }
          }
        },
        "expansionfiles": {
          "methods": {
            "update": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "apkVersionCode",
                "expansionFileType"
              ],
              "response": {
                "$ref": "ExpansionFile"
              },
              "id": "androidpublisher.edits.expansionfiles.update",
              "httpMethod": "PUT",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                },
                "expansionFileType": {
                  "enumDescriptions": [
                    "Unspecified expansion file type.",
                    "Main expansion file.",
                    "Patch expansion file."
                  ],
                  "description": "The file type of the file configuration which is being read or modified.",
                  "enum": [
                    "expansionFileTypeUnspecified",
                    "main",
                    "patch"
                  ],
                  "location": "path",
                  "required": true,
                  "type": "string"
                },
                "apkVersionCode": {
                  "location": "path",
                  "required": true,
                  "description": "The version code of the APK whose expansion file configuration is being read or modified.",
                  "format": "int32",
                  "type": "integer"
                }
              },
              "request": {
                "$ref": "ExpansionFile"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates the APK's expansion file configuration to reference another APK's expansion file. To add a new expansion file use the Upload method."
            },
            "get": {
              "id": "androidpublisher.edits.expansionfiles.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "expansionFileType": {
                  "description": "The file type of the file configuration which is being read or modified.",
                  "enumDescriptions": [
                    "Unspecified expansion file type.",
                    "Main expansion file.",
                    "Patch expansion file."
                  ],
                  "location": "path",
                  "required": true,
                  "enum": [
                    "expansionFileTypeUnspecified",
                    "main",
                    "patch"
                  ],
                  "type": "string"
                },
                "apkVersionCode": {
                  "description": "The version code of the APK whose expansion file configuration is being read or modified.",
                  "format": "int32",
                  "location": "path",
                  "required": true,
                  "type": "integer"
                }
              },
              "response": {
                "$ref": "ExpansionFile"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Fetches the expansion file configuration for the specified APK.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "apkVersionCode",
                "expansionFileType"
              ]
            },
            "patch": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "apkVersionCode",
                "expansionFileType"
              ],
              "id": "androidpublisher.edits.expansionfiles.patch",
              "httpMethod": "PATCH",
              "parameters": {
                "apkVersionCode": {
                  "type": "integer",
                  "location": "path",
                  "required": true,
                  "description": "The version code of the APK whose expansion file configuration is being read or modified.",
                  "format": "int32"
                },
                "expansionFileType": {
                  "type": "string",
                  "enum": [
                    "expansionFileTypeUnspecified",
                    "main",
                    "patch"
                  ],
                  "location": "path",
                  "required": true,
                  "enumDescriptions": [
                    "Unspecified expansion file type.",
                    "Main expansion file.",
                    "Patch expansion file."
                  ],
                  "description": "The file type of the expansion file configuration which is being updated."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "ExpansionFile"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Patches the APK's expansion file configuration to reference another APK's expansion file. To add a new expansion file use the Upload method.",
              "request": {
                "$ref": "ExpansionFile"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}"
            },
            "upload": {
              "mediaUpload": {
                "accept": [
                  "application/octet-stream"
                ],
                "maxSize": "2147483648",
                "protocols": {
                  "resumable": {
                    "multipart": true,
                    "path": "/resumable/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}"
                  },
                  "simple": {
                    "multipart": true,
                    "path": "/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}"
                  }
                }
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "apkVersionCode",
                "expansionFileType"
              ],
              "id": "androidpublisher.edits.expansionfiles.upload",
              "httpMethod": "POST",
              "parameters": {
                "apkVersionCode": {
                  "type": "integer",
                  "location": "path",
                  "required": true,
                  "format": "int32",
                  "description": "The version code of the APK whose expansion file configuration is being read or modified."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "expansionFileType": {
                  "type": "string",
                  "description": "The file type of the expansion file configuration which is being updated.",
                  "enumDescriptions": [
                    "Unspecified expansion file type.",
                    "Main expansion file.",
                    "Patch expansion file."
                  ],
                  "location": "path",
                  "required": true,
                  "enum": [
                    "expansionFileTypeUnspecified",
                    "main",
                    "patch"
                  ]
                }
              },
              "response": {
                "$ref": "ExpansionFilesUploadResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Uploads a new expansion file and attaches to the specified APK.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/expansionFiles/{expansionFileType}",
              "supportsMediaUpload": true
            }
          }
        },
        "details": {
          "methods": {
            "get": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                }
              },
              "id": "androidpublisher.edits.details.get",
              "httpMethod": "GET",
              "response": {
                "$ref": "AppDetails"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Gets details of an app.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "parameterOrder": [
                "packageName",
                "editId"
              ]
            },
            "patch": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "response": {
                "$ref": "AppDetails"
              },
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.details.patch",
              "httpMethod": "PATCH",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "request": {
                "$ref": "AppDetails"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Patches details of an app."
            },
            "update": {
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Identifier of the edit."
                }
              },
              "id": "androidpublisher.edits.details.update",
              "httpMethod": "PUT",
              "response": {
                "$ref": "AppDetails"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates details of an app.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "request": {
                "$ref": "AppDetails"
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/details",
              "parameterOrder": [
                "packageName",
                "editId"
              ]
            }
          }
        },
        "images": {
          "methods": {
            "list": {
              "id": "androidpublisher.edits.images.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "imageType": {
                  "enum": [
                    "appImageTypeUnspecified",
                    "phoneScreenshots",
                    "sevenInchScreenshots",
                    "tenInchScreenshots",
                    "tvScreenshots",
                    "wearScreenshots",
                    "icon",
                    "featureGraphic",
                    "tvBanner"
                  ],
                  "location": "path",
                  "required": true,
                  "enumDescriptions": [
                    "Unspecified type. Do not use.",
                    "Phone screenshot.",
                    "Seven inch screenshot.",
                    "Ten inch screenshot.",
                    "TV screenshot.",
                    "Wear screenshot.",
                    "Icon.",
                    "Feature graphic.",
                    "TV banner."
                  ],
                  "description": "Type of the Image. Providing an image type that refers to no images will return an empty response.",
                  "type": "string"
                },
                "language": {
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German). There must be a store listing for the specified language.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "ImagesListResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all images. The response may be empty.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language",
                "imageType"
              ]
            },
            "delete": {
              "parameters": {
                "imageType": {
                  "type": "string",
                  "description": "Type of the Image.",
                  "enumDescriptions": [
                    "Unspecified type. Do not use.",
                    "Phone screenshot.",
                    "Seven inch screenshot.",
                    "Ten inch screenshot.",
                    "TV screenshot.",
                    "Wear screenshot.",
                    "Icon.",
                    "Feature graphic.",
                    "TV banner."
                  ],
                  "location": "path",
                  "required": true,
                  "enum": [
                    "appImageTypeUnspecified",
                    "phoneScreenshots",
                    "sevenInchScreenshots",
                    "tenInchScreenshots",
                    "tvScreenshots",
                    "wearScreenshots",
                    "icon",
                    "featureGraphic",
                    "tvBanner"
                  ]
                },
                "language": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German)."
                },
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                },
                "imageId": {
                  "description": "Unique identifier an image within the set of images attached to this edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.images.delete",
              "httpMethod": "DELETE",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}/{imageId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes the image (specified by id) from the edit.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}/{imageId}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language",
                "imageType",
                "imageId"
              ]
            },
            "deleteall": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language",
                "imageType"
              ],
              "response": {
                "$ref": "ImagesDeleteAllResponse"
              },
              "id": "androidpublisher.edits.images.deleteall",
              "httpMethod": "DELETE",
              "parameters": {
                "language": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German). Providing a language that is not supported by the App is a no-op."
                },
                "imageType": {
                  "type": "string",
                  "enum": [
                    "appImageTypeUnspecified",
                    "phoneScreenshots",
                    "sevenInchScreenshots",
                    "tenInchScreenshots",
                    "tvScreenshots",
                    "wearScreenshots",
                    "icon",
                    "featureGraphic",
                    "tvBanner"
                  ],
                  "location": "path",
                  "required": true,
                  "enumDescriptions": [
                    "Unspecified type. Do not use.",
                    "Phone screenshot.",
                    "Seven inch screenshot.",
                    "Ten inch screenshot.",
                    "TV screenshot.",
                    "Wear screenshot.",
                    "Icon.",
                    "Feature graphic.",
                    "TV banner."
                  ],
                  "description": "Type of the Image. Providing an image type that refers to no images is a no-op."
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Deletes all images for the specified language and image type. Returns an empty response if no images are found."
            },
            "upload": {
              "parameters": {
                "language": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German). Providing a language that is not supported by the App is a no-op."
                },
                "imageType": {
                  "location": "path",
                  "required": true,
                  "enum": [
                    "appImageTypeUnspecified",
                    "phoneScreenshots",
                    "sevenInchScreenshots",
                    "tenInchScreenshots",
                    "tvScreenshots",
                    "wearScreenshots",
                    "icon",
                    "featureGraphic",
                    "tvBanner"
                  ],
                  "description": "Type of the Image.",
                  "enumDescriptions": [
                    "Unspecified type. Do not use.",
                    "Phone screenshot.",
                    "Seven inch screenshot.",
                    "Ten inch screenshot.",
                    "TV screenshot.",
                    "Wear screenshot.",
                    "Icon.",
                    "Feature graphic.",
                    "TV banner."
                  ],
                  "type": "string"
                },
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.images.upload",
              "httpMethod": "POST",
              "response": {
                "$ref": "ImagesUploadResponse"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Uploads an image of the specified language and image type, and adds to the edit.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "supportsMediaUpload": true,
              "mediaUpload": {
                "accept": [
                  "image/*"
                ],
                "maxSize": "15728640",
                "protocols": {
                  "resumable": {
                    "path": "/resumable/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
                    "multipart": true
                  },
                  "simple": {
                    "path": "/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
                    "multipart": true
                  }
                }
              },
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/listings/{language}/{imageType}",
              "parameterOrder": [
                "packageName",
                "editId",
                "language",
                "imageType"
              ]
            }
          }
        },
        "tracks": {
          "methods": {
            "list": {
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Lists all tracks.",
              "response": {
                "$ref": "TracksListResponse"
              },
              "id": "androidpublisher.edits.tracks.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                }
              },
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks"
            },
            "patch": {
              "request": {
                "$ref": "Track"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Patches a track.",
              "response": {
                "$ref": "Track"
              },
              "id": "androidpublisher.edits.tracks.patch",
              "httpMethod": "PATCH",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "description": "Identifier of the edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "track": {
                  "type": "string",
                  "description": "Identifier of the track. [More on track name](https://developers.google.com/android-publisher/tracks#ff-track-name)",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}"
            },
            "get": {
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Gets a track.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                },
                "editId": {
                  "location": "path",
                  "required": true,
                  "description": "Identifier of the edit.",
                  "type": "string"
                },
                "track": {
                  "type": "string",
                  "description": "Identifier of the track. [More on track name](https://developers.google.com/android-publisher/tracks#ff-track-name)",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.tracks.get",
              "httpMethod": "GET",
              "response": {
                "$ref": "Track"
              },
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}"
            },
            "create": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks",
              "parameterOrder": [
                "packageName",
                "editId"
              ],
              "id": "androidpublisher.edits.tracks.create",
              "httpMethod": "POST",
              "parameters": {
                "packageName": {
                  "type": "string",
                  "description": "Required. Package name of the app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "type": "string",
                  "description": "Required. Identifier of the edit.",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "Track"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates a new track.",
              "request": {
                "$ref": "TrackConfig"
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks"
            },
            "update": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}",
              "parameterOrder": [
                "packageName",
                "editId",
                "track"
              ],
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "editId": {
                  "type": "string",
                  "description": "Identifier of the edit.",
                  "location": "path",
                  "required": true
                },
                "track": {
                  "type": "string",
                  "description": "Identifier of the track. [More on track name](https://developers.google.com/android-publisher/tracks#ff-track-name)",
                  "location": "path",
                  "required": true
                }
              },
              "id": "androidpublisher.edits.tracks.update",
              "httpMethod": "PUT",
              "response": {
                "$ref": "Track"
              },
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Updates a track.",
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/tracks/{track}",
              "request": {
                "$ref": "Track"
              }
            }
          }
        },
        "deobfuscationfiles": {
          "methods": {
            "upload": {
              "response": {
                "$ref": "DeobfuscationFilesUploadResponse"
              },
              "id": "androidpublisher.edits.deobfuscationfiles.upload",
              "httpMethod": "POST",
              "parameters": {
                "apkVersionCode": {
                  "type": "integer",
                  "location": "path",
                  "required": true,
                  "format": "int32",
                  "description": "The version code of the APK whose Deobfuscation File is being uploaded."
                },
                "deobfuscationFileType": {
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "enum": [
                    "deobfuscationFileTypeUnspecified",
                    "proguard",
                    "nativeCode"
                  ],
                  "description": "The type of the deobfuscation file.",
                  "enumDescriptions": [
                    "Unspecified deobfuscation file type.",
                    "Proguard deobfuscation file type.",
                    "Native debugging symbols file type."
                  ]
                },
                "packageName": {
                  "type": "string",
                  "description": "Unique identifier for the Android app.",
                  "location": "path",
                  "required": true
                },
                "editId": {
                  "description": "Unique identifier for this edit.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/deobfuscationFiles/{deobfuscationFileType}",
              "supportsMediaUpload": true,
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Uploads a new deobfuscation file and attaches to the specified APK.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/deobfuscationFiles/{deobfuscationFileType}",
              "mediaUpload": {
                "protocols": {
                  "resumable": {
                    "path": "/resumable/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/deobfuscationFiles/{deobfuscationFileType}",
                    "multipart": true
                  },
                  "simple": {
                    "multipart": true,
                    "path": "/upload/androidpublisher/v3/applications/{packageName}/edits/{editId}/apks/{apkVersionCode}/deobfuscationFiles/{deobfuscationFileType}"
                  }
                },
                "accept": [
                  "application/octet-stream"
                ],
                "maxSize": "1677721600"
              },
              "parameterOrder": [
                "packageName",
                "editId",
                "apkVersionCode",
                "deobfuscationFileType"
              ]
            }
          }
        }
      },
      "methods": {
        "get": {
          "parameterOrder": [
            "packageName",
            "editId"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Gets an app edit.",
          "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}",
          "id": "androidpublisher.edits.get",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            },
            "editId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Identifier of the edit."
            }
          },
          "response": {
            "$ref": "AppEdit"
          }
        },
        "commit": {
          "id": "androidpublisher.edits.commit",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            },
            "editId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Identifier of the edit."
            },
            "changesNotSentForReview": {
              "location": "query",
              "type": "boolean",
              "description": "When a rejection happens, the parameter will make sure that the changes in this edit won't be reviewed until they are explicitly sent for review from within the Google Play Console UI. These changes will be added to any other changes that are not yet sent for review."
            },
            "changesInReviewBehavior": {
              "enumDescriptions": [
                "Defaults to CANCEL_IN_REVIEW_AND_SUBMIT.",
                "If there are changes already in review, then this will cancel that review first and then send all the changes for publishing.",
                "If there are changes in review, then this will return an error. Please refer to the error message sample that is returned when this happens. Note that this won't invalidate the edit. If there aren't any changes in review, then this will continue and send the new changes for publishing."
              ],
              "description": "Optional. Specify how the API should behave if there are changes currently in review. If this value is not set, it will default to \"CANCEL_IN_REVIEW_AND_SUBMIT\", which will cancel the changes in review and then send all the changes for publishing.",
              "enum": [
                "CHANGES_IN_REVIEW_BEHAVIOR_TYPE_UNSPECIFIED",
                "CANCEL_IN_REVIEW_AND_SUBMIT",
                "ERROR_IF_IN_REVIEW"
              ],
              "location": "query",
              "type": "string"
            }
          },
          "response": {
            "$ref": "AppEdit"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Commits an app edit.",
          "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}:commit",
          "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}:commit",
          "parameterOrder": [
            "packageName",
            "editId"
          ]
        },
        "insert": {
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/{packageName}/edits",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Creates a new edit for an app.",
          "request": {
            "$ref": "AppEdit"
          },
          "path": "androidpublisher/v3/applications/{packageName}/edits",
          "id": "androidpublisher.edits.insert",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Package name of the app."
            }
          },
          "response": {
            "$ref": "AppEdit"
          }
        },
        "delete": {
          "parameters": {
            "packageName": {
              "type": "string",
              "description": "Package name of the app.",
              "location": "path",
              "required": true
            },
            "editId": {
              "location": "path",
              "required": true,
              "description": "Identifier of the edit.",
              "type": "string"
            }
          },
          "id": "androidpublisher.edits.delete",
          "httpMethod": "DELETE",
          "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Deletes an app edit.",
          "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}",
          "parameterOrder": [
            "packageName",
            "editId"
          ]
        },
        "validate": {
          "parameters": {
            "packageName": {
              "description": "Package name of the app.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "editId": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Identifier of the edit."
            }
          },
          "id": "androidpublisher.edits.validate",
          "httpMethod": "POST",
          "response": {
            "$ref": "AppEdit"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Validates an app edit.",
          "path": "androidpublisher/v3/applications/{packageName}/edits/{editId}:validate",
          "flatPath": "androidpublisher/v3/applications/{packageName}/edits/{editId}:validate",
          "parameterOrder": [
            "packageName",
            "editId"
          ]
        }
      }
    },
    "internalappsharingartifacts": {
      "methods": {
        "uploadapk": {
          "parameterOrder": [
            "packageName"
          ],
          "flatPath": "androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/apk",
          "mediaUpload": {
            "protocols": {
              "resumable": {
                "multipart": true,
                "path": "/resumable/upload/androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/apk"
              },
              "simple": {
                "multipart": true,
                "path": "/upload/androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/apk"
              }
            },
            "accept": [
              "application/octet-stream",
              "application/vnd.android.package-archive"
            ],
            "maxSize": "1073741824"
          },
          "path": "androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/apk",
          "supportsMediaUpload": true,
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Uploads an APK to internal app sharing. If you are using the Google API client libraries, please increase the timeout of the http request before calling this endpoint (a timeout of 2 minutes is recommended). See [Timeouts and Errors](https://developers.google.com/api-client-library/java/google-api-java-client/errors) for an example in java.",
          "response": {
            "$ref": "InternalAppSharingArtifact"
          },
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "description": "Package name of the app.",
              "type": "string"
            }
          },
          "id": "androidpublisher.internalappsharingartifacts.uploadapk",
          "httpMethod": "POST"
        },
        "uploadbundle": {
          "mediaUpload": {
            "accept": [
              "application/octet-stream"
            ],
            "maxSize": "10737418240",
            "protocols": {
              "resumable": {
                "path": "/resumable/upload/androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/bundle",
                "multipart": true
              },
              "simple": {
                "multipart": true,
                "path": "/upload/androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/bundle"
              }
            }
          },
          "flatPath": "androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/bundle",
          "parameterOrder": [
            "packageName"
          ],
          "id": "androidpublisher.internalappsharingartifacts.uploadbundle",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "type": "string",
              "description": "Package name of the app.",
              "location": "path",
              "required": true
            }
          },
          "response": {
            "$ref": "InternalAppSharingArtifact"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Uploads an app bundle to internal app sharing. If you are using the Google API client libraries, please increase the timeout of the http request before calling this endpoint (a timeout of 2 minutes is recommended). See [Timeouts and Errors](https://developers.google.com/api-client-library/java/google-api-java-client/errors) for an example in java.",
          "path": "androidpublisher/v3/applications/internalappsharing/{packageName}/artifacts/bundle",
          "supportsMediaUpload": true
        }
      }
    },
    "applications": {
      "resources": {
        "deviceTierConfigs": {
          "methods": {
            "create": {
              "flatPath": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs",
              "parameterOrder": [
                "packageName"
              ],
              "response": {
                "$ref": "DeviceTierConfig"
              },
              "id": "androidpublisher.applications.deviceTierConfigs.create",
              "httpMethod": "POST",
              "parameters": {
                "allowUnknownDevices": {
                  "type": "boolean",
                  "description": "Whether the service should accept device IDs that are unknown to Play's device catalog.",
                  "location": "query"
                },
                "packageName": {
                  "location": "path",
                  "required": true,
                  "type": "string",
                  "description": "Package name of the app."
                }
              },
              "request": {
                "$ref": "DeviceTierConfig"
              },
              "path": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Creates a new device tier config for an app."
            },
            "get": {
              "response": {
                "$ref": "DeviceTierConfig"
              },
              "id": "androidpublisher.applications.deviceTierConfigs.get",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "location": "path",
                  "required": true,
                  "description": "Package name of the app.",
                  "type": "string"
                },
                "deviceTierConfigId": {
                  "location": "path",
                  "required": true,
                  "format": "int64",
                  "description": "Required. Id of an existing device tier config.",
                  "type": "string"
                }
              },
              "path": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs/{deviceTierConfigId}",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Returns a particular device tier config.",
              "flatPath": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs/{deviceTierConfigId}",
              "parameterOrder": [
                "packageName",
                "deviceTierConfigId"
              ]
            },
            "list": {
              "parameterOrder": [
                "packageName"
              ],
              "flatPath": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs",
              "scopes": [
                "https://www.googleapis.com/auth/androidpublisher"
              ],
              "description": "Returns created device tier configs, ordered by descending creation time.",
              "path": "androidpublisher/v3/applications/{packageName}/deviceTierConfigs",
              "id": "androidpublisher.applications.deviceTierConfigs.list",
              "httpMethod": "GET",
              "parameters": {
                "packageName": {
                  "description": "Package name of the app.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "pageSize": {
                  "description": "The maximum number of device tier configs to return. The service may return fewer than this value. If unspecified, at most 10 device tier configs will be returned. The maximum value for this field is 100; values above 100 will be coerced to 100. Device tier configs will be ordered by descending creation time.",
                  "type": "integer",
                  "format": "int32",
                  "location": "query"
                },
                "pageToken": {
                  "location": "query",
                  "type": "string",
                  "description": "A page token, received from a previous `ListDeviceTierConfigs` call. Provide this to retrieve the subsequent page."
                }
              },
              "response": {
                "$ref": "ListDeviceTierConfigsResponse"
              }
            }
          }
        },
        "tracks": {
          "resources": {
            "releases": {
              "methods": {
                "list": {
                  "flatPath": "androidpublisher/v3/applications/{applicationsId}/tracks/{tracksId}/releases",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "androidpublisher.applications.tracks.releases.list",
                  "httpMethod": "GET",
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "pattern": "^applications/[^/]+/tracks/[^/]+$",
                      "description": "Required. The parent track, which owns this collection of releases. Format: applications/{package_name}/tracks/{track}",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "ListReleaseSummariesResponse"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/androidpublisher"
                  ],
                  "description": "Returns the list of all releases for a given track. This excludes any releases that are obsolete.",
                  "path": "androidpublisher/v3/{+parent}/releases"
                }
              }
            }
          }
        }
      },
      "methods": {
        "dataSafety": {
          "id": "androidpublisher.applications.dataSafety",
          "httpMethod": "POST",
          "parameters": {
            "packageName": {
              "location": "path",
              "required": true,
              "type": "string",
              "description": "Required. Package name of the app."
            }
          },
          "response": {
            "$ref": "SafetyLabelsUpdateResponse"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Writes the Safety Labels declaration of an app.",
          "request": {
            "$ref": "SafetyLabelsUpdateRequest"
          },
          "path": "androidpublisher/v3/applications/{packageName}/dataSafety",
          "flatPath": "androidpublisher/v3/applications/{packageName}/dataSafety",
          "parameterOrder": [
            "packageName"
          ]
        }
      }
    },
    "users": {
      "methods": {
        "create": {
          "flatPath": "androidpublisher/v3/developers/{developersId}/users",
          "parameterOrder": [
            "parent"
          ],
          "response": {
            "$ref": "User"
          },
          "id": "androidpublisher.users.create",
          "httpMethod": "POST",
          "parameters": {
            "parent": {
              "location": "path",
              "required": true,
              "description": "Required. The developer account to add the user to. Format: developers/{developer}",
              "pattern": "^developers/[^/]+$",
              "type": "string"
            }
          },
          "request": {
            "$ref": "User"
          },
          "path": "androidpublisher/v3/{+parent}/users",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Grant access for a user to the given developer account."
        },
        "list": {
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Lists all users with access to a developer account.",
          "path": "androidpublisher/v3/{+parent}/users",
          "id": "androidpublisher.users.list",
          "httpMethod": "GET",
          "parameters": {
            "pageSize": {
              "type": "integer",
              "format": "int32",
              "description": "The maximum number of results to return. This must be set to -1 to disable pagination.",
              "location": "query"
            },
            "pageToken": {
              "description": "A token received from a previous call to this method, in order to retrieve further results.",
              "type": "string",
              "location": "query"
            },
            "parent": {
              "type": "string",
              "pattern": "^developers/[^/]+$",
              "description": "Required. The developer account to fetch users from. Format: developers/{developer}",
              "location": "path",
              "required": true
            }
          },
          "response": {
            "$ref": "ListUsersResponse"
          },
          "parameterOrder": [
            "parent"
          ],
          "flatPath": "androidpublisher/v3/developers/{developersId}/users"
        },
        "patch": {
          "flatPath": "androidpublisher/v3/developers/{developersId}/users/{usersId}",
          "parameterOrder": [
            "name"
          ],
          "id": "androidpublisher.users.patch",
          "httpMethod": "PATCH",
          "parameters": {
            "name": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. Resource name for this user, following the pattern \"developers/{developer}/users/{email}\".",
              "pattern": "^developers/[^/]+/users/[^/]+$"
            },
            "updateMask": {
              "location": "query",
              "type": "string",
              "format": "google-fieldmask",
              "description": "Optional. The list of fields to be updated."
            }
          },
          "response": {
            "$ref": "User"
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Updates access for the user to the developer account.",
          "request": {
            "$ref": "User"
          },
          "path": "androidpublisher/v3/{+name}"
        },
        "delete": {
          "flatPath": "androidpublisher/v3/developers/{developersId}/users/{usersId}",
          "id": "androidpublisher.users.delete",
          "httpMethod": "DELETE",
          "parameters": {
            "name": {
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^developers/[^/]+/users/[^/]+$",
              "description": "Required. The name of the user to delete. Format: developers/{developer}/users/{email}"
            }
          },
          "path": "androidpublisher/v3/{+name}",
          "parameterOrder": [
            "name"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Removes all access for the user to the given developer account."
        }
      }
    },
    "grants": {
      "methods": {
        "create": {
          "parameterOrder": [
            "parent"
          ],
          "flatPath": "androidpublisher/v3/developers/{developersId}/users/{usersId}/grants",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Grant access for a user to the given package.",
          "request": {
            "$ref": "Grant"
          },
          "path": "androidpublisher/v3/{+parent}/grants",
          "id": "androidpublisher.grants.create",
          "httpMethod": "POST",
          "parameters": {
            "parent": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. The user which needs permission. Format: developers/{developer}/users/{user}",
              "pattern": "^developers/[^/]+/users/[^/]+$"
            }
          },
          "response": {
            "$ref": "Grant"
          }
        },
        "patch": {
          "response": {
            "$ref": "Grant"
          },
          "id": "androidpublisher.grants.patch",
          "httpMethod": "PATCH",
          "parameters": {
            "name": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. Resource name for this grant, following the pattern \"developers/{developer}/users/{email}/grants/{package_name}\". If this grant is for a draft app, the app ID will be used in this resource name instead of the package name.",
              "pattern": "^developers/[^/]+/users/[^/]+/grants/[^/]+$"
            },
            "updateMask": {
              "location": "query",
              "type": "string",
              "format": "google-fieldmask",
              "description": "Optional. The list of fields to be updated."
            }
          },
          "request": {
            "$ref": "Grant"
          },
          "path": "androidpublisher/v3/{+name}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Updates access for the user to the given package.",
          "flatPath": "androidpublisher/v3/developers/{developersId}/users/{usersId}/grants/{grantsId}",
          "parameterOrder": [
            "name"
          ]
        },
        "delete": {
          "flatPath": "androidpublisher/v3/developers/{developersId}/users/{usersId}/grants/{grantsId}",
          "parameters": {
            "name": {
              "type": "string",
              "location": "path",
              "required": true,
              "description": "Required. The name of the grant to delete. Format: developers/{developer}/users/{email}/grants/{package_name}",
              "pattern": "^developers/[^/]+/users/[^/]+/grants/[^/]+$"
            }
          },
          "id": "androidpublisher.grants.delete",
          "httpMethod": "DELETE",
          "path": "androidpublisher/v3/{+name}",
          "parameterOrder": [
            "name"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Removes all access for the user to the given package or developer account."
        }
      }
    },
    "generatedapks": {
      "methods": {
        "list": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/generatedApks/{versionCode}",
          "parameterOrder": [
            "packageName",
            "versionCode"
          ],
          "response": {
            "$ref": "GeneratedApksListResponse"
          },
          "id": "androidpublisher.generatedapks.list",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "description": "Package name of the app.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "versionCode": {
              "type": "integer",
              "location": "path",
              "required": true,
              "description": "Version code of the app bundle.",
              "format": "int32"
            }
          },
          "path": "androidpublisher/v3/applications/{packageName}/generatedApks/{versionCode}",
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Returns download metadata for all APKs that were generated from a given app bundle."
        },
        "download": {
          "flatPath": "androidpublisher/v3/applications/{packageName}/generatedApks/{versionCode}/downloads/{downloadId}:download",
          "supportsMediaDownload": true,
          "useMediaDownloadService": true,
          "parameterOrder": [
            "packageName",
            "versionCode",
            "downloadId"
          ],
          "id": "androidpublisher.generatedapks.download",
          "httpMethod": "GET",
          "parameters": {
            "packageName": {
              "description": "Package name of the app.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "versionCode": {
              "format": "int32",
              "description": "Version code of the app bundle.",
              "location": "path",
              "required": true,
              "type": "integer"
            },
            "downloadId": {
              "description": "Download ID, which uniquely identifies the APK to download. Can be obtained from the response of `generatedapks.list` method.",
              "type": "string",
              "location": "path",
              "required": true
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/androidpublisher"
          ],
          "description": "Downloads a single signed APK generated from an app bundle.",
          "path": "androidpublisher/v3/applications/{packageName}/generatedApks/{versionCode}/downloads/{downloadId}:download"
        }
      }
    }
  },
  "rootUrl": "https://androidpublisher.googleapis.com/",
  "basePath": "",
  "servicePath": "",
  "batchPath": "batch",
  "description": "Lets Android application developers access their Google Play accounts. At a high level, the expected workflow is to \"insert\" an Edit, make changes as necessary, and then \"commit\" it. ",
  "discoveryVersion": "v1",
  "title": "Google Play Android Developer API",
  "name": "androidpublisher",
  "canonicalName": "Android Publisher",
  "ownerDomain": "google.com",
  "id": "androidpublisher:v3",
  "kind": "discovery#restDescription",
  "version": "v3",
  "mtlsRootUrl": "https://androidpublisher.mtls.googleapis.com/",
  "protocol": "rest",
  "documentationLink": "https://developers.google.com/android-publisher",
  "schemas": {
    "PrepaidBasePlanType": {
      "id": "PrepaidBasePlanType",
      "type": "object",
      "description": "Represents a base plan that does not automatically renew at the end of the base plan, and must be manually renewed by the user.",
      "properties": {
        "billingPeriodDuration": {
          "type": "string",
          "description": "Required. Immutable. Subscription period, specified in ISO 8601 format. For a list of acceptable billing periods, refer to the help center. The duration is immutable after the base plan is created."
        },
        "timeExtension": {
          "enum": [
            "TIME_EXTENSION_UNSPECIFIED",
            "TIME_EXTENSION_ACTIVE",
            "TIME_EXTENSION_INACTIVE"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified state.",
            "Time extension is active. Users are allowed to top-up or extend their prepaid plan.",
            "Time extension is inactive. Users cannot top-up or extend their prepaid plan."
          ],
          "description": "Whether users should be able to extend this prepaid base plan in Google Play surfaces. Defaults to TIME_EXTENSION_ACTIVE if not specified."
        }
      }
    },
    "UpdateOneTimeProductOfferRequest": {
      "id": "UpdateOneTimeProductOfferRequest",
      "type": "object",
      "description": "Request message for UpdateOneTimeProductOffer.",
      "properties": {
        "oneTimeProductOffer": {
          "$ref": "OneTimeProductOffer",
          "description": "Required. The one-time product offer to update."
        },
        "regionsVersion": {
          "$ref": "RegionsVersion",
          "description": "Required. The version of the available regions being used for the offer."
        },
        "allowMissing": {
          "description": "Optional. If set to true, and the offer with the given package_name, product_id, purchase_option_id and offer_id doesn't exist, an offer will be created. If a new offer is created, the update_mask is ignored.",
          "type": "boolean"
        },
        "latencyTolerance": {
          "description": "Optional. The latency tolerance for the propagation of this offer update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "updateMask": {
          "type": "string",
          "format": "google-fieldmask",
          "description": "Required. The list of fields to be updated."
        }
      }
    },
    "BatchUpdateOneTimeProductOffersRequest": {
      "id": "BatchUpdateOneTimeProductOffersRequest",
      "type": "object",
      "description": "Request message for BatchUpdateOneTimeProductOffers.",
      "properties": {
        "requests": {
          "description": "Required. A list of update requests of up to 100 elements. All requests must update different offers.",
          "type": "array",
          "items": {
            "$ref": "UpdateOneTimeProductOfferRequest"
          }
        }
      }
    },
    "OrderHistory": {
      "id": "OrderHistory",
      "type": "object",
      "description": "Details about events which modified the order.",
      "properties": {
        "partialRefundEvents": {
          "type": "array",
          "items": {
            "$ref": "PartialRefundEvent"
          },
          "description": "Details of the partial refund events for this order."
        },
        "processedEvent": {
          "$ref": "ProcessedEvent",
          "description": "Details of when the order was processed."
        },
        "cancellationEvent": {
          "description": "Details of when the order was canceled.",
          "$ref": "CancellationEvent"
        },
        "refundEvent": {
          "$ref": "RefundEvent",
          "description": "Details of when the order was fully refunded."
        }
      }
    },
    "SubscriptionListing": {
      "id": "SubscriptionListing",
      "type": "object",
      "description": "The consumer-visible metadata of a subscription.",
      "properties": {
        "title": {
          "type": "string",
          "description": "Required. The title of this subscription in the language of this listing. Plain text."
        },
        "benefits": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "A list of benefits shown to the user on platforms such as the Play Store and in restoration flows in the language of this listing. Plain text. Ordered list of at most four benefits."
        },
        "languageCode": {
          "description": "Required. The language of this listing, as defined by BCP-47, e.g. \"en-US\".",
          "type": "string"
        },
        "description": {
          "description": "The description of this subscription in the language of this listing. Maximum length - 200 characters. Plain text.",
          "type": "string"
        }
      }
    },
    "BatchUpdateSubscriptionOffersResponse": {
      "description": "Response message for BatchUpdateSubscriptionOffers.",
      "properties": {
        "subscriptionOffers": {
          "type": "array",
          "items": {
            "$ref": "SubscriptionOffer"
          },
          "description": "The updated subscription offers list."
        }
      },
      "id": "BatchUpdateSubscriptionOffersResponse",
      "type": "object"
    },
    "ImagesUploadResponse": {
      "description": "Response for uploading an image.",
      "properties": {
        "image": {
          "$ref": "Image",
          "description": "The uploaded image."
        }
      },
      "id": "ImagesUploadResponse",
      "type": "object"
    },
    "RestrictedPaymentCountries": {
      "id": "RestrictedPaymentCountries",
      "type": "object",
      "description": "Countries where the purchase of this product is restricted to payment methods registered in the same country. If empty, no payment location restrictions are imposed.",
      "properties": {
        "regionCodes": {
          "description": "Required. Region codes to impose payment restrictions on, as defined by ISO 3166-2, e.g. \"US\".",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "RegionalTaxConfig": {
      "id": "RegionalTaxConfig",
      "type": "object",
      "description": "Details about taxation in a given geographical region.",
      "properties": {
        "regionCode": {
          "type": "string",
          "description": "Required. Region code this configuration applies to, as defined by ISO 3166-2, e.g. \"US\"."
        },
        "taxTier": {
          "enum": [
            "TAX_TIER_UNSPECIFIED",
            "TAX_TIER_BOOKS_1",
            "TAX_TIER_NEWS_1",
            "TAX_TIER_NEWS_2",
            "TAX_TIER_MUSIC_OR_AUDIO_1",
            "TAX_TIER_LIVE_OR_BROADCAST_1"
          ],
          "type": "string",
          "enumDescriptions": [
            "",
            "",
            "",
            "",
            "",
            ""
          ],
          "description": "Tax tier to specify reduced tax rate. Developers who sell digital news, magazines, newspapers, books, or audiobooks in various regions may be eligible for reduced tax rates. [Learn more](https://support.google.com/googleplay/android-developer/answer/10463498)."
        },
        "eligibleForStreamingServiceTaxRate": {
          "type": "boolean",
          "description": "You must tell us if your app contains streaming products to correctly charge US state and local sales tax. Field only supported in the United States."
        },
        "streamingTaxType": {
          "type": "string",
          "enumDescriptions": [
            "No telecommunications tax collected.",
            "US-specific telecommunications tax tier for video streaming, on demand, rentals / subscriptions / pay-per-view.",
            "US-specific telecommunications tax tier for video streaming of pre-recorded content like movies, tv shows.",
            "US-specific telecommunications tax tier for video streaming of multi-channel programming.",
            "US-specific telecommunications tax tier for audio streaming, rental / subscription.",
            "US-specific telecommunications tax tier for audio streaming, sale / permanent download.",
            "US-specific telecommunications tax tier for multi channel audio streaming like radio."
          ],
          "description": "To collect communications or amusement taxes in the United States, choose the appropriate tax category. [Learn more](https://support.google.com/googleplay/android-developer/answer/10463498#streaming_tax).",
          "enum": [
            "STREAMING_TAX_TYPE_UNSPECIFIED",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_RENTAL",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_SALES",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_MULTI_CHANNEL",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_RENTAL",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_SALES",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_MULTI_CHANNEL"
          ]
        }
      }
    },
    "DeviceRam": {
      "id": "DeviceRam",
      "type": "object",
      "description": "Conditions about a device's RAM capabilities.",
      "properties": {
        "minBytes": {
          "type": "string",
          "format": "int64",
          "description": "Minimum RAM in bytes (bound included)."
        },
        "maxBytes": {
          "type": "string",
          "format": "int64",
          "description": "Maximum RAM in bytes (bound excluded)."
        }
      }
    },
    "OtherRegionsSubscriptionOfferConfig": {
      "description": "Configuration for any new locations Play may launch in specified on a subscription offer.",
      "properties": {
        "otherRegionsNewSubscriberAvailability": {
          "description": "Whether the subscription offer in any new locations Play may launch in the future. If not specified, this will default to false.",
          "type": "boolean"
        }
      },
      "id": "OtherRegionsSubscriptionOfferConfig",
      "type": "object"
    },
    "PausedStateContext": {
      "description": "Information specific to a subscription in paused state.",
      "properties": {
        "autoResumeTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Time at which the subscription will be automatically resumed."
        }
      },
      "id": "PausedStateContext",
      "type": "object"
    },
    "SubscriptionCancelSurveyResult": {
      "description": "Information provided by the user when they complete the subscription cancellation flow (cancellation reason survey).",
      "properties": {
        "cancelSurveyReason": {
          "type": "integer",
          "format": "int32",
          "description": "The cancellation reason the user chose in the survey. Possible values are: 0. Other 1. I don't use this service enough 2. Technical issues 3. Cost-related reasons 4. I found a better app"
        },
        "userInputCancelReason": {
          "description": "The customized input cancel reason from the user. Only present when cancelReason is 0.",
          "type": "string"
        }
      },
      "id": "SubscriptionCancelSurveyResult",
      "type": "object"
    },
    "UpgradeTargetingRule": {
      "description": "Represents a targeting rule of the form: User currently has {scope} [with billing period {billing_period}].",
      "properties": {
        "scope": {
          "description": "Required. The scope of subscriptions this rule considers. Only allows \"this subscription\" and \"specific subscription in app\".",
          "$ref": "TargetingRuleScope"
        },
        "billingPeriodDuration": {
          "description": "The specific billing period duration, specified in ISO 8601 format, that a user must be currently subscribed to to be eligible for this rule. If not specified, users subscribed to any billing period are matched.",
          "type": "string"
        },
        "oncePerUser": {
          "type": "boolean",
          "description": "Limit this offer to only once per user. If set to true, a user can never be eligible for this offer again if they ever subscribed to this offer."
        }
      },
      "id": "UpgradeTargetingRule",
      "type": "object"
    },
    "InappproductsListResponse": {
      "description": "Response listing all in-app products.",
      "properties": {
        "tokenPagination": {
          "description": "Pagination token, to handle a number of products that is over one page.",
          "$ref": "TokenPagination"
        },
        "kind": {
          "type": "string",
          "description": "The kind of this response (\"androidpublisher#inappproductsListResponse\")."
        },
        "inappproduct": {
          "type": "array",
          "items": {
            "$ref": "InAppProduct"
          },
          "description": "All in-app products."
        },
        "pageInfo": {
          "deprecated": true,
          "$ref": "PageInfo",
          "description": "Deprecated and unset."
        }
      },
      "id": "InappproductsListResponse",
      "type": "object"
    },
    "DeviceFeature": {
      "id": "DeviceFeature",
      "type": "object",
      "description": "Represents a device feature.",
      "properties": {
        "featureName": {
          "description": "Name of the feature.",
          "type": "string"
        },
        "featureVersion": {
          "description": "The feature version specified by android:glEsVersion or android:version in in the AndroidManifest.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "TestPurchaseContext": {
      "description": "Context about a test purchase.",
      "properties": {
        "fopType": {
          "enum": [
            "FOP_TYPE_UNSPECIFIED",
            "TEST"
          ],
          "type": "string",
          "enumDescriptions": [
            "Fop type unspecified. This value should never be set.",
            "The purchase was made using a test card."
          ],
          "description": "The fop type of the test purchase."
        }
      },
      "id": "TestPurchaseContext",
      "type": "object"
    },
    "OneTimeProductOfferRegionalPricingAndAvailabilityConfig": {
      "id": "OneTimeProductOfferRegionalPricingAndAvailabilityConfig",
      "type": "object",
      "description": "Regional pricing and availability configuration for a one-time product offer.",
      "properties": {
        "noOverride": {
          "description": "The price defined in the purchase option for this region will be used.",
          "$ref": "OneTimeProductOfferNoPriceOverrideOptions"
        },
        "relativeDiscount": {
          "type": "number",
          "format": "double",
          "description": "The fraction of the purchase option price that the user pays for this offer. For example, if the purchase option price for this region is $12, then a 50% discount would correspond to a price of $6. The discount must be specified as a fraction strictly larger than 0 and strictly smaller than 1. The resulting price will be rounded to the nearest billable unit (e.g. cents for USD). The relative discount is considered invalid if the discounted price ends up being smaller than the minimum price allowed in this region."
        },
        "absoluteDiscount": {
          "$ref": "Money",
          "description": "The absolute value of the discount that is subtracted from the purchase option price. It should be between 0 and the purchase option price."
        },
        "regionCode": {
          "type": "string",
          "description": "Required. Region code this configuration applies to, as defined by ISO 3166-2, e.g., \"US\"."
        },
        "availability": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified availability. Must not be used.",
            "The offer is available to users.",
            "The offer is no longer available to users. This value can only be used if the availability was previously set as AVAILABLE."
          ],
          "description": "Required. The availability for this region.",
          "enum": [
            "AVAILABILITY_UNSPECIFIED",
            "AVAILABLE",
            "NO_LONGER_AVAILABLE"
          ]
        }
      }
    },
    "DeobfuscationFile": {
      "description": "Represents a deobfuscation file.",
      "properties": {
        "symbolType": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified deobfuscation file type.",
            "Proguard deobfuscation file type.",
            "Native debugging symbols file type."
          ],
          "description": "The type of the deobfuscation file.",
          "enum": [
            "deobfuscationFileTypeUnspecified",
            "proguard",
            "nativeCode"
          ]
        }
      },
      "id": "DeobfuscationFile",
      "type": "object"
    },
    "BatchGetOneTimeProductOffersResponse": {
      "id": "BatchGetOneTimeProductOffersResponse",
      "type": "object",
      "description": "Response message for the BatchGetOneTimeProductOffers endpoint.",
      "properties": {
        "oneTimeProductOffers": {
          "type": "array",
          "items": {
            "$ref": "OneTimeProductOffer"
          },
          "description": "The list of updated one-time product offers, in the same order as the request."
        }
      }
    },
    "ReleaseSummary": {
      "description": "Summary of a release.",
      "properties": {
        "releaseName": {
          "description": "Name of the release.",
          "type": "string"
        },
        "track": {
          "description": "Identifier for the track. [Learn more about track names.](https://developers.google.com/android-publisher/tracks).",
          "type": "string"
        },
        "activeArtifacts": {
          "type": "array",
          "items": {
            "$ref": "ArtifactSummary"
          },
          "description": "List of active artifacts on this release"
        },
        "releaseLifecycleState": {
          "enum": [
            "RELEASE_LIFECYCLE_STATE_UNSPECIFIED",
            "RELEASE_LIFECYCLE_STATE_DRAFT",
            "RELEASE_LIFECYCLE_STATE_NOT_SENT_FOR_REVIEW",
            "RELEASE_LIFECYCLE_STATE_IN_REVIEW",
            "RELEASE_LIFECYCLE_STATE_APPROVED_NOT_PUBLISHED",
            "RELEASE_LIFECYCLE_STATE_NOT_APPROVED",
            "RELEASE_LIFECYCLE_STATE_PUBLISHED"
          ],
          "description": "The lifecycle state of a release.",
          "type": "string",
          "enumDescriptions": [
            "Not specified.",
            "The release is not yet ready and can still be edited.",
            "The release is ready to be sent for review and an action is required from developer",
            "Submitted and in review",
            "Passed review and is ready to be published manually by developer",
            "App was rejected in review",
            "Available to users on the track. This includes fully- or partially-rolled out releases and any halted release that can be resumed."
          ]
        }
      },
      "id": "ReleaseSummary",
      "type": "object"
    },
    "SubscriptionPurchase": {
      "id": "SubscriptionPurchase",
      "type": "object",
      "description": "A SubscriptionPurchase resource indicates the status of a user's subscription purchase.",
      "properties": {
        "obfuscatedExternalAccountId": {
          "description": "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.",
          "type": "string"
        },
        "acknowledgementState": {
          "description": "The acknowledgement state of the subscription product. Possible values are: 0. Yet to be acknowledged 1. Acknowledged",
          "type": "integer",
          "format": "int32"
        },
        "introductoryPriceInfo": {
          "$ref": "IntroductoryPriceInfo",
          "description": "Introductory price information of the subscription. This is only present when the subscription was purchased with an introductory price. This field does not indicate the subscription is currently in introductory price period."
        },
        "obfuscatedExternalProfileId": {
          "description": "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.",
          "type": "string"
        },
        "kind": {
          "type": "string",
          "description": "This kind represents a subscriptionPurchase object in the androidpublisher service."
        },
        "profileName": {
          "type": "string",
          "description": "The profile name of the user when the subscription was purchased. Only present for purchases made with 'Subscribe with Google'."
        },
        "familyName": {
          "type": "string",
          "description": "The family name of the user when the subscription was purchased. Only present for purchases made with 'Subscribe with Google'."
        },
        "expiryTimeMillis": {
          "type": "string",
          "format": "int64",
          "description": "Time at which the subscription will expire, in milliseconds since the Epoch."
        },
        "profileId": {
          "type": "string",
          "description": "The Google profile id of the user when the subscription was purchased. Only present for purchases made with 'Subscribe with Google'."
        },
        "priceCurrencyCode": {
          "description": "ISO 4217 currency code for the subscription price. For example, if the price is specified in British pounds sterling, price_currency_code is \"GBP\".",
          "type": "string"
        },
        "priceAmountMicros": {
          "description": "Price of the subscription, For tax exclusive countries, the price doesn't include tax. For tax inclusive countries, the price includes tax. Price is expressed in micro-units, where 1,000,000 micro-units represents one unit of the currency. For example, if the subscription price is €1.99, price_amount_micros is 1990000.",
          "type": "string",
          "format": "int64"
        },
        "cancelSurveyResult": {
          "description": "Information provided by the user when they complete the subscription cancellation flow (cancellation reason survey).",
          "$ref": "SubscriptionCancelSurveyResult"
        },
        "startTimeMillis": {
          "type": "string",
          "format": "int64",
          "description": "Time at which the subscription was granted, in milliseconds since the Epoch."
        },
        "orderId": {
          "type": "string",
          "description": "The order id of the latest recurring order associated with the purchase of the subscription. If the subscription was canceled because payment was declined, this will be the order id from the payment declined order."
        },
        "emailAddress": {
          "description": "The email address of the user when the subscription was purchased. Only present for purchases made with 'Subscribe with Google'.",
          "type": "string"
        },
        "countryCode": {
          "type": "string",
          "description": "ISO 3166-1 alpha-2 billing country/region code of the user at the time the subscription was granted."
        },
        "givenName": {
          "description": "The given name of the user when the subscription was purchased. Only present for purchases made with 'Subscribe with Google'.",
          "type": "string"
        },
        "userCancellationTimeMillis": {
          "description": "The time at which the subscription was canceled by the user, in milliseconds since the epoch. Only present if cancelReason is 0.",
          "type": "string",
          "format": "int64"
        },
        "autoRenewing": {
          "description": "Whether the subscription will automatically be renewed when it reaches its current expiry time.",
          "type": "boolean"
        },
        "developerPayload": {
          "description": "A developer-specified string that contains supplemental information about an order.",
          "type": "string"
        },
        "externalAccountId": {
          "description": "User account identifier in the third-party service. Only present if account linking happened as part of the subscription purchase flow.",
          "type": "string"
        },
        "cancelReason": {
          "type": "integer",
          "format": "int32",
          "description": "The reason why a subscription was canceled or is not auto-renewing. Possible values are: 0. User canceled the subscription 1. Subscription was canceled by the system, for example because of a billing problem 2. Subscription was replaced with a new subscription 3. Subscription was canceled by the developer"
        },
        "purchaseType": {
          "type": "integer",
          "format": "int32",
          "description": "The type of purchase of the subscription. This field is only set if this purchase was not made using the standard in-app billing flow. Possible values are: 0. Test (i.e. purchased from a license testing account) 1. Promo (i.e. purchased using a promo code)"
        },
        "linkedPurchaseToken": {
          "description": "The purchase token of the originating purchase if this subscription is one of the following: 0. Re-signup of a canceled but non-lapsed subscription 1. Upgrade/downgrade from a previous subscription For example, suppose a user originally signs up and you receive purchase token X, then the user cancels and goes through the resignup flow (before their subscription lapses) and you receive purchase token Y, and finally the user upgrades their subscription and you receive purchase token Z. If you call this API with purchase token Z, this field will be set to Y. If you call this API with purchase token Y, this field will be set to X. If you call this API with purchase token X, this field will not be set.",
          "type": "string"
        },
        "paymentState": {
          "type": "integer",
          "format": "int32",
          "description": "The payment state of the subscription. Possible values are: 0. Payment pending 1. Payment received 2. Free trial 3. Pending deferred upgrade/downgrade Not present for canceled, expired subscriptions."
        },
        "priceChange": {
          "$ref": "SubscriptionPriceChange",
          "description": "The latest price change information available. This is present only when there is an upcoming price change for the subscription yet to be applied. Once the subscription renews with the new price or the subscription is canceled, no price change information will be returned."
        },
        "promotionCode": {
          "description": "The promotion code applied on this purchase. This field is only set if a vanity code promotion is applied when the subscription was purchased.",
          "type": "string"
        },
        "promotionType": {
          "type": "integer",
          "format": "int32",
          "description": "The type of promotion applied on this purchase. This field is only set if a promotion is applied when the subscription was purchased. Possible values are: 0. One time code 1. Vanity code"
        },
        "autoResumeTimeMillis": {
          "type": "string",
          "format": "int64",
          "description": "Time at which the subscription will be automatically resumed, in milliseconds since the Epoch. Only present if the user has requested to pause the subscription."
        }
      }
    },
    "OutOfAppPurchaseContext": {
      "description": "Information specific to an out of app purchase.",
      "properties": {
        "expiredExternalAccountIdentifiers": {
          "$ref": "ExternalAccountIdentifiers",
          "description": "User account identifier from the last expired subscription for this SKU."
        },
        "expiredPurchaseToken": {
          "description": "The purchase token of the last expired subscription. This purchase token must only be used to help identify the user if the link between the purchaseToken and user is stored in your database. This cannot be used to call the Google Developer API if it has been more than 60 days since expiry.",
          "type": "string"
        }
      },
      "id": "OutOfAppPurchaseContext",
      "type": "object"
    },
    "ListAppRecoveriesResponse": {
      "id": "ListAppRecoveriesResponse",
      "type": "object",
      "description": "Response message for ListAppRecoveries. -- api-linter: core::0158::response-next-page-token-field=disabled",
      "properties": {
        "recoveryActions": {
          "type": "array",
          "items": {
            "$ref": "AppRecoveryAction"
          },
          "description": "List of recovery actions associated with the requested package name."
        }
      }
    },
    "ProcessedEvent": {
      "description": "Details of when the order was processed.",
      "properties": {
        "eventTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when the order was processed."
        }
      },
      "id": "ProcessedEvent",
      "type": "object"
    },
    "DeferredItemReplacement": {
      "id": "DeferredItemReplacement",
      "type": "object",
      "description": "Information related to deferred item replacement.",
      "properties": {
        "productId": {
          "description": "The product_id going to replace the existing product_id.",
          "type": "string"
        }
      }
    },
    "BasePriceOfferPhase": {
      "description": "Details about base price offer phase.",
      "properties": {},
      "id": "BasePriceOfferPhase",
      "type": "object"
    },
    "OneTimeProduct": {
      "description": "A single one-time product for an app.",
      "properties": {
        "listings": {
          "type": "array",
          "items": {
            "$ref": "OneTimeProductListing"
          },
          "description": "Required. Set of localized title and description data. Must not have duplicate entries with the same language_code."
        },
        "purchaseOptions": {
          "description": "Required. The set of purchase options for this one-time product.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProductPurchaseOption"
          }
        },
        "regionsVersion": {
          "$ref": "RegionsVersion",
          "readOnly": true,
          "description": "Output only. The version of the regions configuration that was used to generate the one-time product."
        },
        "restrictedPaymentCountries": {
          "description": "Optional. Countries where the purchase of this one-time product is restricted to payment methods registered in the same country. If empty, no payment location restrictions are imposed.",
          "$ref": "RestrictedPaymentCountries"
        },
        "offerTags": {
          "type": "array",
          "items": {
            "$ref": "OfferTag"
          },
          "description": "Optional. List of up to 20 custom tags specified for this one-time product, and returned to the app through the billing library. Purchase options and offers for this product will also receive these tags in the billing library."
        },
        "productId": {
          "type": "string",
          "description": "Required. Immutable. Unique product ID of the product. Unique within the parent app. Product IDs must start with a number or lowercase letter, and can contain numbers (0-9), lowercase letters (a-z), underscores (_), and periods (.)."
        },
        "packageName": {
          "description": "Required. Immutable. Package name of the parent app.",
          "type": "string"
        },
        "taxAndComplianceSettings": {
          "$ref": "OneTimeProductTaxAndComplianceSettings",
          "description": "Details about taxes and legal compliance."
        }
      },
      "id": "OneTimeProduct",
      "type": "object"
    },
    "ReviewsReplyResponse": {
      "description": "Response on status of replying to a review.",
      "properties": {
        "result": {
          "description": "The result of replying/updating a reply to review.",
          "$ref": "ReviewReplyResult"
        }
      },
      "id": "ReviewsReplyResponse",
      "type": "object"
    },
    "BatchGetSubscriptionOffersResponse": {
      "id": "BatchGetSubscriptionOffersResponse",
      "type": "object",
      "description": "Response message for BatchGetSubscriptionOffers endpoint.",
      "properties": {
        "subscriptionOffers": {
          "type": "array",
          "items": {
            "$ref": "SubscriptionOffer"
          }
        }
      }
    },
    "DeviceTierConfig": {
      "description": "Configuration describing device targeting criteria for the content of an app.",
      "properties": {
        "deviceGroups": {
          "type": "array",
          "items": {
            "$ref": "DeviceGroup"
          },
          "description": "Definition of device groups for the app."
        },
        "userCountrySets": {
          "description": "Definition of user country sets for the app.",
          "type": "array",
          "items": {
            "$ref": "UserCountrySet"
          }
        },
        "deviceTierConfigId": {
          "readOnly": true,
          "type": "string",
          "format": "int64",
          "description": "Output only. The device tier config ID."
        },
        "deviceTierSet": {
          "$ref": "DeviceTierSet",
          "description": "Definition of the set of device tiers for the app."
        }
      },
      "id": "DeviceTierConfig",
      "type": "object"
    },
    "RefundDetails": {
      "id": "RefundDetails",
      "type": "object",
      "description": "Details for a partial or full refund.",
      "properties": {
        "total": {
          "$ref": "Money",
          "description": "The total amount refunded, including tax."
        },
        "tax": {
          "description": "The amount of tax refunded.",
          "$ref": "Money"
        }
      }
    },
    "RemoteInAppUpdate": {
      "id": "RemoteInAppUpdate",
      "type": "object",
      "description": "Object representation for Remote in-app update action type.",
      "properties": {
        "isRemoteInAppUpdateRequested": {
          "description": "Required. Set to true if Remote In-App Update action type is needed.",
          "type": "boolean"
        }
      }
    },
    "AppVersionRange": {
      "id": "AppVersionRange",
      "type": "object",
      "description": "Data format for a continuous range of app versions.",
      "properties": {
        "versionCodeStart": {
          "type": "string",
          "format": "int64",
          "description": "Lowest app version in the range, inclusive."
        },
        "versionCodeEnd": {
          "type": "string",
          "format": "int64",
          "description": "Highest app version in the range, inclusive."
        }
      }
    },
    "ListOneTimeProductOffersResponse": {
      "description": "Response message for ListOneTimeProductOffers.",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        },
        "oneTimeProductOffers": {
          "description": "The one_time_product offers from the specified request.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProductOffer"
          }
        }
      },
      "id": "ListOneTimeProductOffersResponse",
      "type": "object"
    },
    "ExternalOfferDetails": {
      "description": "Reporting details unique to the external offers program.",
      "properties": {
        "installedAppPackage": {
          "type": "string",
          "description": "Optional. The package name of the app downloaded through this transaction. Required when link_type is LINK_TO_APP_DOWNLOAD."
        },
        "appDownloadEventExternalTransactionId": {
          "type": "string",
          "description": "Optional. The external transaction id associated with the app download event through an external link. Required when reporting transactions made in externally installed apps."
        },
        "linkType": {
          "enum": [
            "EXTERNAL_OFFER_LINK_TYPE_UNSPECIFIED",
            "LINK_TO_DIGITAL_CONTENT_OFFER",
            "LINK_TO_APP_DOWNLOAD"
          ],
          "description": "Optional. The type of content being reported by this transaction. Required when reporting app downloads or purchased digital content offers made in app installed through Google Play.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified, do not use.",
            "An offer to purchase digital content.",
            "An app install."
          ]
        },
        "installedAppCategory": {
          "enum": [
            "EXTERNAL_OFFER_APP_CATEGORY_UNSPECIFIED",
            "APP",
            "GAME"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified, do not use.",
            "The app is classified under the app category.",
            "The app is classified under the game category."
          ],
          "description": "Optional. The category of the downloaded app though this transaction. This must match the category provided in Play Console during the external app verification process. Only required for app downloads."
        }
      },
      "id": "ExternalOfferDetails",
      "type": "object"
    },
    "Image": {
      "id": "Image",
      "type": "object",
      "description": "An uploaded image. The resource for ImagesService.",
      "properties": {
        "sha1": {
          "type": "string",
          "description": "A sha1 hash of the image."
        },
        "sha256": {
          "type": "string",
          "description": "A sha256 hash of the image."
        },
        "id": {
          "type": "string",
          "description": "A unique id representing this image."
        },
        "url": {
          "type": "string",
          "description": "A URL that will serve a preview of the image."
        }
      }
    },
    "BatchMigrateBasePlanPricesRequest": {
      "description": "Request message for BatchMigrateBasePlanPrices.",
      "properties": {
        "requests": {
          "description": "Required. Up to 100 price migration requests. All requests must update different base plans.",
          "type": "array",
          "items": {
            "$ref": "MigrateBasePlanPricesRequest"
          }
        }
      },
      "id": "BatchMigrateBasePlanPricesRequest",
      "type": "object"
    },
    "ListReleaseSummariesResponse": {
      "description": "Response listing all releases for a given track that are either ready to be sent for review, in review, approved, not approved or available.",
      "properties": {
        "releases": {
          "description": "List of releases for this track. A maximum of 20 releases can be returned.",
          "type": "array",
          "items": {
            "$ref": "ReleaseSummary"
          }
        }
      },
      "id": "ListReleaseSummariesResponse",
      "type": "object"
    },
    "OrderDetails": {
      "id": "OrderDetails",
      "type": "object",
      "description": "Detailed information about the order at creation time.",
      "properties": {
        "taxInclusive": {
          "description": "Indicates whether the listed price was tax inclusive or not.",
          "type": "boolean"
        }
      }
    },
    "RentOfferDetails": {
      "description": "Offer details information related to a rental line item.",
      "properties": {},
      "id": "RentOfferDetails",
      "type": "object"
    },
    "ActivateBasePlanRequest": {
      "id": "ActivateBasePlanRequest",
      "type": "object",
      "description": "Request message for ActivateBasePlan.",
      "properties": {
        "packageName": {
          "description": "Required. The parent app (package name) of the base plan to activate.",
          "type": "string"
        },
        "productId": {
          "type": "string",
          "description": "Required. The parent subscription (ID) of the base plan to activate."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        },
        "basePlanId": {
          "description": "Required. The unique base plan ID of the base plan to activate.",
          "type": "string"
        }
      }
    },
    "TokenPagination": {
      "id": "TokenPagination",
      "type": "object",
      "description": "Pagination information returned by a List operation when token pagination is enabled. List operations that supports paging return only one \"page\" of results. This protocol buffer message describes the page that has been returned. When using token pagination, clients should use the next/previous token to get another page of the result. The presence or absence of next/previous token indicates whether a next/previous page is available and provides a mean of accessing this page. ListRequest.page_token should be set to either next_page_token or previous_page_token to access another page.",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "Tokens to pass to the standard list field 'page_token'. Whenever available, tokens are preferred over manipulating start_index."
        },
        "previousPageToken": {
          "type": "string"
        }
      }
    },
    "AndroidSdks": {
      "id": "AndroidSdks",
      "type": "object",
      "description": "Android api level targeting data for app recovery action targeting.",
      "properties": {
        "sdkLevels": {
          "description": "Android api levels of devices targeted by recovery action. See https://developer.android.com/guide/topics/manifest/uses-sdk-element#ApiLevels for different api levels in android.",
          "type": "array",
          "items": {
            "type": "string",
            "format": "int64"
          }
        }
      }
    },
    "SubscribeWithGoogleInfo": {
      "id": "SubscribeWithGoogleInfo",
      "type": "object",
      "description": "Information associated with purchases made with 'Subscribe with Google'.",
      "properties": {
        "familyName": {
          "description": "The family name of the user when the subscription was purchased.",
          "type": "string"
        },
        "givenName": {
          "description": "The given name of the user when the subscription was purchased.",
          "type": "string"
        },
        "profileId": {
          "type": "string",
          "description": "The Google profile id of the user when the subscription was purchased."
        },
        "profileName": {
          "description": "The profile name of the user when the subscription was purchased.",
          "type": "string"
        },
        "emailAddress": {
          "description": "The email address of the user when the subscription was purchased.",
          "type": "string"
        }
      }
    },
    "SdkVersion": {
      "id": "SdkVersion",
      "type": "object",
      "description": "Represents an sdk version.",
      "properties": {
        "min": {
          "type": "integer",
          "format": "int32",
          "description": "Inclusive minimum value of an sdk version."
        }
      }
    },
    "TrackConfig": {
      "description": "Configurations of the new track.",
      "properties": {
        "type": {
          "type": "string",
          "enumDescriptions": [
            "Fallback value, do not use.",
            "Closed testing track."
          ],
          "description": "Required. Type of the new track. Currently, the only supported value is closedTesting.",
          "enum": [
            "TRACK_TYPE_UNSPECIFIED",
            "CLOSED_TESTING"
          ]
        },
        "track": {
          "type": "string",
          "description": "Required. Identifier of the new track. For default tracks, this field consists of the track alias only. Form factor tracks have a special prefix as an identifier, for example `wear:production`, `automotive:production`. This prefix must match the value of the `form_factor` field, if it is not a default track. [More on track name](https://developers.google.com/android-publisher/tracks#ff-track-name)"
        },
        "formFactor": {
          "enum": [
            "FORM_FACTOR_UNSPECIFIED",
            "DEFAULT",
            "WEAR",
            "AUTOMOTIVE"
          ],
          "description": "Required. Form factor of the new track. Defaults to the default track.",
          "type": "string",
          "enumDescriptions": [
            "Fallback value, do not use.",
            "Default track.",
            "Wear form factor track.",
            "Automotive form factor track."
          ]
        }
      },
      "id": "TrackConfig",
      "type": "object"
    },
    "OneTimeProductPreOrderOffer": {
      "id": "OneTimeProductPreOrderOffer",
      "type": "object",
      "description": "Configuration specific to pre-order offers.",
      "properties": {
        "priceChangeBehavior": {
          "enum": [
            "PRE_ORDER_PRICE_CHANGE_BEHAVIOR_UNSPECIFIED",
            "PRE_ORDER_PRICE_CHANGE_BEHAVIOR_TWO_POINT_LOWEST",
            "PRE_ORDER_PRICE_CHANGE_BEHAVIOR_NEW_ORDERS_ONLY"
          ],
          "description": "Required. Immutable. Specifies how price changes affect pre-existing pre-orders.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified price change behavior. Must not be used.",
            "The buyer gets charged the minimum between the initial price at the time of pre-order and the final offer price on the release date.",
            "The buyer gets the same price as the one they pre-ordered, regardless of any price changes that may have happened after the pre-order."
          ]
        },
        "startTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Required. Time when the pre-order will start being available."
        },
        "endTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Required. Time when the pre-order will stop being available."
        },
        "releaseTime": {
          "description": "Required. Time on which the product associated with the pre-order will be released and the pre-order orders fulfilled.",
          "type": "string",
          "format": "google-datetime"
        }
      }
    },
    "UserCountrySet": {
      "id": "UserCountrySet",
      "type": "object",
      "description": "A set of user countries. A country set determines what variation of app content gets served to a specific location.",
      "properties": {
        "name": {
          "type": "string",
          "description": "Country set name."
        },
        "countryCodes": {
          "description": "List of country codes representing countries. A Country code is represented in ISO 3166 alpha-2 format. For Example:- \"IT\" for Italy, \"GE\" for Georgia.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ExpansionFilesUploadResponse": {
      "id": "ExpansionFilesUploadResponse",
      "type": "object",
      "description": "Response for uploading an expansion file.",
      "properties": {
        "expansionFile": {
          "description": "The uploaded expansion file configuration.",
          "$ref": "ExpansionFile"
        }
      }
    },
    "DeviceGroup": {
      "id": "DeviceGroup",
      "type": "object",
      "description": "A group of devices. A group is defined by a set of device selectors. A device belongs to the group if it matches any selector (logical OR).",
      "properties": {
        "name": {
          "description": "The name of the group.",
          "type": "string"
        },
        "deviceSelectors": {
          "description": "Device selectors for this group. A device matching any of the selectors is included in this group.",
          "type": "array",
          "items": {
            "$ref": "DeviceSelector"
          }
        }
      }
    },
    "InappproductsUpdateRequest": {
      "description": "Request to update an in-app product.",
      "properties": {
        "inappproduct": {
          "$ref": "InAppProduct",
          "description": "The new in-app product."
        },
        "sku": {
          "description": "Unique identifier for the in-app product.",
          "type": "string"
        },
        "allowMissing": {
          "description": "If set to true, and the in-app product with the given package_name and sku doesn't exist, the in-app product will be created.",
          "type": "boolean"
        },
        "autoConvertMissingPrices": {
          "description": "If true the prices for all regions targeted by the parent app that don't have a price specified for this in-app product will be auto converted to the target currency based on the default price. Defaults to false.",
          "type": "boolean"
        },
        "packageName": {
          "type": "string",
          "description": "Package name of the app."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        }
      },
      "id": "InappproductsUpdateRequest",
      "type": "object"
    },
    "InAppProductListing": {
      "description": "Store listing of a single in-app product.",
      "properties": {
        "title": {
          "description": "Title for the store listing.",
          "type": "string"
        },
        "benefits": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Localized entitlement benefits for a subscription."
        },
        "description": {
          "description": "Description for the store listing.",
          "type": "string"
        }
      },
      "id": "InAppProductListing",
      "type": "object"
    },
    "BuyerAddress": {
      "description": "Address information for the customer, for use in tax computation.",
      "properties": {
        "buyerState": {
          "type": "string",
          "description": "Top-level administrative subdivision of the buyer address country. When Google is the Merchant of Record for the order, this information is not included."
        },
        "buyerCountry": {
          "description": "Two letter country code based on ISO-3166-1 Alpha-2 (UN country codes).",
          "type": "string"
        },
        "buyerPostcode": {
          "type": "string",
          "description": "Postal code of an address. When Google is the Merchant of Record for the order, this information is not included."
        }
      },
      "id": "BuyerAddress",
      "type": "object"
    },
    "DeferredItemRemoval": {
      "description": "Information related to deferred item replacement.",
      "properties": {},
      "id": "DeferredItemRemoval",
      "type": "object"
    },
    "SdkVersionTargeting": {
      "description": "Targeting based on sdk version.",
      "properties": {
        "value": {
          "type": "array",
          "items": {
            "$ref": "SdkVersion"
          },
          "description": "Value of an sdk version."
        },
        "alternatives": {
          "type": "array",
          "items": {
            "$ref": "SdkVersion"
          },
          "description": "Targeting of other sibling directories that were in the Bundle. For main splits this is targeting of other main splits."
        }
      },
      "id": "SdkVersionTargeting",
      "type": "object"
    },
    "RevocationContextItemBasedRefund": {
      "id": "RevocationContextItemBasedRefund",
      "type": "object",
      "description": "Used to determine what specific item to revoke in a subscription with multiple items.",
      "properties": {
        "productId": {
          "description": "Required. If the subscription is a subscription with add-ons, the product id of the subscription item to revoke.",
          "type": "string"
        }
      }
    },
    "PreorderOfferDetails": {
      "id": "PreorderOfferDetails",
      "type": "object",
      "description": "Offer details information related to a preorder line item.",
      "properties": {
        "preorderReleaseTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when a preordered item is released for a preorder purchase."
        }
      }
    },
    "BatchGetOneTimeProductsResponse": {
      "id": "BatchGetOneTimeProductsResponse",
      "type": "object",
      "description": "Response message for the BatchGetOneTimeProducts endpoint.",
      "properties": {
        "oneTimeProducts": {
          "type": "array",
          "items": {
            "$ref": "OneTimeProduct"
          },
          "description": "The list of requested one-time products, in the same order as the request."
        }
      }
    },
    "SafetyLabelsUpdateRequest": {
      "id": "SafetyLabelsUpdateRequest",
      "type": "object",
      "description": "Request to update Safety Labels of an app.",
      "properties": {
        "safetyLabels": {
          "description": "Required. Contents of the CSV file containing Data Safety responses. For the format of this file, see the Help Center documentation at https://support.google.com/googleplay/android-developer/answer/10787469?#zippy=%2Cunderstand-the-csv-format To download an up to date template, follow the steps at https://support.google.com/googleplay/android-developer/answer/10787469?#zippy=%2Cexport-to-a-csv-file",
          "type": "string"
        }
      }
    },
    "User": {
      "description": "A user resource.",
      "properties": {
        "partial": {
          "description": "Output only. Whether there are more permissions for the user that are not represented here. This can happen if the caller does not have permission to manage all apps in the account. This is also `true` if this user is the account owner. If this field is `true`, it should be taken as a signal that this user cannot be fully managed via the API. That is, the API caller is not be able to manage all of the permissions this user holds, either because it doesn't know about them or because the user is the account owner.",
          "readOnly": true,
          "type": "boolean"
        },
        "developerAccountPermissions": {
          "type": "array",
          "items": {
            "enum": [
              "DEVELOPER_LEVEL_PERMISSION_UNSPECIFIED",
              "CAN_SEE_ALL_APPS",
              "CAN_VIEW_FINANCIAL_DATA_GLOBAL",
              "CAN_MANAGE_PERMISSIONS_GLOBAL",
              "CAN_EDIT_GAMES_GLOBAL",
              "CAN_PUBLISH_GAMES_GLOBAL",
              "CAN_REPLY_TO_REVIEWS_GLOBAL",
              "CAN_MANAGE_PUBLIC_APKS_GLOBAL",
              "CAN_MANAGE_TRACK_APKS_GLOBAL",
              "CAN_MANAGE_TRACK_USERS_GLOBAL",
              "CAN_MANAGE_PUBLIC_LISTING_GLOBAL",
              "CAN_MANAGE_DRAFT_APPS_GLOBAL",
              "CAN_CREATE_MANAGED_PLAY_APPS_GLOBAL",
              "CAN_CHANGE_MANAGED_PLAY_SETTING_GLOBAL",
              "CAN_MANAGE_ORDERS_GLOBAL",
              "CAN_MANAGE_APP_CONTENT_GLOBAL",
              "CAN_VIEW_NON_FINANCIAL_DATA_GLOBAL",
              "CAN_VIEW_APP_QUALITY_GLOBAL",
              "CAN_MANAGE_DEEPLINKS_GLOBAL"
            ],
            "type": "string",
            "enumDescriptions": [
              "Unknown or unspecified permission.",
              "View app information and download bulk reports (read-only). Deprecated: Check CAN_VIEW_NON_FINANCIAL_DATA_GLOBAL.",
              "View financial data, orders, and cancellation survey responses.",
              "Admin (all permissions).",
              "Edit Play Games Services projects.",
              "Publish Play Games Services projects.",
              "Reply to reviews.",
              "Release to production, exclude devices, and use app signing by Google Play.",
              "Release to testing tracks.",
              "Manage testing tracks and edit tester lists.",
              "Manage store presence.",
              "Create, edit, and delete draft apps.",
              "Create and publish private apps to your organization.",
              "Choose whether apps are public, or only available to your organization.",
              "Manage orders and subscriptions.",
              "Manage policy related pages on all apps for the developer.",
              "View app information and download bulk reports (read-only).",
              "View app quality information for all apps for the developer.",
              "Manage the deep links setup for all apps for the developer."
            ],
            "enumDeprecated": [
              false,
              true,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false
            ]
          },
          "description": "Permissions for the user which apply across the developer account."
        },
        "email": {
          "type": "string",
          "description": "Immutable. The user's email address."
        },
        "expirationTime": {
          "description": "The time at which the user's access expires, if set. When setting this value, it must always be in the future.",
          "type": "string",
          "format": "google-datetime"
        },
        "name": {
          "type": "string",
          "description": "Required. Resource name for this user, following the pattern \"developers/{developer}/users/{email}\"."
        },
        "accessState": {
          "type": "string",
          "readOnly": true,
          "enumDescriptions": [
            "Unknown or unspecified access state.",
            "User is invited but has not yet accepted the invitation.",
            "Invitation has expired.",
            "User has accepted an invitation and has access to the Play Console.",
            "Account access has expired."
          ],
          "description": "Output only. The state of the user's access to the Play Console.",
          "enum": [
            "ACCESS_STATE_UNSPECIFIED",
            "INVITED",
            "INVITATION_EXPIRED",
            "ACCESS_GRANTED",
            "ACCESS_EXPIRED"
          ]
        },
        "grants": {
          "readOnly": true,
          "type": "array",
          "items": {
            "$ref": "Grant"
          },
          "description": "Output only. Per-app permissions for the user."
        }
      },
      "id": "User",
      "type": "object"
    },
    "ItemExpiryTimeDetails": {
      "id": "ItemExpiryTimeDetails",
      "type": "object",
      "description": "Expiry time details of a subscription item.",
      "properties": {
        "expiryTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The new expiry time for this subscription item."
        },
        "productId": {
          "type": "string",
          "description": "The product ID of the subscription item (for example, 'premium_plan')."
        }
      }
    },
    "UpdateSubscriptionRequest": {
      "id": "UpdateSubscriptionRequest",
      "type": "object",
      "description": "Request message for UpdateSubscription.",
      "properties": {
        "regionsVersion": {
          "$ref": "RegionsVersion",
          "description": "Required. The version of the available regions being used for the subscription."
        },
        "allowMissing": {
          "type": "boolean",
          "description": "Optional. If set to true, and the subscription with the given package_name and product_id doesn't exist, the subscription will be created. If a new subscription is created, update_mask is ignored."
        },
        "subscription": {
          "$ref": "Subscription",
          "description": "Required. The subscription to update."
        },
        "updateMask": {
          "description": "Required. The list of fields to be updated.",
          "type": "string",
          "format": "google-fieldmask"
        },
        "latencyTolerance": {
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        }
      }
    },
    "TrackCountryAvailability": {
      "description": "Resource for per-track country availability information.",
      "properties": {
        "restOfWorld": {
          "description": "Whether artifacts in this track are available to \"rest of the world\" countries.",
          "type": "boolean"
        },
        "countries": {
          "type": "array",
          "items": {
            "$ref": "TrackTargetedCountry"
          },
          "description": "A list of one or more countries where artifacts in this track are available. This list includes all countries that are targeted by the track, even if only specific carriers are targeted in that country."
        },
        "syncWithProduction": {
          "type": "boolean",
          "description": "Whether this track's availability is synced with the default production track. See https://support.google.com/googleplay/android-developer/answer/7550024 for more information on syncing country availability with production. Note that if this is true, the returned \"countries\" and \"rest_of_world\" fields will reflect the values for the default production track."
        }
      },
      "id": "TrackCountryAvailability",
      "type": "object"
    },
    "ConvertRegionPricesRequest": {
      "id": "ConvertRegionPricesRequest",
      "type": "object",
      "description": "Request message for ConvertRegionPrices.",
      "properties": {
        "price": {
          "description": "The intital price to convert other regions from. Tax exclusive.",
          "$ref": "Money"
        },
        "productTaxCategoryCode": {
          "description": "Optional. Product tax category code in context. Product tax category determines the transaction tax rates applied to the product that will be factored into the price calculation. If not set, tax rates for the default product tax category will be used. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/16408159) for more information.",
          "type": "string"
        }
      }
    },
    "SubscriptionTaxAndComplianceSettings": {
      "id": "SubscriptionTaxAndComplianceSettings",
      "type": "object",
      "description": "Details about taxation, Google Play policy, and legal compliance for subscription products.",
      "properties": {
        "taxRateInfoByRegionCode": {
          "type": "object",
          "description": "A mapping from region code to tax rate details. The keys are region codes as defined by Unicode's \"CLDR\".",
          "additionalProperties": {
            "$ref": "RegionalTaxRateInfo"
          }
        },
        "eeaWithdrawalRightType": {
          "description": "Digital content or service classification for products distributed to users in the European Economic Area (EEA). The withdrawal regime under EEA consumer laws depends on this classification. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/10463498) for more information.",
          "type": "string",
          "enumDescriptions": [
            "",
            "",
            ""
          ],
          "enum": [
            "WITHDRAWAL_RIGHT_TYPE_UNSPECIFIED",
            "WITHDRAWAL_RIGHT_DIGITAL_CONTENT",
            "WITHDRAWAL_RIGHT_SERVICE"
          ]
        },
        "isTokenizedDigitalAsset": {
          "type": "boolean",
          "description": "Whether this subscription is declared as a product representing a tokenized digital asset."
        },
        "regionalProductAgeRatingInfos": {
          "description": "Regional age rating information. Currently this field is only supported for region code `US`.",
          "type": "array",
          "items": {
            "$ref": "RegionalProductAgeRatingInfo"
          }
        },
        "productTaxCategoryCode": {
          "description": "Product tax category code to assign to the subscription. Product tax category determines the transaction tax rates applied to the subscription. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/16408159) for more information.",
          "type": "string"
        }
      }
    },
    "ProrationPeriodDetails": {
      "description": "Details of a proration period. A proration period can be a period calculated during a plan change to cover existing entitlements (For more information, see [Allow users to upgrade, downgrade, or change their subscription](https://developer.android.com/google/play/billing/subscriptions#allow-users-change), or a prorated period to align add-on renewal dates with the base (For more information, see [Rules applicable for items in the purchase](https://developer.android.com/google/play/billing/subscription-with-addons#rules-base-addons)).",
      "properties": {
        "originalOfferPhase": {
          "enum": [
            "OFFER_PHASE_UNSPECIFIED",
            "BASE",
            "INTRODUCTORY",
            "FREE_TRIAL"
          ],
          "type": "string",
          "enumDescriptions": [
            "Offer phase unspecified. This value is not used.",
            "The order funds a base price period.",
            "The order funds an introductory pricing period.",
            "The order funds a free trial period."
          ],
          "description": "Represent the original offer phase from the purchased the line item if the proration period contains any of them. For example, a proration period from CHARGE_FULL_PRICE plan change may merge the 1st offer phase of the subscription offer of the new product user purchased. In this case, the original offer phase will be set here."
        }
      },
      "id": "ProrationPeriodDetails",
      "type": "object"
    },
    "CancelSubscriptionPurchaseRequest": {
      "description": "Request for the purchases.subscriptionsv2.cancel API.",
      "properties": {
        "cancellationContext": {
          "$ref": "CancellationContext",
          "description": "Required. Additional details around the subscription revocation."
        }
      },
      "id": "CancelSubscriptionPurchaseRequest",
      "type": "object"
    },
    "OneTimeProductPurchaseOptionRegionalPricingAndAvailabilityConfig": {
      "id": "OneTimeProductPurchaseOptionRegionalPricingAndAvailabilityConfig",
      "type": "object",
      "description": "Regional pricing and availability configuration for a purchase option.",
      "properties": {
        "regionCode": {
          "description": "Required. Region code this configuration applies to, as defined by ISO 3166-2, e.g., \"US\".",
          "type": "string"
        },
        "price": {
          "description": "The price of the purchase option in the specified region. Must be set in the currency that is linked to the specified region.",
          "$ref": "Money"
        },
        "availability": {
          "enum": [
            "AVAILABILITY_UNSPECIFIED",
            "AVAILABLE",
            "NO_LONGER_AVAILABLE",
            "AVAILABLE_IF_RELEASED",
            "AVAILABLE_FOR_OFFERS_ONLY"
          ],
          "description": "The availability of the purchase option.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified availability. Must not be used.",
            "The purchase option is available to users.",
            "The purchase option is no longer available to users. This value can only be used if the availability was previously set as AVAILABLE.",
            "The purchase option is initially unavailable, but made available via a released pre-order offer.",
            "The purchase option is unavailable but offers linked to it (i.e. Play Points offer) are available."
          ]
        }
      }
    },
    "TargetingRuleScopeThisSubscription": {
      "id": "TargetingRuleScopeThisSubscription",
      "type": "object",
      "description": "Represents the targeting rule scope corresponding to the subscriptions in which this offer is defined.",
      "properties": {}
    },
    "UpdateSubscriptionOfferStateRequest": {
      "description": "Request message to update the state of a subscription offer.",
      "properties": {
        "deactivateSubscriptionOfferRequest": {
          "$ref": "DeactivateSubscriptionOfferRequest",
          "description": "Deactivates an offer. Once deactivated, the offer will become unavailable to new subscribers, but existing subscribers will maintain their subscription"
        },
        "activateSubscriptionOfferRequest": {
          "$ref": "ActivateSubscriptionOfferRequest",
          "description": "Activates an offer. Once activated, the offer will be available to new subscribers."
        }
      },
      "id": "UpdateSubscriptionOfferStateRequest",
      "type": "object"
    },
    "InstallmentPlan": {
      "description": "Information to a installment plan.",
      "properties": {
        "subsequentCommittedPaymentsCount": {
          "type": "integer",
          "format": "int32",
          "description": "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."
        },
        "initialCommittedPaymentsCount": {
          "description": "Total number of payments the user is initially committed for.",
          "type": "integer",
          "format": "int32"
        },
        "pendingCancellation": {
          "$ref": "PendingCancellation",
          "description": "If present, this installment plan is pending to be canceled. The cancellation will happen only after the user finished all committed payments."
        },
        "remainingCommittedPaymentsCount": {
          "description": "Total number of committed payments remaining to be paid for in this renewal cycle.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "InstallmentPlan",
      "type": "object"
    },
    "SystemApkOptions": {
      "description": "Options for system APKs.",
      "properties": {
        "rotated": {
          "description": "Whether to use the rotated key for signing the system APK.",
          "type": "boolean"
        },
        "uncompressedDexFiles": {
          "description": "Whether system APK was generated with uncompressed dex files.",
          "type": "boolean"
        },
        "uncompressedNativeLibraries": {
          "description": "Whether system APK was generated with uncompressed native libraries.",
          "type": "boolean"
        }
      },
      "id": "SystemApkOptions",
      "type": "object"
    },
    "Listing": {
      "id": "Listing",
      "type": "object",
      "description": "A localized store listing. The resource for ListingsService.",
      "properties": {
        "title": {
          "type": "string",
          "description": "Localized title of the app."
        },
        "shortDescription": {
          "type": "string",
          "description": "Short description of the app."
        },
        "language": {
          "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German).",
          "type": "string"
        },
        "fullDescription": {
          "type": "string",
          "description": "Full description of the app."
        },
        "video": {
          "description": "URL of a promotional YouTube video for the app.",
          "type": "string"
        }
      }
    },
    "SystemInitiatedCancellation": {
      "id": "SystemInitiatedCancellation",
      "type": "object",
      "description": "Information specific to cancellations initiated by Google system.",
      "properties": {}
    },
    "BatchDeleteOneTimeProductsRequest": {
      "id": "BatchDeleteOneTimeProductsRequest",
      "type": "object",
      "description": "Request message for BatchDeleteOneTimeProduct.",
      "properties": {
        "requests": {
          "description": "Required. A list of delete requests of up to 100 elements. All requests must delete different one-time products.",
          "type": "array",
          "items": {
            "$ref": "DeleteOneTimeProductRequest"
          }
        }
      }
    },
    "RegionalSubscriptionOfferPhaseConfig": {
      "description": "Configuration for a single phase of a subscription offer in a single region.",
      "properties": {
        "regionCode": {
          "description": "Required. Immutable. The region to which this config applies.",
          "type": "string"
        },
        "price": {
          "description": "The absolute price the user pays for this offer phase. The price must not be smaller than the minimum price allowed for this region.",
          "$ref": "Money"
        },
        "free": {
          "description": "Set to specify this offer is free to obtain.",
          "$ref": "RegionalSubscriptionOfferPhaseFreePriceOverride"
        },
        "absoluteDiscount": {
          "description": "The absolute amount of money subtracted from the base plan price prorated over the phase duration that the user pays for this offer phase. For example, if the base plan price for this region is $12 for a period of 1 year, then a $1 absolute discount for a phase of a duration of 3 months would correspond to a price of $2. The resulting price may not be smaller than the minimum price allowed for this region.",
          "$ref": "Money"
        },
        "relativeDiscount": {
          "description": "The fraction of the base plan price prorated over the phase duration that the user pays for this offer phase. For example, if the base plan price for this region is $12 for a period of 1 year, then a 50% discount for a phase of a duration of 3 months would correspond to a price of $1.50. The discount must be specified as a fraction strictly larger than 0 and strictly smaller than 1. The resulting price will be rounded to the nearest billable unit (e.g. cents for USD). The relative discount is considered invalid if the discounted price ends up being smaller than the minimum price allowed in this region.",
          "type": "number",
          "format": "double"
        }
      },
      "id": "RegionalSubscriptionOfferPhaseConfig",
      "type": "object"
    },
    "LanguageTargeting": {
      "description": "Targeting based on language.",
      "properties": {
        "value": {
          "description": "ISO-639: 2 or 3 letter language code.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "alternatives": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Alternative languages."
        }
      },
      "id": "LanguageTargeting",
      "type": "object"
    },
    "ActivatePurchaseOptionRequest": {
      "description": "Request message for UpdatePurchaseOptionState.",
      "properties": {
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the purchase option to activate."
        },
        "productId": {
          "type": "string",
          "description": "Required. The parent one-time product (ID) of the purchase option to activate."
        },
        "latencyTolerance": {
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "purchaseOptionId": {
          "type": "string",
          "description": "Required. The purchase option ID of the purchase option to activate."
        }
      },
      "id": "ActivatePurchaseOptionRequest",
      "type": "object"
    },
    "DeactivatePurchaseOptionRequest": {
      "description": "Request message for UpdatePurchaseOptionState.",
      "properties": {
        "packageName": {
          "description": "Required. The parent app (package name) of the purchase option to deactivate.",
          "type": "string"
        },
        "productId": {
          "description": "Required. The parent one-time product (ID) of the purchase option to deactivate.",
          "type": "string"
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        },
        "purchaseOptionId": {
          "description": "Required. The purchase option ID of the purchase option to deactivate.",
          "type": "string"
        }
      },
      "id": "DeactivatePurchaseOptionRequest",
      "type": "object"
    },
    "RefundEvent": {
      "description": "Details of when the order was fully refunded.",
      "properties": {
        "refundDetails": {
          "$ref": "RefundDetails",
          "description": "Details for the full refund."
        },
        "refundReason": {
          "description": "The reason the order was refunded.",
          "type": "string",
          "enumDescriptions": [
            "Refund reason unspecified. This value is not used.",
            "The order was refunded for a reason other than the listed reasons here.",
            "The order was charged back."
          ],
          "enum": [
            "REFUND_REASON_UNSPECIFIED",
            "OTHER",
            "CHARGEBACK"
          ]
        },
        "eventTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when the order was fully refunded."
        }
      },
      "id": "RefundEvent",
      "type": "object"
    },
    "ExternalTransactionAddress": {
      "description": "User's address for the external transaction.",
      "properties": {
        "regionCode": {
          "description": "Required. Two letter region code based on ISO-3166-1 Alpha-2 (UN region codes).",
          "type": "string"
        },
        "administrativeArea": {
          "type": "string",
          "description": "Optional. Top-level administrative subdivision of the country/region. Only required for transactions in India. Valid values are \"ANDAMAN AND NICOBAR ISLANDS\", \"ANDHRA PRADESH\", \"ARUNACHAL PRADESH\", \"ASSAM\", \"BIHAR\", \"CHANDIGARH\", \"CHHATTISGARH\", \"DADRA AND NAGAR HAVELI\", \"DADRA AND NAGAR HAVELI AND DAMAN AND DIU\", \"DAMAN AND DIU\", \"DELHI\", \"GOA\", \"GUJARAT\", \"HARYANA\", \"HIMACHAL PRADESH\", \"JAMMU AND KASHMIR\", \"JHARKHAND\", \"KARNATAKA\", \"KERALA\", \"LADAKH\", \"LAKSHADWEEP\", \"MADHYA PRADESH\", \"MAHARASHTRA\", \"MANIPUR\", \"MEGHALAYA\", \"MIZORAM\", \"NAGALAND\", \"ODISHA\", \"PUDUCHERRY\", \"PUNJAB\", \"RAJASTHAN\", \"SIKKIM\", \"TAMIL NADU\", \"TELANGANA\", \"TRIPURA\", \"UTTAR PRADESH\", \"UTTARAKHAND\", and \"WEST BENGAL\"."
        }
      },
      "id": "ExternalTransactionAddress",
      "type": "object"
    },
    "DeactivateSubscriptionOfferRequest": {
      "id": "DeactivateSubscriptionOfferRequest",
      "type": "object",
      "description": "Request message for DeactivateSubscriptionOffer.",
      "properties": {
        "productId": {
          "description": "Required. The parent subscription (ID) of the offer to deactivate.",
          "type": "string"
        },
        "offerId": {
          "description": "Required. The unique offer ID of the offer to deactivate.",
          "type": "string"
        },
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to deactivate."
        },
        "latencyTolerance": {
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "basePlanId": {
          "description": "Required. The parent base plan (ID) of the offer to deactivate.",
          "type": "string"
        }
      }
    },
    "BatchUpdatePurchaseOptionStatesRequest": {
      "description": "Request message for BatchUpdatePurchaseOptionStates.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdatePurchaseOptionStateRequest"
          },
          "description": "Required. The update request list of up to 100 elements. All requests must update different purchase options."
        }
      },
      "id": "BatchUpdatePurchaseOptionStatesRequest",
      "type": "object"
    },
    "ListOneTimeProductsResponse": {
      "description": "Response message for ListOneTimeProducts.",
      "properties": {
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "oneTimeProducts": {
          "description": "The one-time products from the specified app.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProduct"
          }
        }
      },
      "id": "ListOneTimeProductsResponse",
      "type": "object"
    },
    "OneTimeProductListing": {
      "id": "OneTimeProductListing",
      "type": "object",
      "description": "Regional store listing for a one-time product.",
      "properties": {
        "languageCode": {
          "type": "string",
          "description": "Required. The language of this listing, as defined by BCP-47, e.g., \"en-US\"."
        },
        "description": {
          "description": "Required. The description of this product in the language of this listing. The maximum length is 200 characters.",
          "type": "string"
        },
        "title": {
          "description": "Required. The title of this product in the language of this listing. The maximum length is 55 characters.",
          "type": "string"
        }
      }
    },
    "ArtifactSummary": {
      "description": "Summary of an artifact.",
      "properties": {
        "versionCode": {
          "type": "integer",
          "format": "int32",
          "description": "Artifact's version code"
        }
      },
      "id": "ArtifactSummary",
      "type": "object"
    },
    "OneTimeProductPurchaseOptionNewRegionsConfig": {
      "id": "OneTimeProductPurchaseOptionNewRegionsConfig",
      "type": "object",
      "description": "Pricing information for any new regions Play may launch in the future.",
      "properties": {
        "usdPrice": {
          "$ref": "Money",
          "description": "Required. Price in USD to use for any new regions Play may launch in."
        },
        "eurPrice": {
          "description": "Required. Price in EUR to use for any new regions Play may launch in.",
          "$ref": "Money"
        },
        "availability": {
          "enum": [
            "AVAILABILITY_UNSPECIFIED",
            "AVAILABLE",
            "NO_LONGER_AVAILABLE"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified availability. Must not be used.",
            "The config will be used for any new regions Play may launch in the future.",
            "The config is not available anymore and will not be used for any new regions Play may launch in the future. This value can only be used if the availability was previously set as AVAILABLE."
          ],
          "description": "Required. The regional availability for the new regions config. When set to AVAILABLE, the pricing information will be used for any new regions Play may launch in the future."
        }
      }
    },
    "ScreenDensityTargeting": {
      "id": "ScreenDensityTargeting",
      "type": "object",
      "description": "Targeting based on screen density.",
      "properties": {
        "value": {
          "type": "array",
          "items": {
            "$ref": "ScreenDensity"
          },
          "description": "Value of a screen density."
        },
        "alternatives": {
          "type": "array",
          "items": {
            "$ref": "ScreenDensity"
          },
          "description": "Targeting of other sibling directories that were in the Bundle. For main splits this is targeting of other main splits."
        }
      }
    },
    "SubscriptionDetails": {
      "description": "Details of a subscription purchase.",
      "properties": {
        "offerPhase": {
          "enum": [
            "OFFER_PHASE_UNSPECIFIED",
            "BASE",
            "INTRODUCTORY",
            "FREE_TRIAL"
          ],
          "type": "string",
          "enumDescriptions": [
            "Offer phase unspecified. This value is not used.",
            "The order funds a base price period.",
            "The order funds an introductory pricing period.",
            "The order funds a free trial period."
          ],
          "description": "The pricing phase for the billing period funded by this order. Deprecated. Use offer_phase_details instead."
        },
        "servicePeriodStartTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The start of the billing period funded by this order. This is a snapshot of the billing/service period start time at the moment the order was processed, and should be used only for accounting."
        },
        "offerPhaseDetails": {
          "description": "The pricing phase details for the entitlement period funded by this order.",
          "$ref": "OfferPhaseDetails"
        },
        "servicePeriodEndTime": {
          "description": "The end of the billing period funded by this order. This is a snapshot of the billing/service period end time at the moment the order was processed, and should be used only for accounting. To get the current end time of the subscription service period, use purchases.subscriptionsv2.get.",
          "type": "string",
          "format": "google-datetime"
        },
        "offerId": {
          "type": "string",
          "description": "The offer ID for the current subscription offer."
        },
        "basePlanId": {
          "description": "The base plan ID of the subscription.",
          "type": "string"
        }
      },
      "id": "SubscriptionDetails",
      "type": "object"
    },
    "BatchUpdatePurchaseOptionStatesResponse": {
      "description": "Response message for BatchUpdatePurchaseOptionStates.",
      "properties": {
        "oneTimeProducts": {
          "description": "The list of updated one-time products. This list will match the requests one to one, in the same order.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProduct"
          }
        }
      },
      "id": "BatchUpdatePurchaseOptionStatesResponse",
      "type": "object"
    },
    "ListSubscriptionOffersResponse": {
      "description": "Response message for ListSubscriptionOffers.",
      "properties": {
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        },
        "subscriptionOffers": {
          "description": "The subscription offers from the specified subscription.",
          "type": "array",
          "items": {
            "$ref": "SubscriptionOffer"
          }
        }
      },
      "id": "ListSubscriptionOffersResponse",
      "type": "object"
    },
    "SafetyLabelsUpdateResponse": {
      "id": "SafetyLabelsUpdateResponse",
      "type": "object",
      "description": "Response for SafetyLabelsUpdate rpc.",
      "properties": {}
    },
    "UpdateSubscriptionOfferRequest": {
      "description": "Request message for UpdateSubscriptionOffer.",
      "properties": {
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ]
        },
        "updateMask": {
          "description": "Required. The list of fields to be updated.",
          "type": "string",
          "format": "google-fieldmask"
        },
        "allowMissing": {
          "type": "boolean",
          "description": "Optional. If set to true, and the subscription offer with the given package_name, product_id, base_plan_id and offer_id doesn't exist, an offer will be created. If a new offer is created, update_mask is ignored."
        },
        "subscriptionOffer": {
          "description": "Required. The subscription offer to update.",
          "$ref": "SubscriptionOffer"
        },
        "regionsVersion": {
          "description": "Required. The version of the available regions being used for the subscription_offer.",
          "$ref": "RegionsVersion"
        }
      },
      "id": "UpdateSubscriptionOfferRequest",
      "type": "object"
    },
    "InternalAppSharingArtifact": {
      "id": "InternalAppSharingArtifact",
      "type": "object",
      "description": "An artifact resource which gets created when uploading an APK or Android App Bundle through internal app sharing.",
      "properties": {
        "sha256": {
          "type": "string",
          "description": "The sha256 hash of the artifact represented as a lowercase hexadecimal number, matching the output of the sha256sum command."
        },
        "downloadUrl": {
          "description": "The download URL generated for the uploaded artifact. Users that are authorized to download can follow the link to the Play Store app to install it.",
          "type": "string"
        },
        "certificateFingerprint": {
          "type": "string",
          "description": "The sha256 fingerprint of the certificate used to sign the generated artifact."
        }
      }
    },
    "DeobfuscationFilesUploadResponse": {
      "id": "DeobfuscationFilesUploadResponse",
      "type": "object",
      "description": "Responses for the upload.",
      "properties": {
        "deobfuscationFile": {
          "$ref": "DeobfuscationFile",
          "description": "The uploaded Deobfuscation File configuration."
        }
      }
    },
    "OfferPhaseDetails": {
      "id": "OfferPhaseDetails",
      "type": "object",
      "description": "Details of a pricing phase for the entitlement period funded by this order.",
      "properties": {
        "freeTrialDetails": {
          "description": "The order funds a free trial period.",
          "$ref": "FreeTrialDetails"
        },
        "baseDetails": {
          "description": "The order funds a base price period.",
          "$ref": "BaseDetails"
        },
        "introductoryPriceDetails": {
          "description": "The order funds an introductory pricing period.",
          "$ref": "IntroductoryPriceDetails"
        },
        "prorationPeriodDetails": {
          "description": "The order funds a proration period.",
          "$ref": "ProrationPeriodDetails"
        }
      }
    },
    "SystemApksListResponse": {
      "description": "Response to list previously created system APK variants.",
      "properties": {
        "variants": {
          "type": "array",
          "items": {
            "$ref": "Variant"
          },
          "description": "All system APK variants created."
        }
      },
      "id": "SystemApksListResponse",
      "type": "object"
    },
    "ApksListResponse": {
      "description": "Response listing all APKs.",
      "properties": {
        "kind": {
          "type": "string",
          "description": "The kind of this response (\"androidpublisher#apksListResponse\")."
        },
        "apks": {
          "type": "array",
          "items": {
            "$ref": "Apk"
          },
          "description": "All APKs."
        }
      },
      "id": "ApksListResponse",
      "type": "object"
    },
    "Targeting": {
      "description": "Targeting details for a recovery action such as regions, android sdk levels, app versions etc.",
      "properties": {
        "versionList": {
          "description": "Target version codes as a list.",
          "$ref": "AppVersionList"
        },
        "androidSdks": {
          "$ref": "AndroidSdks",
          "description": "Targeting is based on android api levels of devices."
        },
        "allUsers": {
          "description": "All users are targeted.",
          "$ref": "AllUsers"
        },
        "versionRange": {
          "$ref": "AppVersionRange",
          "description": "Target version codes as a range."
        },
        "regions": {
          "description": "Targeting is based on the user account region.",
          "$ref": "Regions"
        }
      },
      "id": "Targeting",
      "type": "object"
    },
    "ReviewReplyResult": {
      "id": "ReviewReplyResult",
      "type": "object",
      "description": "The result of replying/updating a reply to review.",
      "properties": {
        "replyText": {
          "description": "The reply text that was applied.",
          "type": "string"
        },
        "lastEdited": {
          "$ref": "Timestamp",
          "description": "The time at which the reply took effect."
        }
      }
    },
    "AutoRenewingPlan": {
      "description": "Information related to an auto renewing plan.",
      "properties": {
        "priceChangeDetails": {
          "$ref": "SubscriptionItemPriceChangeDetails",
          "description": "The information of the last price change for the item since subscription signup."
        },
        "priceStepUpConsentDetails": {
          "description": "The information of the latest price step-up consent.",
          "$ref": "PriceStepUpConsentDetails"
        },
        "installmentDetails": {
          "$ref": "InstallmentPlan",
          "description": "The installment plan commitment and state related info for the auto renewing plan."
        },
        "autoRenewEnabled": {
          "type": "boolean",
          "description": "If the subscription is currently set to auto-renew, e.g. the user has not canceled the subscription"
        },
        "recurringPrice": {
          "$ref": "Money",
          "description": "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 orders.get API instead if transaction details are needed."
        }
      },
      "id": "AutoRenewingPlan",
      "type": "object"
    },
    "DeployAppRecoveryRequest": {
      "id": "DeployAppRecoveryRequest",
      "type": "object",
      "description": "Request message for DeployAppRecovery.",
      "properties": {}
    },
    "BatchGetOneTimeProductOffersRequest": {
      "description": "Request message for the BatchGetOneTimeProductOffers endpoint.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "GetOneTimeProductOfferRequest"
          },
          "description": "Required. A list of get requests of up to 100 elements. All requests must retrieve different offers."
        }
      },
      "id": "BatchGetOneTimeProductOffersRequest",
      "type": "object"
    },
    "BaseDetails": {
      "id": "BaseDetails",
      "type": "object",
      "description": "Details of a base price pricing phase.",
      "properties": {}
    },
    "OneTimePurchaseDetails": {
      "description": "Details of a one-time purchase.",
      "properties": {
        "offerId": {
          "description": "The offer ID of the one-time purchase offer.",
          "type": "string"
        },
        "preorderDetails": {
          "description": "The details of a pre-order purchase. Only set if it is a pre-order purchase. Note that this field will be set even after pre-order is fulfilled.",
          "$ref": "PreorderDetails"
        },
        "purchaseOptionId": {
          "description": "ID of the purchase option. This field is set for both purchase options and variant offers. For purchase options, this ID identifies the purchase option itself. For variant offers, this ID refers to the associated purchase option, and in conjunction with offer_id it identifies the variant offer.",
          "type": "string"
        },
        "quantity": {
          "type": "integer",
          "format": "int32",
          "description": "The number of items purchased (for multi-quantity item purchases)."
        },
        "rentalDetails": {
          "$ref": "RentalDetails",
          "description": "The details of a rent purchase. Only set if it is a rent purchase."
        }
      },
      "id": "OneTimePurchaseDetails",
      "type": "object"
    },
    "ProductPurchasesAcknowledgeRequest": {
      "id": "ProductPurchasesAcknowledgeRequest",
      "type": "object",
      "description": "Request for the product.purchases.acknowledge API.",
      "properties": {
        "developerPayload": {
          "type": "string",
          "description": "Payload to attach to the purchase."
        }
      }
    },
    "Money": {
      "description": "Represents an amount of money with its currency type.",
      "properties": {
        "units": {
          "type": "string",
          "format": "int64",
          "description": "The whole units of the amount. For example if `currencyCode` is `\"USD\"`, then 1 unit is one US dollar."
        },
        "nanos": {
          "type": "integer",
          "format": "int32",
          "description": "Number of nano (10^-9) units of the amount. The value must be between -999,999,999 and +999,999,999 inclusive. If `units` is positive, `nanos` must be positive or zero. If `units` is zero, `nanos` can be positive, zero, or negative. If `units` is negative, `nanos` must be negative or zero. For example $-1.75 is represented as `units`=-1 and `nanos`=-750,000,000."
        },
        "currencyCode": {
          "type": "string",
          "description": "The three-letter currency code defined in ISO 4217."
        }
      },
      "id": "Money",
      "type": "object"
    },
    "Comment": {
      "id": "Comment",
      "type": "object",
      "description": "An entry of conversation between user and developer.",
      "properties": {
        "userComment": {
          "$ref": "UserComment",
          "description": "A comment from a user."
        },
        "developerComment": {
          "description": "A comment from a developer.",
          "$ref": "DeveloperComment"
        }
      }
    },
    "ExternallyHostedApk": {
      "id": "ExternallyHostedApk",
      "type": "object",
      "description": "Defines an APK available for this application that is hosted externally and not uploaded to Google Play. This function is only available to organizations using Managed Play whose application is configured to restrict distribution to the organizations.",
      "properties": {
        "iconBase64": {
          "description": "The icon image from the APK, as a base64 encoded byte array.",
          "type": "string"
        },
        "fileSha256Base64": {
          "description": "The sha256 checksum of this APK, represented as a base64 encoded byte array.",
          "type": "string"
        },
        "minimumSdk": {
          "description": "The minimum SDK targeted by this APK.",
          "type": "integer",
          "format": "int32"
        },
        "versionCode": {
          "description": "The version code of this APK.",
          "type": "integer",
          "format": "int32"
        },
        "usesPermissions": {
          "description": "The permissions requested by this APK.",
          "type": "array",
          "items": {
            "$ref": "UsesPermission"
          }
        },
        "externallyHostedUrl": {
          "type": "string",
          "description": "The URL at which the APK is hosted. This must be an https URL."
        },
        "applicationLabel": {
          "type": "string",
          "description": "The application label."
        },
        "usesFeatures": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "The features required by this APK (optional)."
        },
        "fileSha1Base64": {
          "type": "string",
          "description": "The sha1 checksum of this APK, represented as a base64 encoded byte array."
        },
        "nativeCodes": {
          "description": "The native code environments supported by this APK (optional).",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "packageName": {
          "type": "string",
          "description": "The package name."
        },
        "versionName": {
          "description": "The version name of this APK.",
          "type": "string"
        },
        "fileSize": {
          "type": "string",
          "format": "int64",
          "description": "The file size in bytes of this APK."
        },
        "maximumSdk": {
          "type": "integer",
          "format": "int32",
          "description": "The maximum SDK supported by this APK (optional)."
        },
        "certificateBase64s": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "A certificate (or array of certificates if a certificate-chain is used) used to sign this APK, represented as a base64 encoded byte array."
        }
      }
    },
    "BatchUpdateOneTimeProductOfferStatesRequest": {
      "description": "Request message for BatchUpdateOneTimeProductOfferStates.",
      "properties": {
        "requests": {
          "description": "Required. The update request list of up to 100 elements. All requests must update different offers.",
          "type": "array",
          "items": {
            "$ref": "UpdateOneTimeProductOfferStateRequest"
          }
        }
      },
      "id": "BatchUpdateOneTimeProductOfferStatesRequest",
      "type": "object"
    },
    "Timestamp": {
      "description": "A Timestamp represents a point in time independent of any time zone or local calendar, encoded as a count of seconds and fractions of seconds at nanosecond resolution. The count is relative to an epoch at UTC midnight on January 1, 1970.",
      "properties": {
        "seconds": {
          "description": "Represents seconds of UTC time since Unix epoch.",
          "type": "string",
          "format": "int64"
        },
        "nanos": {
          "description": "Non-negative fractions of a second at nanosecond resolution. Must be from 0 to 999,999,999 inclusive.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "Timestamp",
      "type": "object"
    },
    "SubscriptionPurchaseLineItem": {
      "id": "SubscriptionPurchaseLineItem",
      "type": "object",
      "description": "Item-level info for a subscription purchase.",
      "properties": {
        "autoRenewingPlan": {
          "$ref": "AutoRenewingPlan",
          "description": "The item is auto renewing."
        },
        "deferredItemRemoval": {
          "description": "Information for deferred item removal.",
          "$ref": "DeferredItemRemoval"
        },
        "itemReplacement": {
          "description": "Details of the item being replaced. This field is only populated if this item replaced another item in a previous subscription and is only available for 60 days after the purchase time.",
          "$ref": "ItemReplacement"
        },
        "expiryTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Time at which the subscription expired or will expire unless the access is extended (ex. renews)."
        },
        "offerDetails": {
          "description": "The offer details for this item.",
          "$ref": "OfferDetails"
        },
        "deferredItemReplacement": {
          "$ref": "DeferredItemReplacement",
          "description": "Information for deferred item replacement."
        },
        "latestSuccessfulOrderId": {
          "type": "string",
          "description": "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)."
        },
        "productId": {
          "type": "string",
          "description": "The purchased product ID (for example, 'monthly001')."
        },
        "offerPhase": {
          "$ref": "OfferPhase",
          "description": "Current offer phase details for this item."
        },
        "signupPromotion": {
          "$ref": "SignupPromotion",
          "description": "Promotion details about this item. Only set if a promotion was applied during signup."
        },
        "prepaidPlan": {
          "description": "The item is prepaid.",
          "$ref": "PrepaidPlan"
        }
      }
    },
    "SignupPromotion": {
      "id": "SignupPromotion",
      "type": "object",
      "description": "The promotion applied on this item when purchased.",
      "properties": {
        "vanityCode": {
          "$ref": "VanityCode",
          "description": "A vanity code was applied."
        },
        "oneTimeCode": {
          "$ref": "OneTimeCode",
          "description": "A one-time code was applied."
        }
      }
    },
    "InstallmentsBasePlanType": {
      "id": "InstallmentsBasePlanType",
      "type": "object",
      "description": "Represents an installments base plan where a user commits to a specified number of payments.",
      "properties": {
        "committedPaymentsCount": {
          "description": "Required. Immutable. The number of payments the user is committed to. It is immutable after the base plan is created.",
          "type": "integer",
          "format": "int32"
        },
        "renewalType": {
          "description": "Required. Immutable. Installments base plan renewal type. Determines the behavior at the end of the initial commitment. The renewal type is immutable after the base plan is created.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified state.",
            "Renews periodically for the billing period duration without commitment.",
            "Renews with the commitment of the same duration as the initial one."
          ],
          "enum": [
            "RENEWAL_TYPE_UNSPECIFIED",
            "RENEWAL_TYPE_RENEWS_WITHOUT_COMMITMENT",
            "RENEWAL_TYPE_RENEWS_WITH_COMMITMENT"
          ]
        },
        "resubscribeState": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified state.",
            "Resubscribe is active.",
            "Resubscribe is inactive."
          ],
          "description": "Whether users should be able to resubscribe to this base plan in Google Play surfaces. Defaults to RESUBSCRIBE_STATE_ACTIVE if not specified.",
          "enum": [
            "RESUBSCRIBE_STATE_UNSPECIFIED",
            "RESUBSCRIBE_STATE_ACTIVE",
            "RESUBSCRIBE_STATE_INACTIVE"
          ]
        },
        "prorationMode": {
          "enum": [
            "SUBSCRIPTION_PRORATION_MODE_UNSPECIFIED",
            "SUBSCRIPTION_PRORATION_MODE_CHARGE_ON_NEXT_BILLING_DATE",
            "SUBSCRIPTION_PRORATION_MODE_CHARGE_FULL_PRICE_IMMEDIATELY"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified mode.",
            "Users will be charged for their new base plan at the end of their current billing period.",
            "Users will be charged for their new base plan immediately and in full. Any remaining period of their existing subscription will be used to extend the duration of the new billing plan."
          ],
          "description": "The proration mode for the base plan determines what happens when a user switches to this plan from another base plan. If unspecified, defaults to CHARGE_ON_NEXT_BILLING_DATE."
        },
        "billingPeriodDuration": {
          "description": "Required. Immutable. Subscription period, specified in ISO 8601 format. For a list of acceptable billing periods, refer to the help center. The duration is immutable after the base plan is created.",
          "type": "string"
        },
        "gracePeriodDuration": {
          "type": "string",
          "description": "Grace period of the subscription, specified in ISO 8601 format. Acceptable values must be in days and between P0D and the lesser of 30D and base plan billing period. If not specified, a default value will be used based on the billing period. The sum of gracePeriodDuration and accountHoldDuration must be between P30D and P60D days, inclusive."
        },
        "accountHoldDuration": {
          "description": "Optional. Custom account hold period of the subscription, specified in ISO 8601 format. Acceptable values must be in days and between P0D and P60D. An empty field represents a recommended account hold, calculated as 60 days minus grace period. The sum of gracePeriodDuration and accountHoldDuration must be between P30D and P60D days, inclusive.",
          "type": "string"
        }
      }
    },
    "ArchiveSubscriptionRequest": {
      "properties": {},
      "id": "ArchiveSubscriptionRequest",
      "type": "object",
      "description": "Deprecated: subscription archiving is not supported.",
      "deprecated": true
    },
    "VoidedPurchasesListResponse": {
      "description": "Response for the voidedpurchases.list API.",
      "properties": {
        "tokenPagination": {
          "$ref": "TokenPagination",
          "description": "Pagination information for token pagination."
        },
        "voidedPurchases": {
          "type": "array",
          "items": {
            "$ref": "VoidedPurchase"
          }
        },
        "pageInfo": {
          "description": "General pagination information.",
          "$ref": "PageInfo"
        }
      },
      "id": "VoidedPurchasesListResponse",
      "type": "object"
    },
    "LineItem": {
      "id": "LineItem",
      "type": "object",
      "description": "Details of a line item.",
      "properties": {
        "paidAppDetails": {
          "$ref": "PaidAppDetails",
          "description": "Details of a paid app purchase."
        },
        "productTitle": {
          "description": "Developer-specified name of the product. Displayed in buyer's locale. Example: coins, monthly subscription, etc.",
          "type": "string"
        },
        "productId": {
          "description": "The purchased product ID or in-app SKU (for example, 'monthly001' or 'com.some.thing.inapp1').",
          "type": "string"
        },
        "listingPrice": {
          "$ref": "Money",
          "description": "Item's listed price on Play Store, this may or may not include tax. Excludes Google-funded discounts only."
        },
        "oneTimePurchaseDetails": {
          "description": "Details of a one-time purchase.",
          "$ref": "OneTimePurchaseDetails"
        },
        "subscriptionDetails": {
          "description": "Details of a subscription purchase.",
          "$ref": "SubscriptionDetails"
        },
        "total": {
          "$ref": "Money",
          "description": "The total amount paid by the user for this line item, taking into account discounts and tax."
        },
        "tax": {
          "description": "The tax paid for this line item.",
          "$ref": "Money"
        }
      }
    },
    "PrepaidPlan": {
      "id": "PrepaidPlan",
      "type": "object",
      "description": "Information related to a prepaid plan.",
      "properties": {
        "allowExtendAfterTime": {
          "description": "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.",
          "type": "string",
          "format": "google-datetime"
        }
      }
    },
    "ProductLineItem": {
      "id": "ProductLineItem",
      "type": "object",
      "description": "Contains item-level info for a ProductPurchaseV2.",
      "properties": {
        "productId": {
          "description": "The purchased product ID (for example, 'monthly001').",
          "type": "string"
        },
        "productOfferDetails": {
          "description": "The offer details for this item.",
          "$ref": "ProductOfferDetails"
        }
      }
    },
    "CancelOneTimeProductOfferRequest": {
      "id": "CancelOneTimeProductOfferRequest",
      "type": "object",
      "description": "Request message for CancelOneTimeProductOffer.",
      "properties": {
        "productId": {
          "type": "string",
          "description": "Required. The parent one-time product (ID) of the offer to cancel."
        },
        "purchaseOptionId": {
          "description": "Required. The parent purchase option (ID) of the offer to cancel.",
          "type": "string"
        },
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to cancel."
        },
        "latencyTolerance": {
          "description": "Optional. The latency tolerance for the propagation of this update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "offerId": {
          "type": "string",
          "description": "Required. The offer ID of the offer to cancel."
        }
      }
    },
    "ApksAddExternallyHostedRequest": {
      "id": "ApksAddExternallyHostedRequest",
      "type": "object",
      "description": "Request to create a new externally hosted APK.",
      "properties": {
        "externallyHostedApk": {
          "$ref": "ExternallyHostedApk",
          "description": "The definition of the externally-hosted APK and where it is located."
        }
      }
    },
    "PartialRefundEvent": {
      "id": "PartialRefundEvent",
      "type": "object",
      "description": "Details of the partial refund events for this order.",
      "properties": {
        "state": {
          "enum": [
            "STATE_UNSPECIFIED",
            "PENDING",
            "PROCESSED_SUCCESSFULLY"
          ],
          "description": "The state of the partial refund.",
          "type": "string",
          "enumDescriptions": [
            "State unspecified. This value is not used.",
            "The partial refund has been created, but not yet processed.",
            "The partial refund was processed successfully."
          ]
        },
        "createTime": {
          "description": "The time when the partial refund was created.",
          "type": "string",
          "format": "google-datetime"
        },
        "processTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when the partial refund was processed."
        },
        "refundDetails": {
          "description": "Details for the partial refund.",
          "$ref": "RefundDetails"
        }
      }
    },
    "ApkTargeting": {
      "description": "Represents a set of apk-level targetings.",
      "properties": {
        "sdkVersionTargeting": {
          "description": "The sdk version that the apk targets",
          "$ref": "SdkVersionTargeting"
        },
        "textureCompressionFormatTargeting": {
          "$ref": "TextureCompressionFormatTargeting",
          "description": "Texture-compression-format-level targeting"
        },
        "languageTargeting": {
          "description": "The language that the apk targets",
          "$ref": "LanguageTargeting"
        },
        "abiTargeting": {
          "$ref": "AbiTargeting",
          "description": "The abi that the apk targets"
        },
        "screenDensityTargeting": {
          "description": "The screen density that this apk supports.",
          "$ref": "ScreenDensityTargeting"
        },
        "multiAbiTargeting": {
          "description": "Multi-api-level targeting.",
          "$ref": "MultiAbiTargeting"
        }
      },
      "id": "ApkTargeting",
      "type": "object"
    },
    "BasePlan": {
      "id": "BasePlan",
      "type": "object",
      "description": "A single base plan for a subscription.",
      "properties": {
        "state": {
          "enum": [
            "STATE_UNSPECIFIED",
            "DRAFT",
            "ACTIVE",
            "INACTIVE"
          ],
          "description": "Output only. The state of the base plan, i.e. whether it's active. Draft and inactive base plans can be activated or deleted. Active base plans can be made inactive. Inactive base plans can be canceled. This field cannot be changed by updating the resource. Use the dedicated endpoints instead.",
          "readOnly": true,
          "enumDescriptions": [
            "Unspecified state.",
            "The base plan is currently in a draft state, and hasn't been activated. It can be safely deleted at this point.",
            "The base plan is active and available for new subscribers.",
            "The base plan is inactive and only available for existing subscribers."
          ],
          "type": "string"
        },
        "basePlanId": {
          "type": "string",
          "description": "Required. Immutable. The unique identifier of this base plan. Must be unique within the subscription, and conform with RFC-1034. That is, this ID can only contain lower-case letters (a-z), numbers (0-9), and hyphens (-), and be at most 63 characters."
        },
        "prepaidBasePlanType": {
          "description": "Set when the base plan does not automatically renew at the end of the billing period.",
          "$ref": "PrepaidBasePlanType"
        },
        "installmentsBasePlanType": {
          "$ref": "InstallmentsBasePlanType",
          "description": "Set for installments base plans where a user is committed to a specified number of payments."
        },
        "autoRenewingBasePlanType": {
          "description": "Set when the base plan automatically renews at a regular interval.",
          "$ref": "AutoRenewingBasePlanType"
        },
        "regionalConfigs": {
          "type": "array",
          "items": {
            "$ref": "RegionalBasePlanConfig"
          },
          "description": "Region-specific information for this base plan."
        },
        "offerTags": {
          "type": "array",
          "items": {
            "$ref": "OfferTag"
          },
          "description": "List of up to 20 custom tags specified for this base plan, and returned to the app through the billing library. Subscription offers for this base plan will also receive these offer tags in the billing library."
        },
        "otherRegionsConfig": {
          "$ref": "OtherRegionsBasePlanConfig",
          "description": "Pricing information for any new locations Play may launch in the future. If omitted, the BasePlan will not be automatically available any new locations Play may launch in the future."
        }
      }
    },
    "DeviceTierSet": {
      "id": "DeviceTierSet",
      "type": "object",
      "description": "A set of device tiers. A tier set determines what variation of app content gets served to a specific device, for device-targeted content. You should assign a priority level to each tier, which determines the ordering by which they are evaluated by Play. See the documentation of DeviceTier.level for more details.",
      "properties": {
        "deviceTiers": {
          "type": "array",
          "items": {
            "$ref": "DeviceTier"
          },
          "description": "Device tiers belonging to the set."
        }
      }
    },
    "TextureCompressionFormat": {
      "id": "TextureCompressionFormat",
      "type": "object",
      "description": "Represents texture compression format.",
      "properties": {
        "alias": {
          "enum": [
            "UNSPECIFIED_TEXTURE_COMPRESSION_FORMAT",
            "ETC1_RGB8",
            "PALETTED",
            "THREE_DC",
            "ATC",
            "LATC",
            "DXT1",
            "S3TC",
            "PVRTC",
            "ASTC",
            "ETC2"
          ],
          "description": "Alias for texture compression format.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified format.",
            "ETC1_RGB8 format.",
            "PALETTED format.",
            "THREE_DC format.",
            "ATC format.",
            "LATC format.",
            "DXT1 format.",
            "S3TC format.",
            "PVRTC format.",
            "ASTC format.",
            "ETC2 format."
          ]
        }
      }
    },
    "BatchMigrateBasePlanPricesResponse": {
      "description": "Response message for BatchMigrateBasePlanPrices.",
      "properties": {
        "responses": {
          "description": "Contains one response per requested price migration, in the same order as the request.",
          "type": "array",
          "items": {
            "$ref": "MigrateBasePlanPricesResponse"
          }
        }
      },
      "id": "BatchMigrateBasePlanPricesResponse",
      "type": "object"
    },
    "Subscription": {
      "description": "A single subscription for an app.",
      "properties": {
        "basePlans": {
          "description": "The set of base plans for this subscription. Represents the prices and duration of the subscription if no other offers apply.",
          "type": "array",
          "items": {
            "$ref": "BasePlan"
          }
        },
        "packageName": {
          "type": "string",
          "description": "Immutable. Package name of the parent app."
        },
        "taxAndComplianceSettings": {
          "$ref": "SubscriptionTaxAndComplianceSettings",
          "description": "Details about taxes and legal compliance."
        },
        "listings": {
          "type": "array",
          "items": {
            "$ref": "SubscriptionListing"
          },
          "description": "Required. List of localized listings for this subscription. Must contain at least an entry for the default language of the parent app."
        },
        "archived": {
          "description": "Output only. Deprecated: subscription archiving is not supported.",
          "readOnly": true,
          "type": "boolean",
          "deprecated": true
        },
        "restrictedPaymentCountries": {
          "$ref": "RestrictedPaymentCountries",
          "description": "Optional. Countries where the purchase of this subscription is restricted to payment methods registered in the same country. If empty, no payment location restrictions are imposed."
        },
        "productId": {
          "type": "string",
          "description": "Immutable. Unique product ID of the product. Unique within the parent app. Product IDs must be composed of lower-case letters (a-z), numbers (0-9), underscores (_) and dots (.). It must start with a lower-case letter or number, and be between 1 and 40 (inclusive) characters in length."
        }
      },
      "id": "Subscription",
      "type": "object"
    },
    "ApksAddExternallyHostedResponse": {
      "description": "Response for creating a new externally hosted APK.",
      "properties": {
        "externallyHostedApk": {
          "$ref": "ExternallyHostedApk",
          "description": "The definition of the externally-hosted APK and where it is located."
        }
      },
      "id": "ApksAddExternallyHostedResponse",
      "type": "object"
    },
    "CancelAppRecoveryRequest": {
      "id": "CancelAppRecoveryRequest",
      "type": "object",
      "description": "Request message for CancelAppRecovery.",
      "properties": {}
    },
    "AssetSliceSet": {
      "id": "AssetSliceSet",
      "type": "object",
      "description": "Set of asset slices belonging to a single asset module.",
      "properties": {
        "assetModuleMetadata": {
          "description": "Module level metadata.",
          "$ref": "AssetModuleMetadata"
        },
        "apkDescription": {
          "description": "Asset slices.",
          "type": "array",
          "items": {
            "$ref": "ApkDescription"
          }
        }
      }
    },
    "GetOneTimeProductOfferRequest": {
      "id": "GetOneTimeProductOfferRequest",
      "type": "object",
      "description": "Request message for GetOneTimeProductOffers.",
      "properties": {
        "purchaseOptionId": {
          "description": "Required. The parent purchase option (ID) of the offer to get.",
          "type": "string"
        },
        "offerId": {
          "description": "Required. The unique offer ID of the offer to get.",
          "type": "string"
        },
        "packageName": {
          "description": "Required. The parent app (package name) of the offer to get.",
          "type": "string"
        },
        "productId": {
          "description": "Required. The parent one-time product (ID) of the offer to get.",
          "type": "string"
        }
      }
    },
    "DeactivateOneTimeProductOfferRequest": {
      "description": "Request message for DeactivateOneTimeProductOffer.",
      "properties": {
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to deactivate."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "description": "Optional. The latency tolerance for the propagation of this update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ]
        },
        "offerId": {
          "type": "string",
          "description": "Required. The offer ID of the offer to deactivate."
        },
        "productId": {
          "type": "string",
          "description": "Required. The parent one-time product (ID) of the offer to deactivate."
        },
        "purchaseOptionId": {
          "description": "Required. The parent purchase option (ID) of the offer to deactivate.",
          "type": "string"
        }
      },
      "id": "DeactivateOneTimeProductOfferRequest",
      "type": "object"
    },
    "PaidAppDetails": {
      "description": "Details of a paid app purchase.",
      "properties": {},
      "id": "PaidAppDetails",
      "type": "object"
    },
    "GeneratedApksPerSigningKey": {
      "description": "Download metadata for split, standalone and universal APKs, as well as asset pack slices, signed with a given key.",
      "properties": {
        "generatedStandaloneApks": {
          "description": "List of generated standalone APKs, signed with a key corresponding to certificate_sha256_hash.",
          "type": "array",
          "items": {
            "$ref": "GeneratedStandaloneApk"
          }
        },
        "generatedUniversalApk": {
          "$ref": "GeneratedUniversalApk",
          "description": "Generated universal APK, signed with a key corresponding to certificate_sha256_hash. This field is not set if no universal APK was generated for this signing key."
        },
        "certificateSha256Hash": {
          "description": "SHA256 hash of the APK signing public key certificate.",
          "type": "string"
        },
        "generatedSplitApks": {
          "type": "array",
          "items": {
            "$ref": "GeneratedSplitApk"
          },
          "description": "List of generated split APKs, signed with a key corresponding to certificate_sha256_hash."
        },
        "generatedRecoveryModules": {
          "type": "array",
          "items": {
            "$ref": "GeneratedRecoveryApk"
          },
          "description": "Generated recovery apks for recovery actions signed with a key corresponding to certificate_sha256_hash. This includes all generated recovery APKs, also those in draft or cancelled state. This field is not set if no recovery actions were created for this signing key."
        },
        "targetingInfo": {
          "$ref": "TargetingInfo",
          "description": "Contains targeting information about the generated apks."
        },
        "generatedAssetPackSlices": {
          "type": "array",
          "items": {
            "$ref": "GeneratedAssetPackSlice"
          },
          "description": "List of asset pack slices which will be served for this app bundle, signed with a key corresponding to certificate_sha256_hash."
        }
      },
      "id": "GeneratedApksPerSigningKey",
      "type": "object"
    },
    "ListUsersResponse": {
      "description": "A response containing one or more users with access to an account.",
      "properties": {
        "users": {
          "type": "array",
          "items": {
            "$ref": "User"
          },
          "description": "The resulting users."
        },
        "nextPageToken": {
          "description": "A token to pass to subsequent calls in order to retrieve subsequent results. This will not be set if there are no more results to return.",
          "type": "string"
        }
      },
      "id": "ListUsersResponse",
      "type": "object"
    },
    "OtherRegionsSubscriptionOfferPhaseConfig": {
      "id": "OtherRegionsSubscriptionOfferPhaseConfig",
      "type": "object",
      "description": "Configuration for any new locations Play may launch in for a single offer phase.",
      "properties": {
        "relativeDiscount": {
          "description": "The fraction of the base plan price prorated over the phase duration that the user pays for this offer phase. For example, if the base plan price for this region is $12 for a period of 1 year, then a 50% discount for a phase of a duration of 3 months would correspond to a price of $1.50. The discount must be specified as a fraction strictly larger than 0 and strictly smaller than 1. The resulting price will be rounded to the nearest billable unit (e.g. cents for USD). The relative discount is considered invalid if the discounted price ends up being smaller than the minimum price allowed in any new locations Play may launch in.",
          "type": "number",
          "format": "double"
        },
        "otherRegionsPrices": {
          "$ref": "OtherRegionsSubscriptionOfferPhasePrices",
          "description": "The absolute price the user pays for this offer phase. The price must not be smaller than the minimum price allowed for any new locations Play may launch in."
        },
        "free": {
          "$ref": "OtherRegionsSubscriptionOfferPhaseFreePriceOverride",
          "description": "Set to specify this offer is free to obtain."
        },
        "absoluteDiscounts": {
          "$ref": "OtherRegionsSubscriptionOfferPhasePrices",
          "description": "The absolute amount of money subtracted from the base plan price prorated over the phase duration that the user pays for this offer phase. For example, if the base plan price for this region is $12 for a period of 1 year, then a $1 absolute discount for a phase of a duration of 3 months would correspond to a price of $2. The resulting price may not be smaller than the minimum price allowed for any new locations Play may launch in."
        }
      }
    },
    "BatchUpdateOneTimeProductsResponse": {
      "id": "BatchUpdateOneTimeProductsResponse",
      "type": "object",
      "description": "Response message for BatchUpdateOneTimeProduct.",
      "properties": {
        "oneTimeProducts": {
          "description": "The list of updated one-time products list, in the same order as the request.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProduct"
          }
        }
      }
    },
    "OfferPhase": {
      "id": "OfferPhase",
      "type": "object",
      "description": "Offer phase details.",
      "properties": {
        "freeTrial": {
          "$ref": "FreeTrialOfferPhase",
          "description": "Set when the offer phase is a free trial."
        },
        "basePrice": {
          "$ref": "BasePriceOfferPhase",
          "description": "Set when the offer phase is a base plan pricing phase."
        },
        "prorationPeriod": {
          "description": "Set when the offer phase is a proration period.",
          "$ref": "ProrationPeriodOfferPhase"
        },
        "introductoryPrice": {
          "$ref": "IntroductoryPriceOfferPhase",
          "description": "Set when the offer phase is an introductory price offer phase."
        }
      }
    },
    "GeneratedRecoveryApk": {
      "description": "Download metadata for an app recovery module.",
      "properties": {
        "recoveryId": {
          "type": "string",
          "format": "int64",
          "description": "ID of the recovery action."
        },
        "moduleName": {
          "description": "Name of the module which recovery apk belongs to.",
          "type": "string"
        },
        "downloadId": {
          "type": "string",
          "description": "Download ID, which uniquely identifies the APK to download. Should be supplied to `generatedapks.download` method."
        },
        "recoveryStatus": {
          "type": "string",
          "enumDescriptions": [
            "RecoveryStatus is unspecified.",
            "The app recovery action has not been canceled since it has been created.",
            "The recovery action has been canceled. The action cannot be resumed.",
            "The recovery action is in the draft state and has not yet been deployed to users.",
            "The recovery action is generating recovery apks.",
            "The app recovery action generation has failed."
          ],
          "description": "The status of the recovery action corresponding to the recovery apk.",
          "enum": [
            "RECOVERY_STATUS_UNSPECIFIED",
            "RECOVERY_STATUS_ACTIVE",
            "RECOVERY_STATUS_CANCELED",
            "RECOVERY_STATUS_DRAFT",
            "RECOVERY_STATUS_GENERATION_IN_PROGRESS",
            "RECOVERY_STATUS_GENERATION_FAILED"
          ]
        }
      },
      "id": "GeneratedRecoveryApk",
      "type": "object"
    },
    "AppRecoveryAction": {
      "id": "AppRecoveryAction",
      "type": "object",
      "description": "Information about an app recovery action.",
      "properties": {
        "appRecoveryId": {
          "description": "ID corresponding to the app recovery action.",
          "type": "string",
          "format": "int64"
        },
        "cancelTime": {
          "description": "Timestamp of when the app recovery action is canceled by the developer. Only set if the recovery action has been canceled.",
          "type": "string",
          "format": "google-datetime"
        },
        "targeting": {
          "description": "Specifies targeting criteria for the recovery action such as regions, android sdk versions, app versions etc.",
          "$ref": "Targeting"
        },
        "deployTime": {
          "description": "Timestamp of when the app recovery action is deployed to the users. Only set if the recovery action has been deployed.",
          "type": "string",
          "format": "google-datetime"
        },
        "createTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Timestamp of when the app recovery action is created by the developer. It is always set after creation of the recovery action."
        },
        "status": {
          "type": "string",
          "enumDescriptions": [
            "RecoveryStatus is unspecified.",
            "The app recovery action has not been canceled since it has been created.",
            "The recovery action has been canceled. The action cannot be resumed.",
            "The recovery action is in the draft state and has not yet been deployed to users.",
            "The recovery action is generating recovery apks.",
            "The app recovery action generation has failed."
          ],
          "description": "The status of the recovery action.",
          "enum": [
            "RECOVERY_STATUS_UNSPECIFIED",
            "RECOVERY_STATUS_ACTIVE",
            "RECOVERY_STATUS_CANCELED",
            "RECOVERY_STATUS_DRAFT",
            "RECOVERY_STATUS_GENERATION_IN_PROGRESS",
            "RECOVERY_STATUS_GENERATION_FAILED"
          ]
        },
        "lastUpdateTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Timestamp of when the developer last updated recovery action. In case the action is cancelled, it corresponds to cancellation time. It is always set after creation of the recovery action."
        },
        "remoteInAppUpdateData": {
          "description": "Data about the remote in-app update action such as such as recovered user base, recoverable user base etc. Set only if the recovery action type is Remote In-App Update.",
          "$ref": "RemoteInAppUpdateData"
        }
      }
    },
    "Order": {
      "description": "The Order resource encapsulates comprehensive information about a transaction made on Google Play. It includes a variety of attributes that provide details about the order itself, the products purchased, and the history of events related to the order. The Orders APIs provide real-time access to your order data within the Google Play ecosystem. You can retrieve detailed information and metadata for both one-time and recurring orders, including transaction details like charges, taxes, and refunds, as well as metadata such as pricing phases for subscriptions. The Orders APIs let you automate tasks related to order management, reducing the need for manual checks via the Play Developer Console. The following are some of the use cases for this API: + Real-time order data retrieval - Get order details and metadata immediately after a purchase using an order ID. + Order update synchronization - Periodically sync order updates to maintain an up-to-date record of order information. Note: + The Orders API calls count towards your Play Developer API quota, which defaults to 200K daily, and may be insufficient to sync extensive order histories. + A maximum of 1000 orders can be retrieved per call. Using larger page sizes is recommended to minimize quota usage. Check your quota in the Cloud Console and request more if required.",
      "properties": {
        "total": {
          "description": "The final amount paid by the customer, taking into account discounts and taxes.",
          "$ref": "Money"
        },
        "pointsDetails": {
          "$ref": "PointsDetails",
          "description": "Play points applied to the order, including offer information, discount rate and point values."
        },
        "purchaseToken": {
          "type": "string",
          "description": "The token provided to the user's device when the subscription or item was purchased."
        },
        "buyerAddress": {
          "description": "Address information for the customer, for use in tax computation. When Google is the Merchant of Record for the order, only country is shown.",
          "$ref": "BuyerAddress"
        },
        "orderId": {
          "type": "string",
          "description": "The order ID."
        },
        "salesChannel": {
          "enum": [
            "SALES_CHANNEL_UNSPECIFIED",
            "IN_APP",
            "PC_EMULATOR",
            "NATIVE_PC",
            "PLAY_STORE",
            "OUTSIDE_PLAY_STORE"
          ],
          "description": "The originating sales channel of the order.",
          "type": "string",
          "enumDescriptions": [
            "Sales channel unspecified. This value is not used.",
            "Standard orders that initiated from in-app.",
            "Orders initiated from a PC emulator for in-app purchases.",
            "Orders initiated from a native PC app for in-app purchases.",
            "Orders initiated from the Google Play store.",
            "Orders initiated outside the Google Play store."
          ]
        },
        "lastEventTime": {
          "description": "The time of the last event that occurred on the order.",
          "type": "string",
          "format": "google-datetime"
        },
        "createTime": {
          "description": "The time when the order was created.",
          "type": "string",
          "format": "google-datetime"
        },
        "lineItems": {
          "description": "The individual line items making up this order.",
          "type": "array",
          "items": {
            "$ref": "LineItem"
          }
        },
        "orderDetails": {
          "$ref": "OrderDetails",
          "description": "Detailed information about the order at creation time."
        },
        "state": {
          "description": "The state of the order.",
          "type": "string",
          "enumDescriptions": [
            "State unspecified. This value is not used.",
            "Order has been created and is waiting to be processed.",
            "Order has been successfully processed.",
            "Order was canceled before being processed.",
            "Requested refund is waiting to be processed.",
            "Part of the order amount was refunded.",
            "The full order amount was refunded."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "PENDING",
            "PROCESSED",
            "CANCELED",
            "PENDING_REFUND",
            "PARTIALLY_REFUNDED",
            "REFUNDED"
          ]
        },
        "tax": {
          "description": "The total tax paid as a part of this order.",
          "$ref": "Money"
        },
        "orderHistory": {
          "$ref": "OrderHistory",
          "description": "Details about events which modified the order."
        },
        "developerRevenueInBuyerCurrency": {
          "description": "Your revenue for this order in the buyer's currency, including deductions of partial refunds, taxes and fees. Google deducts standard transaction and third party fees from each sale, including VAT in some regions.",
          "$ref": "Money"
        }
      },
      "id": "Order",
      "type": "object"
    },
    "DeployAppRecoveryResponse": {
      "description": "Response message for DeployAppRecovery.",
      "properties": {},
      "id": "DeployAppRecoveryResponse",
      "type": "object"
    },
    "AutoRenewingBasePlanType": {
      "id": "AutoRenewingBasePlanType",
      "type": "object",
      "description": "Represents a base plan that automatically renews at the end of its subscription period.",
      "properties": {
        "resubscribeState": {
          "enum": [
            "RESUBSCRIBE_STATE_UNSPECIFIED",
            "RESUBSCRIBE_STATE_ACTIVE",
            "RESUBSCRIBE_STATE_INACTIVE"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified state.",
            "Resubscribe is active.",
            "Resubscribe is inactive."
          ],
          "description": "Whether users should be able to resubscribe to this base plan in Google Play surfaces. Defaults to RESUBSCRIBE_STATE_ACTIVE if not specified."
        },
        "prorationMode": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified mode.",
            "Users will be charged for their new base plan at the end of their current billing period.",
            "Users will be charged for their new base plan immediately and in full. Any remaining period of their existing subscription will be used to extend the duration of the new billing plan."
          ],
          "description": "The proration mode for the base plan determines what happens when a user switches to this plan from another base plan. If unspecified, defaults to CHARGE_ON_NEXT_BILLING_DATE.",
          "enum": [
            "SUBSCRIPTION_PRORATION_MODE_UNSPECIFIED",
            "SUBSCRIPTION_PRORATION_MODE_CHARGE_ON_NEXT_BILLING_DATE",
            "SUBSCRIPTION_PRORATION_MODE_CHARGE_FULL_PRICE_IMMEDIATELY"
          ]
        },
        "billingPeriodDuration": {
          "description": "Required. Immutable. Subscription period, specified in ISO 8601 format. For a list of acceptable billing periods, refer to the help center. The duration is immutable after the base plan is created.",
          "type": "string"
        },
        "legacyCompatibleSubscriptionOfferId": {
          "description": "Subscription offer id which is legacy compatible. The backward compatible subscription offer is returned by the Google Play Billing Library deprecated method querySkuDetailsAsync(). Only one subscription offer can be marked as legacy compatible for a given renewing base plan. To have no Subscription offer as legacy compatible set this field as empty string.",
          "type": "string"
        },
        "gracePeriodDuration": {
          "type": "string",
          "description": "Grace period of the subscription, specified in ISO 8601 format. Acceptable values must be in days and between P0D and the lesser of 30D and base plan billing period. If not specified, a default value will be used based on the billing period. The sum of gracePeriodDuration and accountHoldDuration must be between P30D and P60D days, inclusive."
        },
        "accountHoldDuration": {
          "type": "string",
          "description": "Optional. Custom account hold period of the subscription, specified in ISO 8601 format. Acceptable values must be in days and between P0D and P60D. An empty field represents a recommended account hold, calculated as 60 days minus grace period. The sum of gracePeriodDuration and accountHoldDuration must be between P30D and P60D days, inclusive."
        },
        "legacyCompatible": {
          "description": "Whether the renewing base plan is backward compatible. The backward compatible base plan is returned by the Google Play Billing Library deprecated method querySkuDetailsAsync(). Only one renewing base plan can be marked as legacy compatible for a given subscription.",
          "type": "boolean"
        }
      }
    },
    "Track": {
      "description": "A track configuration. The resource for TracksService.",
      "properties": {
        "track": {
          "type": "string",
          "description": "Identifier of the track. Form factor tracks have a special prefix as an identifier, for example `wear:production`, `automotive:production`. [More on track name](https://developers.google.com/android-publisher/tracks#ff-track-name)"
        },
        "releases": {
          "description": "In a read request, represents all active releases in the track. In an update request, represents desired changes.",
          "type": "array",
          "items": {
            "$ref": "TrackRelease"
          }
        }
      },
      "id": "Track",
      "type": "object"
    },
    "RegionalProductAgeRatingInfo": {
      "id": "RegionalProductAgeRatingInfo",
      "type": "object",
      "description": "Details about the age rating for a specific geographic region.",
      "properties": {
        "regionCode": {
          "type": "string",
          "description": "Region code this configuration applies to, as defined by ISO 3166-2, e.g. \"US\"."
        },
        "productAgeRatingTier": {
          "enum": [
            "PRODUCT_AGE_RATING_TIER_UNKNOWN",
            "PRODUCT_AGE_RATING_TIER_EVERYONE",
            "PRODUCT_AGE_RATING_TIER_THIRTEEN_AND_ABOVE",
            "PRODUCT_AGE_RATING_TIER_SIXTEEN_AND_ABOVE",
            "PRODUCT_AGE_RATING_TIER_EIGHTEEN_AND_ABOVE"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unknown age rating tier.",
            "Age rating tier for products that are appropriate for all ages.",
            "Age rating tier for products that are appropriate for 13 years and above.",
            "Age rating tier for products that are appropriate for 16 years and above.",
            "Age rating tier for products that are appropriate for 18 years and above."
          ],
          "description": "The age rating tier of a product for the given region."
        }
      }
    },
    "RevocationContextProratedRefund": {
      "description": "Used to determine if the refund type in the RevocationContext is a prorated refund.",
      "properties": {},
      "id": "RevocationContextProratedRefund",
      "type": "object"
    },
    "InappproductsBatchDeleteRequest": {
      "id": "InappproductsBatchDeleteRequest",
      "type": "object",
      "description": "Request to delete multiple in-app products.",
      "properties": {
        "requests": {
          "description": "Individual delete requests. At least one request is required. Can contain up to 100 requests. All requests must correspond to different in-app products.",
          "type": "array",
          "items": {
            "$ref": "InappproductsDeleteRequest"
          }
        }
      }
    },
    "SubscriptionOfferPhase": {
      "id": "SubscriptionOfferPhase",
      "type": "object",
      "description": "A single phase of a subscription offer.",
      "properties": {
        "recurrenceCount": {
          "type": "integer",
          "format": "int32",
          "description": "Required. The number of times this phase repeats. If this offer phase is not free, each recurrence charges the user the price of this offer phase."
        },
        "duration": {
          "description": "Required. The duration of a single recurrence of this phase. Specified in ISO 8601 format.",
          "type": "string"
        },
        "otherRegionsConfig": {
          "$ref": "OtherRegionsSubscriptionOfferPhaseConfig",
          "description": "Pricing information for any new locations Play may launch in."
        },
        "regionalConfigs": {
          "type": "array",
          "items": {
            "$ref": "RegionalSubscriptionOfferPhaseConfig"
          },
          "description": "Required. The region-specific configuration of this offer phase. This list must contain exactly one entry for each region for which the subscription offer has a regional config."
        }
      }
    },
    "TracksListResponse": {
      "id": "TracksListResponse",
      "type": "object",
      "description": "Response listing all tracks.",
      "properties": {
        "kind": {
          "description": "The kind of this response (\"androidpublisher#tracksListResponse\").",
          "type": "string"
        },
        "tracks": {
          "type": "array",
          "items": {
            "$ref": "Track"
          },
          "description": "All tracks (including tracks with no releases)."
        }
      }
    },
    "CancelSubscriptionPurchaseResponse": {
      "id": "CancelSubscriptionPurchaseResponse",
      "type": "object",
      "description": "Response for the purchases.subscriptionsv2.cancel API.",
      "properties": {}
    },
    "ListSubscriptionsResponse": {
      "description": "Response message for ListSubscriptions.",
      "properties": {
        "subscriptions": {
          "description": "The subscriptions from the specified app.",
          "type": "array",
          "items": {
            "$ref": "Subscription"
          }
        },
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      },
      "id": "ListSubscriptionsResponse",
      "type": "object"
    },
    "UpdateOneTimeProductRequest": {
      "id": "UpdateOneTimeProductRequest",
      "type": "object",
      "description": "Request message for UpdateOneTimeProduct.",
      "properties": {
        "latencyTolerance": {
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product upsert. Defaults to latency-sensitive.",
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "oneTimeProduct": {
          "$ref": "OneTimeProduct",
          "description": "Required. The one-time product to upsert."
        },
        "updateMask": {
          "description": "Required. The list of fields to be updated.",
          "type": "string",
          "format": "google-fieldmask"
        },
        "regionsVersion": {
          "description": "Required. The version of the available regions being used for the one-time product.",
          "$ref": "RegionsVersion"
        },
        "allowMissing": {
          "type": "boolean",
          "description": "Optional. If set to true, and the one-time product with the given package_name and product_id doesn't exist, the one-time product will be created. If a new one-time product is created, update_mask is ignored."
        }
      }
    },
    "CancellationEvent": {
      "id": "CancellationEvent",
      "type": "object",
      "description": "Details of when the order was canceled.",
      "properties": {
        "eventTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when the order was canceled."
        }
      }
    },
    "ConvertRegionPricesResponse": {
      "description": "Response message for ConvertRegionPrices.",
      "properties": {
        "convertedRegionPrices": {
          "additionalProperties": {
            "$ref": "ConvertedRegionPrice"
          },
          "type": "object",
          "description": "Map from region code to converted region price."
        },
        "convertedOtherRegionsPrice": {
          "description": "Converted other regions prices in USD and EUR, to use for countries where Play doesn't support a country's local currency.",
          "$ref": "ConvertedOtherRegionsPrice"
        },
        "regionVersion": {
          "description": "The region version at which the prices were generated.",
          "$ref": "RegionsVersion"
        }
      },
      "id": "ConvertRegionPricesResponse",
      "type": "object"
    },
    "SubscriptionOffer": {
      "description": "A single, temporary offer",
      "properties": {
        "packageName": {
          "description": "Required. Immutable. The package name of the app the parent subscription belongs to.",
          "type": "string"
        },
        "state": {
          "description": "Output only. The current state of this offer. Can be changed using Activate and Deactivate actions. NB: the base plan state supersedes this state, so an active offer may not be available if the base plan is not active.",
          "readOnly": true,
          "enumDescriptions": [
            "Default value, should never be used.",
            "The subscription offer is not and has never been available to users.",
            "The subscription offer is available to new and existing users.",
            "The subscription offer is not available to new users. Existing users retain access."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "DRAFT",
            "ACTIVE",
            "INACTIVE"
          ],
          "type": "string"
        },
        "basePlanId": {
          "type": "string",
          "description": "Required. Immutable. The ID of the base plan to which this offer is an extension."
        },
        "productId": {
          "type": "string",
          "description": "Required. Immutable. The ID of the parent subscription this offer belongs to."
        },
        "phases": {
          "description": "Required. The phases of this subscription offer. Must contain at least one and at most two entries. Users will always receive all these phases in the specified order.",
          "type": "array",
          "items": {
            "$ref": "SubscriptionOfferPhase"
          }
        },
        "offerId": {
          "type": "string",
          "description": "Required. Immutable. Unique ID of this subscription offer. Must be unique within the base plan."
        },
        "targeting": {
          "description": "The requirements that users need to fulfil to be eligible for this offer. Represents the requirements that Play will evaluate to decide whether an offer should be returned. Developers may further filter these offers themselves.",
          "$ref": "SubscriptionOfferTargeting"
        },
        "offerTags": {
          "description": "List of up to 20 custom tags specified for this offer, and returned to the app through the billing library.",
          "type": "array",
          "items": {
            "$ref": "OfferTag"
          }
        },
        "otherRegionsConfig": {
          "$ref": "OtherRegionsSubscriptionOfferConfig",
          "description": "The configuration for any new locations Play may launch in the future."
        },
        "regionalConfigs": {
          "description": "Required. The region-specific configuration of this offer. Must contain at least one entry.",
          "type": "array",
          "items": {
            "$ref": "RegionalSubscriptionOfferConfig"
          }
        }
      },
      "id": "SubscriptionOffer",
      "type": "object"
    },
    "CreateDraftAppRecoveryRequest": {
      "description": "Request message for CreateDraftAppRecovery.",
      "properties": {
        "targeting": {
          "description": "Specifies targeting criteria for the recovery action such as regions, android sdk versions, app versions etc.",
          "$ref": "Targeting"
        },
        "remoteInAppUpdate": {
          "$ref": "RemoteInAppUpdate",
          "description": "Action type is remote in-app update. As a consequence of this action, a downloadable recovery module is also created for testing purposes."
        }
      },
      "id": "CreateDraftAppRecoveryRequest",
      "type": "object"
    },
    "ExpansionFile": {
      "id": "ExpansionFile",
      "type": "object",
      "description": "An expansion file. The resource for ExpansionFilesService.",
      "properties": {
        "fileSize": {
          "description": "If set, this field indicates that this APK has an expansion file uploaded to it: this APK does not reference another APK's expansion file. The field's value is the size of the uploaded expansion file in bytes.",
          "type": "string",
          "format": "int64"
        },
        "referencesVersion": {
          "description": "If set, this APK's expansion file references another APK's expansion file. The file_size field will not be set.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "OtherRecurringProduct": {
      "id": "OtherRecurringProduct",
      "type": "object",
      "description": "Details of a recurring external transaction product which doesn't belong to any other more specific category.",
      "properties": {}
    },
    "ExternalTransactionTestPurchase": {
      "description": "Represents a transaction performed using a test account. These transactions will not be charged by Google.",
      "properties": {},
      "id": "ExternalTransactionTestPurchase",
      "type": "object"
    },
    "SubscriptionPriceChange": {
      "description": "Contains the price change information for a subscription that can be used to control the user journey for the price change in the app. This can be in the form of seeking confirmation from the user or tailoring the experience for a successful conversion.",
      "properties": {
        "newPrice": {
          "$ref": "Price",
          "description": "The new price the subscription will renew with if the price change is accepted by the user."
        },
        "state": {
          "type": "integer",
          "format": "int32",
          "description": "The current state of the price change. Possible values are: 0. Outstanding: State for a pending price change waiting for the user to agree. In this state, you can optionally seek confirmation from the user using the In-App API. 1. Accepted: State for an accepted price change that the subscription will renew with unless it's canceled. The price change takes effect on a future date when the subscription renews. Note that the change might not occur when the subscription is renewed next."
        }
      },
      "id": "SubscriptionPriceChange",
      "type": "object"
    },
    "FullRefund": {
      "description": "A full refund of the remaining amount of a transaction.",
      "properties": {},
      "id": "FullRefund",
      "type": "object"
    },
    "TargetingInfo": {
      "id": "TargetingInfo",
      "type": "object",
      "description": "Targeting information about the generated apks.",
      "properties": {
        "assetSliceSet": {
          "type": "array",
          "items": {
            "$ref": "AssetSliceSet"
          },
          "description": "List of created asset slices."
        },
        "packageName": {
          "type": "string",
          "description": "The package name of this app."
        },
        "variant": {
          "type": "array",
          "items": {
            "$ref": "SplitApkVariant"
          },
          "description": "List of the created variants."
        }
      }
    },
    "GeneratedAssetPackSlice": {
      "id": "GeneratedAssetPackSlice",
      "type": "object",
      "description": "Download metadata for an asset pack slice.",
      "properties": {
        "sliceId": {
          "type": "string",
          "description": "Asset slice ID."
        },
        "moduleName": {
          "type": "string",
          "description": "Name of the module that this asset slice belongs to."
        },
        "version": {
          "type": "string",
          "format": "int64",
          "description": "Asset module version."
        },
        "downloadId": {
          "description": "Download ID, which uniquely identifies the APK to download. Should be supplied to `generatedapks.download` method.",
          "type": "string"
        }
      }
    },
    "SubscriptionPurchaseV2": {
      "description": "Indicates the status of a user's subscription purchase.",
      "properties": {
        "acknowledgementState": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified acknowledgement state.",
            "The subscription is not acknowledged yet.",
            "The subscription is acknowledged."
          ],
          "description": "The acknowledgement state of the subscription.",
          "enum": [
            "ACKNOWLEDGEMENT_STATE_UNSPECIFIED",
            "ACKNOWLEDGEMENT_STATE_PENDING",
            "ACKNOWLEDGEMENT_STATE_ACKNOWLEDGED"
          ]
        },
        "latestOrderId": {
          "deprecated": true,
          "description": "Deprecated: Use line_items.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.",
          "type": "string"
        },
        "externalAccountIdentifiers": {
          "description": "User account identifier in the third-party service.",
          "$ref": "ExternalAccountIdentifiers"
        },
        "linkedPurchaseToken": {
          "description": "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.",
          "type": "string"
        },
        "lineItems": {
          "type": "array",
          "items": {
            "$ref": "SubscriptionPurchaseLineItem"
          },
          "description": "Item-level info for a subscription purchase. The items in the same purchase should be either all with AutoRenewingPlan or all with PrepaidPlan."
        },
        "kind": {
          "type": "string",
          "description": "This kind represents a SubscriptionPurchaseV2 object in the androidpublisher service."
        },
        "startTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Time at which the subscription was granted. Not set for pending subscriptions (subscription was created but awaiting payment during signup)."
        },
        "outOfAppPurchaseContext": {
          "description": "Additional context for out of app purchases. This information is only present for re-subscription purchases (subscription purchases made after the previous subscription of the same product has expired) made through the Google Play subscriptions center. This field will be removed after you acknowledge the subscription.",
          "$ref": "OutOfAppPurchaseContext"
        },
        "canceledStateContext": {
          "$ref": "CanceledStateContext",
          "description": "Additional context around canceled subscriptions. Only present if the subscription currently has subscription_state SUBSCRIPTION_STATE_CANCELED or SUBSCRIPTION_STATE_EXPIRED."
        },
        "subscribeWithGoogleInfo": {
          "$ref": "SubscribeWithGoogleInfo",
          "description": "User profile associated with purchases made with 'Subscribe with Google'."
        },
        "regionCode": {
          "description": "ISO 3166-1 alpha-2 billing country/region code of the user at the time the subscription was granted.",
          "type": "string"
        },
        "subscriptionState": {
          "description": "The current state of the subscription.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified subscription state.",
            "Subscription was created but awaiting payment during signup. In this state, all items are awaiting payment.",
            "Subscription is active. - (1) If the subscription is an auto renewing plan, at least one item is auto_renew_enabled and not expired. - (2) If the subscription is a prepaid plan, at least one item is not expired.",
            "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 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 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 is canceled but not expired yet. The state is only available when the subscription is an auto renewing plan. All items have auto_renew_enabled set to false.",
            "Subscription is expired. All items have expiry_time in the past.",
            "Pending transaction for subscription is canceled. If this pending purchase was for an existing subscription, use linked_purchase_token to get the current state of that subscription."
          ],
          "enum": [
            "SUBSCRIPTION_STATE_UNSPECIFIED",
            "SUBSCRIPTION_STATE_PENDING",
            "SUBSCRIPTION_STATE_ACTIVE",
            "SUBSCRIPTION_STATE_PAUSED",
            "SUBSCRIPTION_STATE_IN_GRACE_PERIOD",
            "SUBSCRIPTION_STATE_ON_HOLD",
            "SUBSCRIPTION_STATE_CANCELED",
            "SUBSCRIPTION_STATE_EXPIRED",
            "SUBSCRIPTION_STATE_PENDING_PURCHASE_CANCELED"
          ]
        },
        "testPurchase": {
          "$ref": "TestPurchase",
          "description": "Only present if this subscription purchase is a test purchase."
        },
        "pausedStateContext": {
          "$ref": "PausedStateContext",
          "description": "Additional context around paused subscriptions. Only present if the subscription currently has subscription_state SUBSCRIPTION_STATE_PAUSED."
        },
        "etag": {
          "description": "Entity tag representing the current state of the subscription. The developer will provide this etag for subscription actions. This etag is always present for auto-renewing and prepaid subscriptions.",
          "type": "string"
        }
      },
      "id": "SubscriptionPurchaseV2",
      "type": "object"
    },
    "CountryTargeting": {
      "description": "Country targeting specification.",
      "properties": {
        "countries": {
          "description": "Countries to target, specified as two letter [CLDR codes](https://unicode.org/cldr/charts/latest/supplemental/territory_containment_un_m_49.html).",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "includeRestOfWorld": {
          "description": "Include \"rest of world\" as well as explicitly targeted countries.",
          "type": "boolean"
        }
      },
      "id": "CountryTargeting",
      "type": "object"
    },
    "ConvertedRegionPrice": {
      "id": "ConvertedRegionPrice",
      "type": "object",
      "description": "A converted region price.",
      "properties": {
        "taxAmount": {
          "description": "The tax amount of the converted price.",
          "$ref": "Money"
        },
        "regionCode": {
          "type": "string",
          "description": "The region code of the region."
        },
        "price": {
          "$ref": "Money",
          "description": "The converted price tax inclusive."
        }
      }
    },
    "BatchUpdateOneTimeProductsRequest": {
      "description": "Request message for BatchUpdateOneTimeProduct.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdateOneTimeProductRequest"
          },
          "description": "Required. A list of update requests of up to 100 elements. All requests must update different one-time products."
        }
      },
      "id": "BatchUpdateOneTimeProductsRequest",
      "type": "object"
    },
    "GeneratedUniversalApk": {
      "description": "Download metadata for a universal APK.",
      "properties": {
        "downloadId": {
          "type": "string",
          "description": "Download ID, which uniquely identifies the APK to download. Should be supplied to `generatedapks.download` method."
        }
      },
      "id": "GeneratedUniversalApk",
      "type": "object"
    },
    "StandaloneApkMetadata": {
      "id": "StandaloneApkMetadata",
      "type": "object",
      "description": "Holds data specific to Standalone APKs.",
      "properties": {
        "fusedModuleName": {
          "description": "Names of the modules fused in this standalone APK.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "FreeTrialDetails": {
      "description": "Details of a free trial pricing phase.",
      "properties": {},
      "id": "FreeTrialDetails",
      "type": "object"
    },
    "OtherRegionsSubscriptionOfferPhaseFreePriceOverride": {
      "description": "Represents the free price override configuration for any new locations Play may launch for a single offer phase.",
      "properties": {},
      "id": "OtherRegionsSubscriptionOfferPhaseFreePriceOverride",
      "type": "object"
    },
    "DeactivateBasePlanRequest": {
      "id": "DeactivateBasePlanRequest",
      "type": "object",
      "description": "Request message for DeactivateBasePlan.",
      "properties": {
        "packageName": {
          "description": "Required. The parent app (package name) of the base plan to deactivate.",
          "type": "string"
        },
        "productId": {
          "description": "Required. The parent subscription (ID) of the base plan to deactivate.",
          "type": "string"
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ]
        },
        "basePlanId": {
          "description": "Required. The unique base plan ID of the base plan to deactivate.",
          "type": "string"
        }
      }
    },
    "BatchDeletePurchaseOptionsRequest": {
      "id": "BatchDeletePurchaseOptionsRequest",
      "type": "object",
      "description": "Request message for BatchDeletePurchaseOption.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "DeletePurchaseOptionRequest"
          },
          "description": "Required. A list of delete requests of up to 100 elements. All requests must delete purchase options from different one-time products."
        }
      }
    },
    "PurchaseStateContext": {
      "id": "PurchaseStateContext",
      "type": "object",
      "description": "Context about the purchase state.",
      "properties": {
        "purchaseState": {
          "type": "string",
          "readOnly": true,
          "enumDescriptions": [
            "Purchase state unspecified. This value should never be set.",
            "Purchased successfully.",
            "Purchase canceled.",
            "The purchase is in a pending state and has not yet been completed. For more information on handling pending purchases, see https://developer.android.com/google/play/billing/integrate#pending."
          ],
          "description": "Output only. The purchase state of the purchase.",
          "enum": [
            "PURCHASE_STATE_UNSPECIFIED",
            "PURCHASED",
            "CANCELLED",
            "PENDING"
          ]
        }
      }
    },
    "BatchUpdateSubscriptionsResponse": {
      "description": "Response message for BatchUpdateSubscription.",
      "properties": {
        "subscriptions": {
          "description": "The updated subscriptions list.",
          "type": "array",
          "items": {
            "$ref": "Subscription"
          }
        }
      },
      "id": "BatchUpdateSubscriptionsResponse",
      "type": "object"
    },
    "ManagedProductTaxAndComplianceSettings": {
      "description": "Details about taxation and legal compliance for managed products.",
      "properties": {
        "eeaWithdrawalRightType": {
          "enum": [
            "WITHDRAWAL_RIGHT_TYPE_UNSPECIFIED",
            "WITHDRAWAL_RIGHT_DIGITAL_CONTENT",
            "WITHDRAWAL_RIGHT_SERVICE"
          ],
          "type": "string",
          "enumDescriptions": [
            "",
            "",
            ""
          ],
          "description": "Digital content or service classification for products distributed to users in the European Economic Area (EEA). The withdrawal regime under EEA consumer laws depends on this classification. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/10463498) for more information."
        },
        "taxRateInfoByRegionCode": {
          "description": "A mapping from region code to tax rate details. The keys are region codes as defined by Unicode's \"CLDR\".",
          "type": "object",
          "additionalProperties": {
            "$ref": "RegionalTaxRateInfo"
          }
        },
        "isTokenizedDigitalAsset": {
          "type": "boolean",
          "description": "Whether this in-app product is declared as a product representing a tokenized digital asset."
        },
        "regionalProductAgeRatingInfos": {
          "type": "array",
          "items": {
            "$ref": "RegionalProductAgeRatingInfo"
          },
          "description": "Regional age rating information. Currently this field is only supported for region code `US`."
        },
        "productTaxCategoryCode": {
          "description": "Product tax category code to assign to the in-app product. Product tax category determines the transaction tax rates applied to the product. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/16408159) for more information.",
          "type": "string"
        }
      },
      "id": "ManagedProductTaxAndComplianceSettings",
      "type": "object"
    },
    "BatchUpdateBasePlanStatesRequest": {
      "id": "BatchUpdateBasePlanStatesRequest",
      "type": "object",
      "description": "Request message for BatchUpdateBasePlanStates.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdateBasePlanStateRequest"
          },
          "description": "Required. The update request list of up to 100 elements. All requests must update different base plans."
        }
      }
    },
    "OneTimeProductBuyPurchaseOption": {
      "description": "A purchase option that can be bought.",
      "properties": {
        "legacyCompatible": {
          "description": "Optional. Whether this purchase option will be available in legacy PBL flows that do not support one-time products model. Up to one \"buy\" purchase option can be marked as backwards compatible.",
          "type": "boolean"
        },
        "multiQuantityEnabled": {
          "type": "boolean",
          "description": "Optional. Whether this purchase option allows multi-quantity. Multi-quantity allows buyer to purchase more than one item in a single checkout."
        }
      },
      "id": "OneTimeProductBuyPurchaseOption",
      "type": "object"
    },
    "UserComment": {
      "description": "User entry from conversation between user and developer.",
      "properties": {
        "thumbsUpCount": {
          "type": "integer",
          "format": "int32",
          "description": "Number of users who have given this review a thumbs up."
        },
        "originalText": {
          "type": "string",
          "description": "Untranslated text of the review, where the review was translated. If the review was not translated this is left blank."
        },
        "starRating": {
          "description": "The star rating associated with the review, from 1 to 5.",
          "type": "integer",
          "format": "int32"
        },
        "appVersionCode": {
          "description": "Integer version code of the app as installed at the time the review was written. May be absent.",
          "type": "integer",
          "format": "int32"
        },
        "reviewerLanguage": {
          "description": "Language code for the reviewer. This is taken from the device settings so is not guaranteed to match the language the review is written in. May be absent.",
          "type": "string"
        },
        "text": {
          "description": "The content of the comment, i.e. review body. In some cases users have been able to write a review with separate title and body; in those cases the title and body are concatenated and separated by a tab character.",
          "type": "string"
        },
        "androidOsVersion": {
          "description": "Integer Android SDK version of the user's device at the time the review was written, e.g. 23 is Marshmallow. May be absent.",
          "type": "integer",
          "format": "int32"
        },
        "deviceMetadata": {
          "description": "Information about the characteristics of the user's device.",
          "$ref": "DeviceMetadata"
        },
        "appVersionName": {
          "description": "String version name of the app as installed at the time the review was written. May be absent.",
          "type": "string"
        },
        "thumbsDownCount": {
          "description": "Number of users who have given this review a thumbs down.",
          "type": "integer",
          "format": "int32"
        },
        "lastModified": {
          "description": "The last time at which this comment was updated.",
          "$ref": "Timestamp"
        },
        "device": {
          "type": "string",
          "description": "Codename for the reviewer's device, e.g. klte, flounder. May be absent."
        }
      },
      "id": "UserComment",
      "type": "object"
    },
    "AcquisitionTargetingRule": {
      "id": "AcquisitionTargetingRule",
      "type": "object",
      "description": "Represents a targeting rule of the form: User never had {scope} before.",
      "properties": {
        "scope": {
          "$ref": "TargetingRuleScope",
          "description": "Required. The scope of subscriptions this rule considers. Only allows \"this subscription\" and \"any subscription in app\"."
        }
      }
    },
    "DeleteOneTimeProductOfferRequest": {
      "description": "Request message for deleting an one-time product offer.",
      "properties": {
        "offerId": {
          "type": "string",
          "description": "Required. The unique offer ID of the offer to delete."
        },
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to delete."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        },
        "purchaseOptionId": {
          "description": "Required. The parent purchase option (ID) of the offer to delete.",
          "type": "string"
        },
        "productId": {
          "description": "Required. The parent one-time product (ID) of the offer to delete.",
          "type": "string"
        }
      },
      "id": "DeleteOneTimeProductOfferRequest",
      "type": "object"
    },
    "RevocationContext": {
      "description": "Revocation context of the purchases.subscriptionsv2.revoke API.",
      "properties": {
        "itemBasedRefund": {
          "$ref": "RevocationContextItemBasedRefund",
          "description": "Optional. Used when a specific item should be refunded in a subscription with add-on items."
        },
        "fullRefund": {
          "$ref": "RevocationContextFullRefund",
          "description": "Optional. Used when users should be refunded the full amount of latest charge on each item in the subscription."
        },
        "proratedRefund": {
          "$ref": "RevocationContextProratedRefund",
          "description": "Optional. Used when users should be refunded a prorated amount they paid for their subscription based on the amount of time remaining in a subscription."
        }
      },
      "id": "RevocationContext",
      "type": "object"
    },
    "GeneratedSplitApk": {
      "id": "GeneratedSplitApk",
      "type": "object",
      "description": "Download metadata for a split APK.",
      "properties": {
        "downloadId": {
          "description": "Download ID, which uniquely identifies the APK to download. Should be supplied to `generatedapks.download` method.",
          "type": "string"
        },
        "variantId": {
          "type": "integer",
          "format": "int32",
          "description": "ID of the generated variant."
        },
        "splitId": {
          "type": "string",
          "description": "Split ID. Empty for the main split of the base module."
        },
        "moduleName": {
          "description": "Name of the module that this APK belongs to.",
          "type": "string"
        }
      }
    },
    "DeviceSpec": {
      "id": "DeviceSpec",
      "type": "object",
      "description": "The device spec used to generate a system APK.",
      "properties": {
        "supportedLocales": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "All installed locales represented as BCP-47 strings, e.g. \"en-US\"."
        },
        "screenDensity": {
          "type": "integer",
          "format": "uint32",
          "description": "Screen dpi."
        },
        "supportedAbis": {
          "description": "Supported ABI architectures in the order of preference. The values should be the string as reported by the platform, e.g. \"armeabi-v7a\", \"x86_64\".",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "ProductPurchaseV2": {
      "description": "A ProductPurchaseV2 resource indicates the status of a user's inapp product purchase.",
      "properties": {
        "orderId": {
          "description": "The order id associated with the purchase of the inapp product. May not be set if there is no order associated with the purchase.",
          "type": "string"
        },
        "kind": {
          "description": "This kind represents a ProductPurchaseV2 object in the androidpublisher service.",
          "type": "string"
        },
        "obfuscatedExternalProfileId": {
          "description": "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.",
          "type": "string"
        },
        "regionCode": {
          "type": "string",
          "description": "ISO 3166-1 alpha-2 billing region code of the user at the time the product was granted."
        },
        "purchaseCompletionTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time when the purchase was successful, i.e., when the PurchaseState has changed to PURCHASED. This field will not be present until the payment is complete. For example, if the user initiated a pending transaction (https://developer.android.com/google/play/billing/integrate#pending), this field will not be populated until the user successfully completes the steps required to complete the transaction."
        },
        "testPurchaseContext": {
          "$ref": "TestPurchaseContext",
          "description": "Information related to test purchases. This will only be set for test purchases."
        },
        "acknowledgementState": {
          "type": "string",
          "readOnly": true,
          "enumDescriptions": [
            "Unspecified acknowledgement state.",
            "The purchase is not acknowledged yet.",
            "The purchase is acknowledged."
          ],
          "description": "Output only. The acknowledgement state of the purchase.",
          "enum": [
            "ACKNOWLEDGEMENT_STATE_UNSPECIFIED",
            "ACKNOWLEDGEMENT_STATE_PENDING",
            "ACKNOWLEDGEMENT_STATE_ACKNOWLEDGED"
          ]
        },
        "obfuscatedExternalAccountId": {
          "description": "An obfuscated version of the id that is uniquely associated with the user's account in your app. Only present if specified using https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedaccountid when the purchase was made.",
          "type": "string"
        },
        "productLineItem": {
          "description": "Contains item-level info for a ProductPurchaseV2.",
          "type": "array",
          "items": {
            "$ref": "ProductLineItem"
          }
        },
        "purchaseStateContext": {
          "$ref": "PurchaseStateContext",
          "description": "Information about the purchase state of the purchase."
        }
      },
      "id": "ProductPurchaseV2",
      "type": "object"
    },
    "BundlesListResponse": {
      "id": "BundlesListResponse",
      "type": "object",
      "description": "Response listing all app bundles.",
      "properties": {
        "kind": {
          "type": "string",
          "description": "The kind of this response (\"androidpublisher#bundlesListResponse\")."
        },
        "bundles": {
          "type": "array",
          "items": {
            "$ref": "Bundle"
          },
          "description": "All app bundles."
        }
      }
    },
    "Variant": {
      "id": "Variant",
      "type": "object",
      "description": "APK that is suitable for inclusion in a system image. The resource of SystemApksService.",
      "properties": {
        "variantId": {
          "readOnly": true,
          "type": "integer",
          "format": "uint32",
          "description": "Output only. The ID of a previously created system APK variant."
        },
        "deviceSpec": {
          "$ref": "DeviceSpec",
          "description": "The device spec used to generate the APK."
        },
        "options": {
          "$ref": "SystemApkOptions",
          "description": "Optional. Options applied to the generated APK."
        }
      }
    },
    "OtherRegionsSubscriptionOfferPhasePrices": {
      "id": "OtherRegionsSubscriptionOfferPhasePrices",
      "type": "object",
      "description": "Pricing information for any new locations Play may launch in.",
      "properties": {
        "usdPrice": {
          "$ref": "Money",
          "description": "Required. Price in USD to use for any new locations Play may launch in."
        },
        "eurPrice": {
          "description": "Required. Price in EUR to use for any new locations Play may launch in.",
          "$ref": "Money"
        }
      }
    },
    "ActivateSubscriptionOfferRequest": {
      "id": "ActivateSubscriptionOfferRequest",
      "type": "object",
      "description": "Request message for ActivateSubscriptionOffer.",
      "properties": {
        "productId": {
          "type": "string",
          "description": "Required. The parent subscription (ID) of the offer to activate."
        },
        "offerId": {
          "description": "Required. The unique offer ID of the offer to activate.",
          "type": "string"
        },
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to activate."
        },
        "latencyTolerance": {
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive.",
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ]
        },
        "basePlanId": {
          "type": "string",
          "description": "Required. The parent base plan (ID) of the offer to activate."
        }
      }
    },
    "BatchGetOrdersResponse": {
      "description": "Response for the orders.batchGet API.",
      "properties": {
        "orders": {
          "description": "Details for the requested order IDs.",
          "type": "array",
          "items": {
            "$ref": "Order"
          }
        }
      },
      "id": "BatchGetOrdersResponse",
      "type": "object"
    },
    "OneTimeProductOffer": {
      "description": "A single offer for a one-time product.",
      "properties": {
        "offerTags": {
          "type": "array",
          "items": {
            "$ref": "OfferTag"
          },
          "description": "Optional. List of up to 20 custom tags specified for this offer, and returned to the app through the billing library."
        },
        "offerId": {
          "description": "Required. Immutable. The ID of this product offer. Must be unique within the purchase option. It must start with a number or lower-case letter, and can only contain lower-case letters (a-z), numbers (0-9), and hyphens (-). The maximum length is 63 characters.",
          "type": "string"
        },
        "discountedOffer": {
          "$ref": "OneTimeProductDiscountedOffer",
          "description": "A discounted offer."
        },
        "productId": {
          "type": "string",
          "description": "Required. Immutable. The ID of the parent product this offer belongs to."
        },
        "purchaseOptionId": {
          "type": "string",
          "description": "Required. Immutable. The ID of the purchase option to which this offer is an extension."
        },
        "regionsVersion": {
          "$ref": "RegionsVersion",
          "description": "Output only. The version of the regions configuration that was used to generate the one-time product offer.",
          "readOnly": true
        },
        "preOrderOffer": {
          "$ref": "OneTimeProductPreOrderOffer",
          "description": "A pre-order offer."
        },
        "packageName": {
          "description": "Required. Immutable. The package name of the app the parent product belongs to.",
          "type": "string"
        },
        "regionalPricingAndAvailabilityConfigs": {
          "type": "array",
          "items": {
            "$ref": "OneTimeProductOfferRegionalPricingAndAvailabilityConfig"
          },
          "description": "Set of regional pricing and availability information for this offer. Must not have duplicate entries with the same region_code."
        },
        "state": {
          "type": "string",
          "description": "Output only. The current state of this offer. This field cannot be changed by updating the resource. Use the dedicated endpoints instead.",
          "readOnly": true,
          "enumDescriptions": [
            "Default value, should never be used.",
            "The offer is not and has never been available to users.",
            "The offer is available to users, as long as its conditions are met.",
            "This state is specific to pre-orders. The offer is cancelled and not available to users. All pending orders related to this offer were cancelled.",
            "This state is specific to discounted offers. The offer is no longer available to users."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "DRAFT",
            "ACTIVE",
            "CANCELLED",
            "INACTIVE"
          ]
        }
      },
      "id": "OneTimeProductOffer",
      "type": "object"
    },
    "PendingCancellation": {
      "id": "PendingCancellation",
      "type": "object",
      "description": "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.",
      "properties": {}
    },
    "OneTimeExternalTransaction": {
      "id": "OneTimeExternalTransaction",
      "type": "object",
      "description": "Represents a one-time transaction.",
      "properties": {
        "externalTransactionToken": {
          "description": "Input only. Provided during the call to Create. Retrieved from the client when the alternative billing flow is launched.",
          "type": "string"
        }
      }
    },
    "SubscriptionPurchasesDeferResponse": {
      "description": "Response for the purchases.subscriptions.defer API.",
      "properties": {
        "newExpiryTimeMillis": {
          "type": "string",
          "format": "int64",
          "description": "The new expiry time for the subscription in milliseconds since the Epoch."
        }
      },
      "id": "SubscriptionPurchasesDeferResponse",
      "type": "object"
    },
    "ModuleTargeting": {
      "id": "ModuleTargeting",
      "type": "object",
      "description": "Targeting on the module level.",
      "properties": {
        "sdkVersionTargeting": {
          "description": "The sdk version that the variant targets",
          "$ref": "SdkVersionTargeting"
        },
        "deviceFeatureTargeting": {
          "description": "Targeting for device features.",
          "type": "array",
          "items": {
            "$ref": "DeviceFeatureTargeting"
          }
        },
        "userCountriesTargeting": {
          "$ref": "UserCountriesTargeting",
          "description": "Countries-level targeting"
        }
      }
    },
    "ListingsListResponse": {
      "description": "Response listing all localized listings.",
      "properties": {
        "kind": {
          "description": "The kind of this response (\"androidpublisher#listingsListResponse\").",
          "type": "string"
        },
        "listings": {
          "description": "All localized listings.",
          "type": "array",
          "items": {
            "$ref": "Listing"
          }
        }
      },
      "id": "ListingsListResponse",
      "type": "object"
    },
    "DeveloperInitiatedCancellation": {
      "id": "DeveloperInitiatedCancellation",
      "type": "object",
      "description": "Information specific to cancellations initiated by developers.",
      "properties": {}
    },
    "OneTimeProductOfferNoPriceOverrideOptions": {
      "description": "Options for one-time product offers without a regional price override.",
      "properties": {},
      "id": "OneTimeProductOfferNoPriceOverrideOptions",
      "type": "object"
    },
    "ImagesDeleteAllResponse": {
      "description": "Response for deleting all images.",
      "properties": {
        "deleted": {
          "type": "array",
          "items": {
            "$ref": "Image"
          },
          "description": "The deleted images."
        }
      },
      "id": "ImagesDeleteAllResponse",
      "type": "object"
    },
    "DeviceTier": {
      "description": "A single device tier. Devices matching any of the device groups in device_group_names are considered to match the tier.",
      "properties": {
        "level": {
          "description": "The priority level of the tier. Tiers are evaluated in descending order of level: the highest level tier has the highest priority. The highest tier matching a given device is selected for that device. You should use a contiguous range of levels for your tiers in a tier set; tier levels in a tier set must be unique. For instance, if your tier set has 4 tiers (including the global fallback), you should define tiers 1, 2 and 3 in this configuration. Note: tier 0 is implicitly defined as a global fallback and selected for devices that don't match any of the tiers explicitly defined here. You mustn't define level 0 explicitly in this configuration.",
          "type": "integer",
          "format": "int32"
        },
        "deviceGroupNames": {
          "description": "Groups of devices included in this tier. These groups must be defined explicitly under device_groups in this configuration.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "id": "DeviceTier",
      "type": "object"
    },
    "SubscriptionPurchasesDeferRequest": {
      "description": "Request for the purchases.subscriptions.defer API.",
      "properties": {
        "deferralInfo": {
          "description": "The information about the new desired expiry time for the subscription.",
          "$ref": "SubscriptionDeferralInfo"
        }
      },
      "id": "SubscriptionPurchasesDeferRequest",
      "type": "object"
    },
    "ExternalTransaction": {
      "id": "ExternalTransaction",
      "type": "object",
      "description": "The details of an external transaction.",
      "properties": {
        "transactionTime": {
          "description": "Required. The time when the transaction was completed.",
          "type": "string",
          "format": "google-datetime"
        },
        "externalOfferDetails": {
          "$ref": "ExternalOfferDetails",
          "description": "Optional. Details necessary to accurately report external offers transactions."
        },
        "originalPreTaxAmount": {
          "$ref": "Price",
          "description": "Required. The original transaction amount before taxes. This represents the pre-tax amount originally notified to Google before any refunds were applied."
        },
        "currentTaxAmount": {
          "readOnly": true,
          "description": "Output only. The current tax amount. This represents the current tax amount including any refunds that may have been applied to this transaction.",
          "$ref": "Price"
        },
        "oneTimeTransaction": {
          "description": "This is a one-time transaction and not part of a subscription.",
          "$ref": "OneTimeExternalTransaction"
        },
        "currentPreTaxAmount": {
          "$ref": "Price",
          "readOnly": true,
          "description": "Output only. The current transaction amount before tax. This represents the current pre-tax amount including any refunds that may have been applied to this transaction."
        },
        "packageName": {
          "description": "Output only. The resource name of the external transaction. The package name of the application the inapp products were sold (for example, 'com.some.app').",
          "readOnly": true,
          "type": "string"
        },
        "transactionProgramCode": {
          "type": "integer",
          "format": "int32",
          "description": "Optional. The transaction program code, used to help determine service fee for eligible apps participating in partner programs. Developers participating in the Play Media Experience Program (https://play.google.com/console/about/programs/mediaprogram/) must provide the program code when reporting alternative billing transactions. If you are an eligible developer, please contact your BDM for more information on how to set this field. Note: this field can not be used for external offers transactions."
        },
        "recurringTransaction": {
          "$ref": "RecurringExternalTransaction",
          "description": "This transaction is part of a recurring series of transactions."
        },
        "createTime": {
          "readOnly": true,
          "type": "string",
          "format": "google-datetime",
          "description": "Output only. The time when this transaction was created. This is the time when Google was notified of the transaction."
        },
        "originalTaxAmount": {
          "$ref": "Price",
          "description": "Required. The original tax amount. This represents the tax amount originally notified to Google before any refunds were applied."
        },
        "transactionState": {
          "type": "string",
          "enum": [
            "TRANSACTION_STATE_UNSPECIFIED",
            "TRANSACTION_REPORTED",
            "TRANSACTION_CANCELED"
          ],
          "description": "Output only. The current state of the transaction.",
          "readOnly": true,
          "enumDescriptions": [
            "Unspecified transaction state. Not used.",
            "The transaction has been successfully reported to Google.",
            "The transaction has been fully refunded."
          ]
        },
        "testPurchase": {
          "$ref": "ExternalTransactionTestPurchase",
          "readOnly": true,
          "description": "Output only. If set, this transaction was a test purchase. Google will not charge for a test transaction."
        },
        "userTaxAddress": {
          "$ref": "ExternalTransactionAddress",
          "description": "Required. User address for tax computation."
        },
        "externalTransactionId": {
          "readOnly": true,
          "type": "string",
          "description": "Output only. The id of this transaction. All transaction ids under the same package name must be unique. Set when creating the external transaction."
        }
      }
    },
    "VariantTargeting": {
      "id": "VariantTargeting",
      "type": "object",
      "description": "Targeting on the level of variants.",
      "properties": {
        "screenDensityTargeting": {
          "$ref": "ScreenDensityTargeting",
          "description": "The screen densities that this variant supports"
        },
        "multiAbiTargeting": {
          "description": "Multi-api-level targeting",
          "$ref": "MultiAbiTargeting"
        },
        "abiTargeting": {
          "description": "The abi that the variant targets",
          "$ref": "AbiTargeting"
        },
        "sdkVersionTargeting": {
          "$ref": "SdkVersionTargeting",
          "description": "The sdk version that the variant targets"
        },
        "textureCompressionFormatTargeting": {
          "$ref": "TextureCompressionFormatTargeting",
          "description": "Texture-compression-format-level targeting"
        }
      }
    },
    "ExternalSubscription": {
      "description": "Details of an external subscription.",
      "properties": {
        "subscriptionType": {
          "enum": [
            "SUBSCRIPTION_TYPE_UNSPECIFIED",
            "RECURRING",
            "PREPAID"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified, do not use.",
            "This is a recurring subscription where the user is charged every billing cycle.",
            "This is a prepaid subscription where the user pays up front."
          ],
          "description": "Required. The type of the external subscription."
        }
      },
      "id": "ExternalSubscription",
      "type": "object"
    },
    "MultiAbiTargeting": {
      "id": "MultiAbiTargeting",
      "type": "object",
      "description": "Targeting based on multiple abis.",
      "properties": {
        "value": {
          "description": "Value of a multi abi.",
          "type": "array",
          "items": {
            "$ref": "MultiAbi"
          }
        },
        "alternatives": {
          "description": "Targeting of other sibling directories that were in the Bundle. For main splits this is targeting of other main splits.",
          "type": "array",
          "items": {
            "$ref": "MultiAbi"
          }
        }
      }
    },
    "LocalizedText": {
      "id": "LocalizedText",
      "type": "object",
      "description": "Localized text in given language.",
      "properties": {
        "language": {
          "type": "string",
          "description": "Language localization code (a BCP-47 language tag; for example, \"de-AT\" for Austrian German)."
        },
        "text": {
          "description": "The text in the given language.",
          "type": "string"
        }
      }
    },
    "RemoteInAppUpdateDataPerBundle": {
      "description": "Data related to the recovery action at bundle level.",
      "properties": {
        "recoveredDeviceCount": {
          "description": "Total number of devices which have been rescued.",
          "type": "string",
          "format": "int64"
        },
        "totalDeviceCount": {
          "type": "string",
          "format": "int64",
          "description": "Total number of devices affected by this recovery action associated with bundle of the app."
        },
        "versionCode": {
          "description": "Version Code corresponding to the target bundle.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "RemoteInAppUpdateDataPerBundle",
      "type": "object"
    },
    "ProductPurchase": {
      "id": "ProductPurchase",
      "type": "object",
      "description": "A ProductPurchase resource indicates the status of a user's inapp product purchase.",
      "properties": {
        "regionCode": {
          "type": "string",
          "description": "ISO 3166-1 alpha-2 billing region code of the user at the time the product was granted."
        },
        "purchaseToken": {
          "type": "string",
          "description": "The purchase token generated to identify this purchase. May not be present."
        },
        "orderId": {
          "description": "The order id associated with the purchase of the inapp product.",
          "type": "string"
        },
        "purchaseState": {
          "type": "integer",
          "format": "int32",
          "description": "The purchase state of the order. Possible values are: 0. Purchased 1. Canceled 2. Pending"
        },
        "purchaseTimeMillis": {
          "description": "The time the product was purchased, in milliseconds since the epoch (Jan 1, 1970).",
          "type": "string",
          "format": "int64"
        },
        "productId": {
          "type": "string",
          "description": "The inapp product SKU. May not be present."
        },
        "developerPayload": {
          "type": "string",
          "description": "A developer-specified string that contains supplemental information about an order."
        },
        "consumptionState": {
          "description": "The consumption state of the inapp product. Possible values are: 0. Yet to be consumed 1. Consumed",
          "type": "integer",
          "format": "int32"
        },
        "refundableQuantity": {
          "description": "The quantity eligible for refund, i.e. quantity that hasn't been refunded. The value reflects quantity-based partial refunds and full refunds.",
          "type": "integer",
          "format": "int32"
        },
        "obfuscatedExternalProfileId": {
          "type": "string",
          "description": "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."
        },
        "purchaseType": {
          "description": "The type of purchase of the inapp product. This field is only set if this purchase was not made using the standard in-app billing flow. Possible values are: 0. Test (i.e. purchased from a license testing account) 1. Promo (i.e. purchased using a promo code). Does not include Play Points purchases. 2. Rewarded (i.e. from watching a video ad instead of paying)",
          "type": "integer",
          "format": "int32"
        },
        "kind": {
          "type": "string",
          "description": "This kind represents an inappPurchase object in the androidpublisher service."
        },
        "obfuscatedExternalAccountId": {
          "type": "string",
          "description": "An obfuscated version of the id that is uniquely associated with the user's account in your app. Only present if specified using https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedaccountid when the purchase was made."
        },
        "acknowledgementState": {
          "description": "The acknowledgement state of the inapp product. Possible values are: 0. Yet to be acknowledged 1. Acknowledged",
          "type": "integer",
          "format": "int32"
        },
        "quantity": {
          "description": "The quantity associated with the purchase of the inapp product. If not present, the quantity is 1.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "DeferralContext": {
      "description": "Deferral context of the purchases.subscriptionsv2.defer API.",
      "properties": {
        "etag": {
          "type": "string",
          "description": "Required. The API will fail if the etag does not match the latest etag for this subscription. The etag is retrieved from purchases.subscriptionsv2.get: https://developers.google.com/android-publisher/api-ref/rest/v3/purchases.subscriptionsv2/get"
        },
        "deferDuration": {
          "description": "Required. The duration by which all subscription items should be deferred.",
          "type": "string",
          "format": "google-duration"
        },
        "validateOnly": {
          "description": "If set to \"true\", the request is a dry run to validate the effect of Defer, the subscription would not be impacted.",
          "type": "boolean"
        }
      },
      "id": "DeferralContext",
      "type": "object"
    },
    "DeleteOneTimeProductRequest": {
      "id": "DeleteOneTimeProductRequest",
      "type": "object",
      "description": "Request message for deleting a one-time product.",
      "properties": {
        "packageName": {
          "description": "Required. The parent app (package name) of the one-time product to delete.",
          "type": "string"
        },
        "productId": {
          "type": "string",
          "description": "Required. The one-time product ID of the one-time product to delete."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        }
      }
    },
    "BatchUpdateSubscriptionOfferStatesRequest": {
      "id": "BatchUpdateSubscriptionOfferStatesRequest",
      "type": "object",
      "description": "Request message for BatchUpdateSubscriptionOfferStates.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdateSubscriptionOfferStateRequest"
          },
          "description": "Required. The update request list of up to 100 elements. All requests must update different offers."
        }
      }
    },
    "DeletePurchaseOptionRequest": {
      "description": "Request message for deleting a purchase option.",
      "properties": {
        "purchaseOptionId": {
          "description": "Required. The purchase option ID of the purchase option to delete.",
          "type": "string"
        },
        "force": {
          "description": "Optional. This field has no effect for purchase options with no offers under them. For purchase options with associated offers: * If `force` is set to false (default), an error will be returned. * If `force` is set to true, any associated offers under the purchase option will be deleted.",
          "type": "boolean"
        },
        "productId": {
          "description": "Required. The parent one-time product (ID) of the purchase option to delete.",
          "type": "string"
        },
        "packageName": {
          "description": "Required. The parent app (package name) of the purchase option to delete.",
          "type": "string"
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        }
      },
      "id": "DeletePurchaseOptionRequest",
      "type": "object"
    },
    "FreeTrialOfferPhase": {
      "id": "FreeTrialOfferPhase",
      "type": "object",
      "description": "Details about free trial offer phase.",
      "properties": {}
    },
    "TargetingRuleScope": {
      "description": "Defines the scope of subscriptions which a targeting rule can match to target offers to users based on past or current entitlement.",
      "properties": {
        "thisSubscription": {
          "description": "The scope of the current targeting rule is the subscription in which this offer is defined.",
          "$ref": "TargetingRuleScopeThisSubscription"
        },
        "anySubscriptionInApp": {
          "description": "The scope of the current targeting rule is any subscription in the parent app.",
          "$ref": "TargetingRuleScopeAnySubscriptionInApp"
        },
        "specificSubscriptionInApp": {
          "description": "The scope of the current targeting rule is the subscription with the specified subscription ID. Must be a subscription within the same parent app.",
          "type": "string"
        }
      },
      "id": "TargetingRuleScope",
      "type": "object"
    },
    "MultiAbi": {
      "description": "Represents a list of ABIs.",
      "properties": {
        "abi": {
          "description": "A list of targeted ABIs, as represented by the Android Platform",
          "type": "array",
          "items": {
            "$ref": "Abi"
          }
        }
      },
      "id": "MultiAbi",
      "type": "object"
    },
    "BatchUpdateOneTimeProductOfferStatesResponse": {
      "description": "Response message for BatchUpdateOneTimeProductOfferStates.",
      "properties": {
        "oneTimeProductOffers": {
          "type": "array",
          "items": {
            "$ref": "OneTimeProductOffer"
          },
          "description": "The updated one-time product offers list, in the same order as the request."
        }
      },
      "id": "BatchUpdateOneTimeProductOfferStatesResponse",
      "type": "object"
    },
    "Regions": {
      "id": "Regions",
      "type": "object",
      "description": "Region targeting data for app recovery action targeting.",
      "properties": {
        "regionCode": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "Regions targeted by the recovery action. Region codes are ISO 3166 Alpha-2 country codes. For example, US stands for United States of America. See https://www.iso.org/iso-3166-country-codes.html for the complete list of country codes."
        }
      }
    },
    "MigrateBasePlanPricesRequest": {
      "description": "Request message for MigrateBasePlanPrices.",
      "properties": {
        "basePlanId": {
          "description": "Required. The unique base plan ID of the base plan to update prices on.",
          "type": "string"
        },
        "regionalPriceMigrations": {
          "type": "array",
          "items": {
            "$ref": "RegionalPriceMigrationConfig"
          },
          "description": "Required. The regional prices to update."
        },
        "packageName": {
          "type": "string",
          "description": "Required. Package name of the parent app. Must be equal to the package_name field on the Subscription resource."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        },
        "regionsVersion": {
          "$ref": "RegionsVersion",
          "description": "Required. The version of the available regions being used for the regional_price_migrations."
        },
        "productId": {
          "type": "string",
          "description": "Required. The ID of the subscription to update. Must be equal to the product_id field on the Subscription resource."
        }
      },
      "id": "MigrateBasePlanPricesRequest",
      "type": "object"
    },
    "DeviceMetadata": {
      "description": "Characteristics of the user's device.",
      "properties": {
        "screenHeightPx": {
          "description": "Screen height in pixels",
          "type": "integer",
          "format": "int32"
        },
        "glEsVersion": {
          "type": "integer",
          "format": "int32",
          "description": "OpenGL version"
        },
        "cpuMake": {
          "type": "string",
          "description": "Device CPU make, e.g. \"Qualcomm\""
        },
        "nativePlatform": {
          "description": "Comma separated list of native platforms (e.g. \"arm\", \"arm7\")",
          "type": "string"
        },
        "deviceClass": {
          "description": "Device class (e.g. tablet)",
          "type": "string"
        },
        "screenDensityDpi": {
          "description": "Screen density in DPI",
          "type": "integer",
          "format": "int32"
        },
        "manufacturer": {
          "type": "string",
          "description": "Device manufacturer (e.g. Motorola)"
        },
        "screenWidthPx": {
          "description": "Screen width in pixels",
          "type": "integer",
          "format": "int32"
        },
        "productName": {
          "type": "string",
          "description": "Device model name (e.g. Droid)"
        },
        "cpuModel": {
          "description": "Device CPU model, e.g. \"MSM8974\"",
          "type": "string"
        },
        "ramMb": {
          "type": "integer",
          "format": "int32",
          "description": "Device RAM in Megabytes, e.g. \"2048\""
        }
      },
      "id": "DeviceMetadata",
      "type": "object"
    },
    "OneTimeCode": {
      "description": "A single use promotion code.",
      "properties": {},
      "id": "OneTimeCode",
      "type": "object"
    },
    "VoidedPurchase": {
      "description": "A VoidedPurchase resource indicates a purchase that was either canceled/refunded/charged-back.",
      "properties": {
        "voidedReason": {
          "description": "The reason why the purchase was voided, possible values are: 0. Other 1. Remorse 2. Not_received 3. Defective 4. Accidental_purchase 5. Fraud 6. Friendly_fraud 7. Chargeback 8. Unacknowledged_purchase",
          "type": "integer",
          "format": "int32"
        },
        "voidedQuantity": {
          "type": "integer",
          "format": "int32",
          "description": "The voided quantity as the result of a quantity-based partial refund. Voided purchases of quantity-based partial refunds may only be returned when includeQuantityBasedPartialRefund is set to true."
        },
        "voidedSource": {
          "description": "The initiator of voided purchase, possible values are: 0. User 1. Developer 2. Google",
          "type": "integer",
          "format": "int32"
        },
        "kind": {
          "type": "string",
          "description": "This kind represents a voided purchase object in the androidpublisher service."
        },
        "orderId": {
          "description": "The order id which uniquely identifies a one-time purchase, subscription purchase, or subscription renewal.",
          "type": "string"
        },
        "purchaseToken": {
          "type": "string",
          "description": "The token which uniquely identifies a one-time purchase or subscription. To uniquely identify subscription renewals use order_id (available starting from version 3 of the API)."
        },
        "purchaseTimeMillis": {
          "description": "The time at which the purchase was made, in milliseconds since the epoch (Jan 1, 1970).",
          "type": "string",
          "format": "int64"
        },
        "voidedTimeMillis": {
          "description": "The time at which the purchase was canceled/refunded/charged-back, in milliseconds since the epoch (Jan 1, 1970).",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "VoidedPurchase",
      "type": "object"
    },
    "BatchUpdateSubscriptionOffersRequest": {
      "description": "Request message for BatchUpdateSubscriptionOffers.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdateSubscriptionOfferRequest"
          },
          "description": "Required. A list of update requests of up to 100 elements. All requests must update different subscription offers."
        }
      },
      "id": "BatchUpdateSubscriptionOffersRequest",
      "type": "object"
    },
    "Grant": {
      "description": "An access grant resource.",
      "properties": {
        "appLevelPermissions": {
          "description": "The permissions granted to the user for this app.",
          "type": "array",
          "items": {
            "enum": [
              "APP_LEVEL_PERMISSION_UNSPECIFIED",
              "CAN_ACCESS_APP",
              "CAN_VIEW_FINANCIAL_DATA",
              "CAN_MANAGE_PERMISSIONS",
              "CAN_REPLY_TO_REVIEWS",
              "CAN_MANAGE_PUBLIC_APKS",
              "CAN_MANAGE_TRACK_APKS",
              "CAN_MANAGE_TRACK_USERS",
              "CAN_MANAGE_PUBLIC_LISTING",
              "CAN_MANAGE_DRAFT_APPS",
              "CAN_MANAGE_ORDERS",
              "CAN_MANAGE_APP_CONTENT",
              "CAN_VIEW_NON_FINANCIAL_DATA",
              "CAN_VIEW_APP_QUALITY",
              "CAN_MANAGE_DEEPLINKS"
            ],
            "type": "string",
            "enumDescriptions": [
              "Unknown or unspecified permission.",
              "View app information (read-only). Deprecated: Try defining a more granular capability. Otherwise, check AppLevelPermission.CAN_VIEW_NON_FINANCIAL_DATA.",
              "View financial data.",
              "Admin (all permissions).",
              "Reply to reviews.",
              "Release to production, exclude devices, and use app signing by Google Play.",
              "Release to testing tracks.",
              "Manage testing tracks and edit tester lists.",
              "Manage store presence.",
              "Edit and delete draft apps.",
              "Manage orders and subscriptions.",
              "Manage policy related pages.",
              "View app information (read-only).",
              "View app quality data such as Vitals, Crashes etc.",
              "Manage the deep links setup of an app."
            ],
            "enumDeprecated": [
              false,
              true,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false
            ]
          }
        },
        "name": {
          "type": "string",
          "description": "Required. Resource name for this grant, following the pattern \"developers/{developer}/users/{email}/grants/{package_name}\". If this grant is for a draft app, the app ID will be used in this resource name instead of the package name."
        },
        "packageName": {
          "description": "Immutable. The package name of the app. This will be empty for draft apps.",
          "type": "string"
        }
      },
      "id": "Grant",
      "type": "object"
    },
    "Review": {
      "id": "Review",
      "type": "object",
      "description": "An Android app review.",
      "properties": {
        "reviewId": {
          "type": "string",
          "description": "Unique identifier for this review."
        },
        "authorName": {
          "description": "The name of the user who wrote the review.",
          "type": "string"
        },
        "comments": {
          "type": "array",
          "items": {
            "$ref": "Comment"
          },
          "description": "A repeated field containing comments for the review."
        }
      }
    },
    "ListDeviceTierConfigsResponse": {
      "description": "Response listing existing device tier configs.",
      "properties": {
        "deviceTierConfigs": {
          "type": "array",
          "items": {
            "$ref": "DeviceTierConfig"
          },
          "description": "Device tier configs created by the developer."
        },
        "nextPageToken": {
          "type": "string",
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages."
        }
      },
      "id": "ListDeviceTierConfigsResponse",
      "type": "object"
    },
    "SplitApkVariant": {
      "id": "SplitApkVariant",
      "type": "object",
      "description": "Variant is a group of APKs that covers a part of the device configuration space. APKs from multiple variants are never combined on one device.",
      "properties": {
        "apkSet": {
          "type": "array",
          "items": {
            "$ref": "ApkSet"
          },
          "description": "Set of APKs, one set per module."
        },
        "variantNumber": {
          "type": "integer",
          "format": "int32",
          "description": "Number of the variant, starting at 0 (unless overridden). A device will receive APKs from the first variant that matches the device configuration, with higher variant numbers having priority over lower variant numbers."
        },
        "targeting": {
          "description": "Variant-level targeting.",
          "$ref": "VariantTargeting"
        }
      }
    },
    "InappproductsBatchUpdateRequest": {
      "id": "InappproductsBatchUpdateRequest",
      "type": "object",
      "description": "Request to update or insert one or more in-app products.",
      "properties": {
        "requests": {
          "description": "Required. Individual update requests. At least one request is required. Can contain up to 100 requests. All requests must correspond to different in-app products.",
          "type": "array",
          "items": {
            "$ref": "InappproductsUpdateRequest"
          }
        }
      }
    },
    "Price": {
      "id": "Price",
      "type": "object",
      "description": "Definition of a price, i.e. currency and units.",
      "properties": {
        "priceMicros": {
          "type": "string",
          "description": "Price in 1/million of the currency base unit, represented as a string."
        },
        "currency": {
          "description": "3 letter Currency code, as defined by ISO 4217. See java/com/google/common/money/CurrencyCode.java",
          "type": "string"
        }
      }
    },
    "ItemReplacement": {
      "id": "ItemReplacement",
      "type": "object",
      "description": "Details about a subscription line item that is being replaced.",
      "properties": {
        "replacementMode": {
          "description": "The replacement mode applied during the purchase.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified replacement mode.",
            "The new plan will be prorated and credited from the old plan.",
            "The user will be charged a prorated price for the new plan.",
            "The new plan will replace the old one without prorating the time.",
            "The user will be charged the full price for the new plan.",
            "The old plan will be cancelled and the new plan will be effective after the old one expires.",
            "The plan will remain unchanged with this replacement."
          ],
          "enum": [
            "REPLACEMENT_MODE_UNSPECIFIED",
            "WITH_TIME_PRORATION",
            "CHARGE_PRORATED_PRICE",
            "WITHOUT_PRORATION",
            "CHARGE_FULL_PRICE",
            "DEFERRED",
            "KEEP_EXISTING"
          ]
        },
        "offerId": {
          "description": "The offer ID of the subscription line item being replaced, if applicable.",
          "type": "string"
        },
        "productId": {
          "description": "The product ID of the subscription line item being replaced.",
          "type": "string"
        },
        "basePlanId": {
          "type": "string",
          "description": "The base plan ID of the subscription line item being replaced."
        }
      }
    },
    "InappproductsBatchGetResponse": {
      "id": "InappproductsBatchGetResponse",
      "type": "object",
      "description": "Response message for BatchGetSubscriptions endpoint.",
      "properties": {
        "inappproduct": {
          "description": "The list of requested in-app products, in the same order as the request.",
          "type": "array",
          "items": {
            "$ref": "InAppProduct"
          }
        }
      }
    },
    "InappproductsDeleteRequest": {
      "id": "InappproductsDeleteRequest",
      "type": "object",
      "description": "Request to delete an in-app product.",
      "properties": {
        "sku": {
          "type": "string",
          "description": "Unique identifier for the in-app product."
        },
        "packageName": {
          "type": "string",
          "description": "Package name of the app."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this product update. Defaults to latency-sensitive."
        }
      }
    },
    "VanityCode": {
      "description": "A multiple use, predefined promotion code.",
      "properties": {
        "promotionCode": {
          "type": "string",
          "description": "The promotion code."
        }
      },
      "id": "VanityCode",
      "type": "object"
    },
    "AppEdit": {
      "description": "An app edit. The resource for EditsService.",
      "properties": {
        "id": {
          "description": "Output only. Identifier of the edit. Can be used in subsequent API calls.",
          "readOnly": true,
          "type": "string"
        },
        "expiryTimeSeconds": {
          "description": "Output only. The time (as seconds since Epoch) at which the edit will expire and will be no longer valid for use.",
          "readOnly": true,
          "type": "string"
        }
      },
      "id": "AppEdit",
      "type": "object"
    },
    "PointsDetails": {
      "description": "Details relating to any Play Points applied to an order.",
      "properties": {
        "pointsSpent": {
          "type": "string",
          "format": "int64",
          "description": "The number of Play Points applied in this order. E.g. for a 100 points for $2 coupon, this is 100. For coupon stacked with base offer, this is the total points spent across both."
        },
        "pointsDiscountRateMicros": {
          "description": "The percentage rate which the Play Points promotion reduces the cost by. E.g. for a 100 points for $2 coupon, this is 500,000. Since $2 has an estimate of 200 points, but the actual Points required, 100, is 50% of this, and 50% in micros is 500,000. Between 0 and 1,000,000.",
          "type": "string",
          "format": "int64"
        },
        "pointsOfferId": {
          "description": "ID unique to the play points offer in use for this order.",
          "type": "string"
        },
        "pointsCouponValue": {
          "$ref": "Money",
          "description": "The monetary value of a Play Points coupon. This is the discount the coupon provides, which may not be the total amount. Only set when Play Points coupons have been used. E.g. for a 100 points for $2 coupon, this is $2."
        }
      },
      "id": "PointsDetails",
      "type": "object"
    },
    "ReviewsListResponse": {
      "id": "ReviewsListResponse",
      "type": "object",
      "description": "Response listing reviews.",
      "properties": {
        "pageInfo": {
          "description": "Information about the current page.",
          "$ref": "PageInfo"
        },
        "reviews": {
          "description": "List of reviews.",
          "type": "array",
          "items": {
            "$ref": "Review"
          }
        },
        "tokenPagination": {
          "$ref": "TokenPagination",
          "description": "Pagination token, to handle a number of products that is over one page."
        }
      }
    },
    "AppDetails": {
      "id": "AppDetails",
      "type": "object",
      "description": "The app details. The resource for DetailsService.",
      "properties": {
        "defaultLanguage": {
          "type": "string",
          "description": "Default language code, in BCP 47 format (eg \"en-US\")."
        },
        "contactEmail": {
          "description": "The user-visible support email for this app.",
          "type": "string"
        },
        "contactWebsite": {
          "type": "string",
          "description": "The user-visible website for this app."
        },
        "contactPhone": {
          "type": "string",
          "description": "The user-visible support telephone number for this app."
        }
      }
    },
    "ImagesListResponse": {
      "description": "Response listing all images.",
      "properties": {
        "images": {
          "type": "array",
          "items": {
            "$ref": "Image"
          },
          "description": "All listed Images."
        }
      },
      "id": "ImagesListResponse",
      "type": "object"
    },
    "RegionsVersion": {
      "description": "The version of the available regions being used for the specified resource.",
      "properties": {
        "version": {
          "type": "string",
          "description": "Required. A string representing the version of available regions being used for the specified resource. Regional prices and latest supported version for the resource have to be specified according to the information published in [this article](https://support.google.com/googleplay/android-developer/answer/10532353). Each time the supported locations substantially change, the version will be incremented. Using this field will ensure that creating and updating the resource with an older region's version and set of regional prices and currencies will succeed even though a new version is available."
        }
      },
      "id": "RegionsVersion",
      "type": "object"
    },
    "ReviewsReplyRequest": {
      "id": "ReviewsReplyRequest",
      "type": "object",
      "description": "Request to reply to review or update existing reply.",
      "properties": {
        "replyText": {
          "description": "The text to set as the reply. Replies of more than approximately 350 characters will be rejected. HTML tags will be stripped.",
          "type": "string"
        }
      }
    },
    "RemoteInAppUpdateData": {
      "description": "Data related to Remote In-App Update action such as recovered user count, affected user count etc.",
      "properties": {
        "remoteAppUpdateDataPerBundle": {
          "description": "Data related to the recovery action at bundle level.",
          "type": "array",
          "items": {
            "$ref": "RemoteInAppUpdateDataPerBundle"
          }
        }
      },
      "id": "RemoteInAppUpdateData",
      "type": "object"
    },
    "ApkSet": {
      "description": "A set of apks representing a module.",
      "properties": {
        "apkDescription": {
          "type": "array",
          "items": {
            "$ref": "ApkDescription"
          },
          "description": "Description of the generated apks."
        },
        "moduleMetadata": {
          "description": "Metadata about the module represented by this ApkSet",
          "$ref": "ModuleMetadata"
        }
      },
      "id": "ApkSet",
      "type": "object"
    },
    "UpdatePurchaseOptionStateRequest": {
      "id": "UpdatePurchaseOptionStateRequest",
      "type": "object",
      "description": "Request message to update the state of a one-time product purchase option.",
      "properties": {
        "activatePurchaseOptionRequest": {
          "$ref": "ActivatePurchaseOptionRequest",
          "description": "Activates a purchase option. Once activated, the purchase option will be available."
        },
        "deactivatePurchaseOptionRequest": {
          "description": "Deactivates a purchase option. Once deactivated, the purchase option will become unavailable.",
          "$ref": "DeactivatePurchaseOptionRequest"
        }
      }
    },
    "PageInfo": {
      "id": "PageInfo",
      "type": "object",
      "description": "Information about the current page. List operations that supports paging return only one \"page\" of results. This protocol buffer message describes the page that has been returned.",
      "properties": {
        "totalResults": {
          "type": "integer",
          "format": "int32",
          "description": "Total number of results available on the backend ! The total number of results in the result set."
        },
        "resultPerPage": {
          "type": "integer",
          "format": "int32",
          "description": "Maximum number of results returned in one page. ! The number of results included in the API response."
        },
        "startIndex": {
          "description": "Index of the first result returned in the current page.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "Bundle": {
      "id": "Bundle",
      "type": "object",
      "description": "Information about an app bundle. The resource for BundlesService.",
      "properties": {
        "versionCode": {
          "description": "The version code of the Android App Bundle, as specified in the Android App Bundle's base module APK manifest file.",
          "type": "integer",
          "format": "int32"
        },
        "sha1": {
          "description": "A sha1 hash of the upload payload, encoded as a hex string and matching the output of the sha1sum command.",
          "type": "string"
        },
        "sha256": {
          "type": "string",
          "description": "A sha256 hash of the upload payload, encoded as a hex string and matching the output of the sha256sum command."
        }
      }
    },
    "CancelAppRecoveryResponse": {
      "description": "Response message for CancelAppRecovery.",
      "properties": {},
      "id": "CancelAppRecoveryResponse",
      "type": "object"
    },
    "OfferDetails": {
      "description": "Offer details information related to a purchase line item.",
      "properties": {
        "offerId": {
          "description": "The offer ID. Only present for discounted offers.",
          "type": "string"
        },
        "offerTags": {
          "description": "The latest offer tags associated with the offer. It includes tags inherited from the base plan.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "basePlanId": {
          "type": "string",
          "description": "The base plan ID. Present for all base plan and offers."
        }
      },
      "id": "OfferDetails",
      "type": "object"
    },
    "AddTargetingRequest": {
      "id": "AddTargetingRequest",
      "type": "object",
      "description": "Request message for AddTargeting.",
      "properties": {
        "targetingUpdate": {
          "$ref": "TargetingUpdate",
          "description": "Specifies targeting updates such as regions, android sdk versions etc."
        }
      }
    },
    "RegionalTaxRateInfo": {
      "description": "Specified details about taxation in a given geographical region.",
      "properties": {
        "taxTier": {
          "enum": [
            "TAX_TIER_UNSPECIFIED",
            "TAX_TIER_BOOKS_1",
            "TAX_TIER_NEWS_1",
            "TAX_TIER_NEWS_2",
            "TAX_TIER_MUSIC_OR_AUDIO_1",
            "TAX_TIER_LIVE_OR_BROADCAST_1"
          ],
          "description": "Tax tier to specify reduced tax rate. Developers who sell digital news, magazines, newspapers, books, or audiobooks in various regions may be eligible for reduced tax rates. [Learn more](https://support.google.com/googleplay/android-developer/answer/10463498).",
          "type": "string",
          "enumDescriptions": [
            "",
            "",
            "",
            "",
            "",
            ""
          ]
        },
        "eligibleForStreamingServiceTaxRate": {
          "type": "boolean",
          "description": "You must tell us if your app contains streaming products to correctly charge US state and local sales tax. Field only supported in the United States."
        },
        "streamingTaxType": {
          "description": "To collect communications or amusement taxes in the United States, choose the appropriate tax category. [Learn more](https://support.google.com/googleplay/android-developer/answer/10463498#streaming_tax).",
          "type": "string",
          "enumDescriptions": [
            "No telecommunications tax collected.",
            "US-specific telecommunications tax tier for video streaming, on demand, rentals / subscriptions / pay-per-view.",
            "US-specific telecommunications tax tier for video streaming of pre-recorded content like movies, tv shows.",
            "US-specific telecommunications tax tier for video streaming of multi-channel programming.",
            "US-specific telecommunications tax tier for audio streaming, rental / subscription.",
            "US-specific telecommunications tax tier for audio streaming, sale / permanent download.",
            "US-specific telecommunications tax tier for multi channel audio streaming like radio."
          ],
          "enum": [
            "STREAMING_TAX_TYPE_UNSPECIFIED",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_RENTAL",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_SALES",
            "STREAMING_TAX_TYPE_TELCO_VIDEO_MULTI_CHANNEL",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_RENTAL",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_SALES",
            "STREAMING_TAX_TYPE_TELCO_AUDIO_MULTI_CHANNEL"
          ]
        }
      },
      "id": "RegionalTaxRateInfo",
      "type": "object"
    },
    "TestPurchase": {
      "description": "Whether this subscription purchase is a test purchase.",
      "properties": {},
      "id": "TestPurchase",
      "type": "object"
    },
    "RegionalPriceMigrationConfig": {
      "id": "RegionalPriceMigrationConfig",
      "type": "object",
      "description": "Configuration for migration of a legacy price cohort.",
      "properties": {
        "oldestAllowedPriceVersionTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "Required. Subscribers in all legacy price cohorts before this time will be migrated to the current price. Subscribers in any newer price cohorts are unaffected. Affected subscribers will receive one or more notifications from Google Play about the price change. Price decreases occur at the subscriber's next billing date. Price increases occur at the subscriber's next billing date following a notification period that varies by region and price increase type."
        },
        "regionCode": {
          "description": "Required. Region code this configuration applies to, as defined by ISO 3166-2, e.g. \"US\".",
          "type": "string"
        },
        "priceIncreaseType": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified state.",
            "Subscribers must accept the price increase or their subscription is canceled.",
            "Subscribers are notified but do not have to accept the price increase. Opt-out price increases not meeting regional, frequency, and amount limits will proceed as opt-in price increase. The first opt-out price increase for each app must be initiated in the Google Play Console."
          ],
          "description": "Optional. The requested type of price increase",
          "enum": [
            "PRICE_INCREASE_TYPE_UNSPECIFIED",
            "PRICE_INCREASE_TYPE_OPT_IN",
            "PRICE_INCREASE_TYPE_OPT_OUT"
          ]
        }
      }
    },
    "RefundExternalTransactionRequest": {
      "id": "RefundExternalTransactionRequest",
      "type": "object",
      "description": "A request to refund an existing external transaction.",
      "properties": {
        "refundTime": {
          "description": "Required. The time that the transaction was refunded.",
          "type": "string",
          "format": "google-datetime"
        },
        "partialRefund": {
          "$ref": "PartialRefund",
          "description": "A partial refund."
        },
        "fullRefund": {
          "$ref": "FullRefund",
          "description": "A full-amount refund."
        }
      }
    },
    "ProrationPeriodOfferPhase": {
      "id": "ProrationPeriodOfferPhase",
      "type": "object",
      "description": "Details about proration period offer phase.",
      "properties": {
        "originalOfferPhaseType": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified original offer phase type.",
            "The subscription is in the base pricing phase (e.g. full price).",
            "The subscription is in an introductory pricing phase.",
            "The subscription is in a free trial."
          ],
          "description": "The original offer phase type before the proration period. Only set when the proration period is updated from an existing offer phase.",
          "enum": [
            "ORIGINAL_OFFER_PHASE_TYPE_UNSPECIFIED",
            "BASE",
            "INTRODUCTORY",
            "FREE_TRIAL"
          ]
        }
      }
    },
    "ConvertedOtherRegionsPrice": {
      "id": "ConvertedOtherRegionsPrice",
      "type": "object",
      "description": "Converted other regions prices.",
      "properties": {
        "eurPrice": {
          "$ref": "Money",
          "description": "Price in EUR to use for the \"Other regions\" location exclusive of taxes."
        },
        "usdPrice": {
          "description": "Price in USD to use for the \"Other regions\" location exclusive of taxes.",
          "$ref": "Money"
        }
      }
    },
    "UpdateBasePlanStateRequest": {
      "description": "Request message to update the state of a subscription base plan.",
      "properties": {
        "activateBasePlanRequest": {
          "$ref": "ActivateBasePlanRequest",
          "description": "Activates a base plan. Once activated, base plans will be available to new subscribers."
        },
        "deactivateBasePlanRequest": {
          "$ref": "DeactivateBasePlanRequest",
          "description": "Deactivates a base plan. Once deactivated, the base plan will become unavailable to new subscribers, but existing subscribers will maintain their subscription"
        }
      },
      "id": "UpdateBasePlanStateRequest",
      "type": "object"
    },
    "RentalDetails": {
      "description": "Details of a rental purchase.",
      "properties": {},
      "id": "RentalDetails",
      "type": "object"
    },
    "TextureCompressionFormatTargeting": {
      "id": "TextureCompressionFormatTargeting",
      "type": "object",
      "description": "Targeting by a texture compression format.",
      "properties": {
        "value": {
          "description": "The list of targeted TCFs. Should not be empty.",
          "type": "array",
          "items": {
            "$ref": "TextureCompressionFormat"
          }
        },
        "alternatives": {
          "description": "List of alternative TCFs (TCFs targeted by the sibling splits).",
          "type": "array",
          "items": {
            "$ref": "TextureCompressionFormat"
          }
        }
      }
    },
    "AppVersionList": {
      "id": "AppVersionList",
      "type": "object",
      "description": "Data format for a list of app versions.",
      "properties": {
        "versionCodes": {
          "description": "List of app version codes.",
          "type": "array",
          "items": {
            "type": "string",
            "format": "int64"
          }
        }
      }
    },
    "ScreenDensity": {
      "description": "Represents a screen density.",
      "properties": {
        "densityAlias": {
          "enum": [
            "DENSITY_UNSPECIFIED",
            "NODPI",
            "LDPI",
            "MDPI",
            "TVDPI",
            "HDPI",
            "XHDPI",
            "XXHDPI",
            "XXXHDPI"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified screen density.",
            "NODPI screen density.",
            "LDPI screen density.",
            "MDPI screen density.",
            "TVDPI screen density.",
            "HDPI screen density.",
            "XHDPI screen density.",
            "XXHDPI screen density.",
            "XXXHDPI screen density."
          ],
          "description": "Alias for a screen density."
        },
        "densityDpi": {
          "description": "Value for density dpi.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "ScreenDensity",
      "type": "object"
    },
    "ProductOfferDetails": {
      "description": "Offer details information related to a purchase line item.",
      "properties": {
        "offerTags": {
          "description": "The latest offer tags associated with the offer. It includes tags inherited from the purchase option.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "preorderOfferDetails": {
          "description": "Offer details for a preorder offer. This will only be set for preorders.",
          "$ref": "PreorderOfferDetails"
        },
        "offerId": {
          "type": "string",
          "description": "The offer ID. Only present for offers."
        },
        "offerToken": {
          "type": "string",
          "description": "The per-transaction offer token used to make this purchase line item."
        },
        "purchaseOptionId": {
          "type": "string",
          "description": "The purchase option ID."
        },
        "quantity": {
          "type": "integer",
          "format": "int32",
          "description": "The quantity associated with the purchase of the inapp product."
        },
        "rentOfferDetails": {
          "description": "Offer details about rent offers. This will only be set for rental line items.",
          "$ref": "RentOfferDetails"
        },
        "refundableQuantity": {
          "description": "The quantity eligible for refund, i.e. quantity that hasn't been refunded. The value reflects quantity-based partial refunds and full refunds.",
          "type": "integer",
          "format": "int32"
        },
        "consumptionState": {
          "type": "string",
          "enum": [
            "CONSUMPTION_STATE_UNSPECIFIED",
            "CONSUMPTION_STATE_YET_TO_BE_CONSUMED",
            "CONSUMPTION_STATE_CONSUMED"
          ],
          "description": "Output only. The consumption state of the purchase.",
          "readOnly": true,
          "enumDescriptions": [
            "Consumption state unspecified. This value should never be set.",
            "Yet to be consumed.",
            "Consumed already."
          ]
        }
      },
      "id": "ProductOfferDetails",
      "type": "object"
    },
    "Apk": {
      "description": "Information about an APK. The resource for ApksService.",
      "properties": {
        "binary": {
          "description": "Information about the binary payload of this APK.",
          "$ref": "ApkBinary"
        },
        "versionCode": {
          "description": "The version code of the APK, as specified in the manifest file.",
          "type": "integer",
          "format": "int32"
        }
      },
      "id": "Apk",
      "type": "object"
    },
    "AssetModuleMetadata": {
      "id": "AssetModuleMetadata",
      "type": "object",
      "description": "Metadata of an asset module.",
      "properties": {
        "name": {
          "description": "Module name.",
          "type": "string"
        },
        "deliveryType": {
          "description": "Indicates the delivery type for persistent install.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified delivery type.",
            "This module will always be downloaded as part of the initial install of the app.",
            "This module is requested on-demand, which means it will not be part of the initial install, and will only be sent when requested by the client.",
            "This module will be downloaded immediately after initial install finishes. The app can be opened before these modules are downloaded."
          ],
          "enum": [
            "UNKNOWN_DELIVERY_TYPE",
            "INSTALL_TIME",
            "ON_DEMAND",
            "FAST_FOLLOW"
          ]
        }
      }
    },
    "InappproductsBatchUpdateResponse": {
      "description": "Response for a batch in-app product update.",
      "properties": {
        "inappproducts": {
          "description": "The updated or inserted in-app products.",
          "type": "array",
          "items": {
            "$ref": "InAppProduct"
          }
        }
      },
      "id": "InappproductsBatchUpdateResponse",
      "type": "object"
    },
    "AbiTargeting": {
      "id": "AbiTargeting",
      "type": "object",
      "description": "Targeting based on Abi.",
      "properties": {
        "value": {
          "type": "array",
          "items": {
            "$ref": "Abi"
          },
          "description": "Value of an abi."
        },
        "alternatives": {
          "type": "array",
          "items": {
            "$ref": "Abi"
          },
          "description": "Targeting of other sibling directories that were in the Bundle. For main splits this is targeting of other main splits."
        }
      }
    },
    "PartialRefund": {
      "id": "PartialRefund",
      "type": "object",
      "description": "A partial refund of a transaction.",
      "properties": {
        "refundId": {
          "description": "Required. A unique id distinguishing this partial refund. If the refund is successful, subsequent refunds with the same id will fail. Must be unique across refunds for one individual transaction.",
          "type": "string"
        },
        "refundPreTaxAmount": {
          "description": "Required. The pre-tax amount of the partial refund. Should be less than the remaining pre-tax amount of the transaction.",
          "$ref": "Price"
        }
      }
    },
    "UsesPermission": {
      "id": "UsesPermission",
      "type": "object",
      "description": "A permission used by this APK.",
      "properties": {
        "name": {
          "type": "string",
          "description": "The name of the permission requested."
        },
        "maxSdkVersion": {
          "type": "integer",
          "format": "int32",
          "description": "Optionally, the maximum SDK version for which the permission is required."
        }
      }
    },
    "IntroductoryPriceDetails": {
      "id": "IntroductoryPriceDetails",
      "type": "object",
      "description": "Details of an introductory price pricing phase.",
      "properties": {}
    },
    "RegionalSubscriptionOfferPhaseFreePriceOverride": {
      "description": "Represents the free price override configuration for a single phase of a subscription offer",
      "properties": {},
      "id": "RegionalSubscriptionOfferPhaseFreePriceOverride",
      "type": "object"
    },
    "OneTimeProductPurchaseOption": {
      "id": "OneTimeProductPurchaseOption",
      "type": "object",
      "description": "A single purchase option for a one-time product.",
      "properties": {
        "buyOption": {
          "description": "A purchase option that can be bought.",
          "$ref": "OneTimeProductBuyPurchaseOption"
        },
        "purchaseOptionId": {
          "type": "string",
          "description": "Required. Immutable. The unique identifier of this purchase option. Must be unique within the one-time product. It must start with a number or lower-case letter, and can only contain lower-case letters (a-z), numbers (0-9), and hyphens (-). The maximum length is 63 characters."
        },
        "rentOption": {
          "description": "A purchase option that can be rented.",
          "$ref": "OneTimeProductRentPurchaseOption"
        },
        "offerTags": {
          "type": "array",
          "items": {
            "$ref": "OfferTag"
          },
          "description": "Optional. List of up to 20 custom tags specified for this purchase option, and returned to the app through the billing library. Offers for this purchase option will also receive these tags in the billing library."
        },
        "newRegionsConfig": {
          "$ref": "OneTimeProductPurchaseOptionNewRegionsConfig",
          "description": "Pricing information for any new locations Play may launch in the future. If omitted, the purchase option will not be automatically available in any new locations Play may launch in the future."
        },
        "state": {
          "enum": [
            "STATE_UNSPECIFIED",
            "DRAFT",
            "ACTIVE",
            "INACTIVE",
            "INACTIVE_PUBLISHED"
          ],
          "readOnly": true,
          "enumDescriptions": [
            "Default value, should never be used.",
            "The purchase option is not and has never been available to users.",
            "The purchase option is available to users.",
            "The purchase option is not available to users anymore.",
            "The purchase option is not available for purchase anymore, but we continue to expose its offer via the Play Billing Library for backwards compatibility. Only automatically migrated purchase options can be in this state."
          ],
          "description": "Output only. The state of the purchase option, i.e., whether it's active. This field cannot be changed by updating the resource. Use the dedicated endpoints instead.",
          "type": "string"
        },
        "regionalPricingAndAvailabilityConfigs": {
          "description": "Regional pricing and availability information for this purchase option.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProductPurchaseOptionRegionalPricingAndAvailabilityConfig"
          }
        },
        "taxAndComplianceSettings": {
          "$ref": "PurchaseOptionTaxAndComplianceSettings",
          "description": "Optional. Details about taxes and legal compliance."
        }
      }
    },
    "SystemOnChip": {
      "id": "SystemOnChip",
      "type": "object",
      "description": "Representation of a System-on-Chip (SoC) of an Android device. Can be used to target S+ devices.",
      "properties": {
        "manufacturer": {
          "description": "Required. The designer of the SoC, eg. \"Google\" Value of build property \"ro.soc.manufacturer\" https://developer.android.com/reference/android/os/Build#SOC_MANUFACTURER Required.",
          "type": "string"
        },
        "model": {
          "description": "Required. The model of the SoC, eg. \"Tensor\" Value of build property \"ro.soc.model\" https://developer.android.com/reference/android/os/Build#SOC_MODEL Required.",
          "type": "string"
        }
      }
    },
    "ApkDescription": {
      "id": "ApkDescription",
      "type": "object",
      "description": "Description of the created apks.",
      "properties": {
        "splitApkMetadata": {
          "$ref": "SplitApkMetadata",
          "description": "Set only for Split APKs."
        },
        "standaloneApkMetadata": {
          "description": "Set only for standalone APKs.",
          "$ref": "StandaloneApkMetadata"
        },
        "instantApkMetadata": {
          "description": "Set only for Instant split APKs.",
          "$ref": "SplitApkMetadata"
        },
        "targeting": {
          "description": "Apk-level targeting.",
          "$ref": "ApkTargeting"
        },
        "path": {
          "type": "string",
          "description": "Path of the Apk, will be in the following format: .apk where DownloadId is the ID used to download the apk using GeneratedApks.Download API."
        },
        "assetSliceMetadata": {
          "description": "Set only for asset slices.",
          "$ref": "SplitApkMetadata"
        }
      }
    },
    "CancellationContext": {
      "id": "CancellationContext",
      "type": "object",
      "description": "Cancellation context of the purchases.subscriptionsv2.cancel API.",
      "properties": {
        "cancellationType": {
          "description": "Required. The type of cancellation for the purchased subscription.",
          "type": "string",
          "enumDescriptions": [
            "Cancellation type unspecified.",
            "Cancellation requested by the user, and the subscription can be restored. It only stops the subscription's next renewal. For an installment subscription, users still need to finish the commitment period. For more details on renewals and payments, see https://developer.android.com/google/play/billing/subscriptions#installments",
            "Cancellation requested by the developer, and the subscription cannot be restored. It stops the subscription's next payment. For an installment subscription, users will not need to pay the next payment and finish the commitment period. For more details on renewals and payments, see https://developer.android.com/google/play/billing/subscriptions#installments"
          ],
          "enum": [
            "CANCELLATION_TYPE_UNSPECIFIED",
            "USER_REQUESTED_STOP_RENEWALS",
            "DEVELOPER_REQUESTED_STOP_PAYMENTS"
          ]
        }
      }
    },
    "AddTargetingResponse": {
      "description": "Response message for AddTargeting.",
      "properties": {},
      "id": "AddTargetingResponse",
      "type": "object"
    },
    "RecurringExternalTransaction": {
      "id": "RecurringExternalTransaction",
      "type": "object",
      "description": "Represents a transaction that is part of a recurring series of payments. This can be a subscription or a one-time product with multiple payments (such as preorder).",
      "properties": {
        "externalTransactionToken": {
          "type": "string",
          "description": "Input only. Provided during the call to Create. Retrieved from the client when the alternative billing flow is launched. Required only for the initial purchase."
        },
        "migratedTransactionProgram": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified transaction program. Not used.",
            "User choice billing, where a user may choose between Google Play Billing developer-managed billing.",
            "Alternative billing only, where users may only use developer-manager billing."
          ],
          "description": "Input only. Provided during the call to Create. Must only be used when migrating a subscription from manual monthly reporting to automated reporting.",
          "enum": [
            "EXTERNAL_TRANSACTION_PROGRAM_UNSPECIFIED",
            "USER_CHOICE_BILLING",
            "ALTERNATIVE_BILLING_ONLY"
          ]
        },
        "externalSubscription": {
          "description": "Details of an external subscription.",
          "$ref": "ExternalSubscription"
        },
        "initialExternalTransactionId": {
          "description": "The external transaction id of the first transaction of this recurring series of transactions. For example, for a subscription this would be the transaction id of the first payment. Required when creating recurring external transactions.",
          "type": "string"
        },
        "otherRecurringProduct": {
          "description": "Details of a recurring external transaction product which doesn't belong to any other specific category.",
          "$ref": "OtherRecurringProduct"
        }
      }
    },
    "DeferSubscriptionPurchaseResponse": {
      "description": "Response for the v2 purchases.subscriptions.defer API.",
      "properties": {
        "itemExpiryTimeDetails": {
          "description": "The new expiry time for each subscription items.",
          "type": "array",
          "items": {
            "$ref": "ItemExpiryTimeDetails"
          }
        }
      },
      "id": "DeferSubscriptionPurchaseResponse",
      "type": "object"
    },
    "CanceledStateContext": {
      "id": "CanceledStateContext",
      "type": "object",
      "description": "Information specific to a subscription in the SUBSCRIPTION_STATE_CANCELED or SUBSCRIPTION_STATE_EXPIRED state.",
      "properties": {
        "systemInitiatedCancellation": {
          "description": "Subscription was canceled by the system, for example because of a billing problem.",
          "$ref": "SystemInitiatedCancellation"
        },
        "userInitiatedCancellation": {
          "description": "Subscription was canceled by user.",
          "$ref": "UserInitiatedCancellation"
        },
        "developerInitiatedCancellation": {
          "description": "Subscription was canceled by the developer.",
          "$ref": "DeveloperInitiatedCancellation"
        },
        "replacementCancellation": {
          "description": "Subscription was replaced by a new subscription.",
          "$ref": "ReplacementCancellation"
        }
      }
    },
    "ApkBinary": {
      "id": "ApkBinary",
      "type": "object",
      "description": "Represents the binary payload of an APK.",
      "properties": {
        "sha1": {
          "type": "string",
          "description": "A sha1 hash of the APK payload, encoded as a hex string and matching the output of the sha1sum command."
        },
        "sha256": {
          "type": "string",
          "description": "A sha256 hash of the APK payload, encoded as a hex string and matching the output of the sha256sum command."
        }
      }
    },
    "BatchUpdateOneTimeProductOffersResponse": {
      "id": "BatchUpdateOneTimeProductOffersResponse",
      "type": "object",
      "description": "Response message for BatchUpdateOneTimeProductOffers.",
      "properties": {
        "oneTimeProductOffers": {
          "description": "The list of updated one-time product offers, in the same order as the request.",
          "type": "array",
          "items": {
            "$ref": "OneTimeProductOffer"
          }
        }
      }
    },
    "ModuleMetadata": {
      "id": "ModuleMetadata",
      "type": "object",
      "description": "Metadata of a module.",
      "properties": {
        "name": {
          "description": "Module name.",
          "type": "string"
        },
        "moduleType": {
          "description": "Indicates the type of this feature module.",
          "type": "string",
          "enumDescriptions": [
            "Unknown feature module.",
            "Regular feature module."
          ],
          "enum": [
            "UNKNOWN_MODULE_TYPE",
            "FEATURE_MODULE"
          ]
        },
        "deliveryType": {
          "enum": [
            "UNKNOWN_DELIVERY_TYPE",
            "INSTALL_TIME",
            "ON_DEMAND",
            "FAST_FOLLOW"
          ],
          "description": "Indicates the delivery type (e.g. on-demand) of the module.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified delivery type.",
            "This module will always be downloaded as part of the initial install of the app.",
            "This module is requested on-demand, which means it will not be part of the initial install, and will only be sent when requested by the client.",
            "This module will be downloaded immediately after initial install finishes. The app can be opened before these modules are downloaded."
          ]
        },
        "dependencies": {
          "description": "Names of the modules that this module directly depends on. Each module implicitly depends on the base module.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "targeting": {
          "description": "The targeting that makes a conditional module installed. Relevant only for Split APKs.",
          "$ref": "ModuleTargeting"
        }
      }
    },
    "UserCountriesTargeting": {
      "id": "UserCountriesTargeting",
      "type": "object",
      "description": "Describes an inclusive/exclusive list of country codes that module targets.",
      "properties": {
        "countryCodes": {
          "type": "array",
          "items": {
            "type": "string"
          },
          "description": "List of country codes in the two-letter CLDR territory format."
        },
        "exclude": {
          "description": "Indicates if the list above is exclusive.",
          "type": "boolean"
        }
      }
    },
    "ActivateOneTimeProductOfferRequest": {
      "id": "ActivateOneTimeProductOfferRequest",
      "type": "object",
      "description": "Request message for ActivateOneTimeProductOffer.",
      "properties": {
        "productId": {
          "description": "Required. The parent one-time product (ID) of the offer to activate.",
          "type": "string"
        },
        "purchaseOptionId": {
          "type": "string",
          "description": "Required. The parent purchase option (ID) of the offer to activate."
        },
        "packageName": {
          "type": "string",
          "description": "Required. The parent app (package name) of the offer to activate."
        },
        "latencyTolerance": {
          "enum": [
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_UNSPECIFIED",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE",
            "PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_TOLERANT"
          ],
          "type": "string",
          "enumDescriptions": [
            "Defaults to PRODUCT_UPDATE_LATENCY_TOLERANCE_LATENCY_SENSITIVE.",
            "The update will propagate to clients within several minutes on average and up to a few hours in rare cases. Throughput is limited to 7,200 updates per app per hour.",
            "The update will propagate to clients within 24 hours. Supports high throughput of up to 720,000 updates per app per hour using batch modification methods."
          ],
          "description": "Optional. The latency tolerance for the propagation of this update. Defaults to latency-sensitive."
        },
        "offerId": {
          "description": "Required. The offer ID of the offer to activate.",
          "type": "string"
        }
      }
    },
    "GeneratedApksListResponse": {
      "id": "GeneratedApksListResponse",
      "type": "object",
      "description": "Response to list generated APKs.",
      "properties": {
        "generatedApks": {
          "description": "All generated APKs, grouped by the APK signing key.",
          "type": "array",
          "items": {
            "$ref": "GeneratedApksPerSigningKey"
          }
        }
      }
    },
    "UpdateOneTimeProductOfferStateRequest": {
      "description": "Request message to update the state of a one-time product offer.",
      "properties": {
        "deactivateOneTimeProductOfferRequest": {
          "$ref": "DeactivateOneTimeProductOfferRequest",
          "description": "Deactivates an offer. Once deactivated, the offer is no longer available to users. This state transition is specific to discounted offers."
        },
        "activateOneTimeProductOfferRequest": {
          "$ref": "ActivateOneTimeProductOfferRequest",
          "description": "Activates an offer. Once activated, the offer is available to users, as long as its conditions are met."
        },
        "cancelOneTimeProductOfferRequest": {
          "$ref": "CancelOneTimeProductOfferRequest",
          "description": "Cancels an offer. Once cancelled, the offer is not available to users. Any pending orders related to this offer will be cancelled. This state transition is specific to pre-orders."
        }
      },
      "id": "UpdateOneTimeProductOfferStateRequest",
      "type": "object"
    },
    "BatchUpdateSubscriptionsRequest": {
      "id": "BatchUpdateSubscriptionsRequest",
      "type": "object",
      "description": "Request message for BatchUpdateSubscription.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "UpdateSubscriptionRequest"
          },
          "description": "Required. A list of update requests of up to 100 elements. All requests must update different subscriptions."
        }
      }
    },
    "ExternalAccountIds": {
      "id": "ExternalAccountIds",
      "type": "object",
      "description": "User account identifier in your app.",
      "properties": {
        "obfuscatedAccountId": {
          "description": "Optional. Specifies an optional obfuscated string that is uniquely associated with the purchaser's user account in your app. If you pass this value, Google Play can use it to detect irregular activity. Do not use this field to store any Personally Identifiable Information (PII) such as emails in cleartext. Attempting to store PII in this field will result in purchases being blocked. Google Play recommends that you use either encryption or a one-way hash to generate an obfuscated identifier to send to Google Play. This identifier is limited to 64 characters. This field can only be set for resubscription purchases. See https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedaccountid to set this field for purchases made using the standard in-app billing flow.",
          "type": "string"
        },
        "obfuscatedProfileId": {
          "description": "Optional. Specifies an optional obfuscated string that is uniquely associated with the purchaser's user profile in your app. If you pass this value, Google Play can use it to detect irregular activity. Do not use this field to store any Personally Identifiable Information (PII) such as emails in cleartext. Attempting to store PII in this field will result in purchases being blocked. Google Play recommends that you use either encryption or a one-way hash to generate an obfuscated identifier to send to Google Play. This identifier is limited to 64 characters. This field can only be set for resubscription purchases. See https://developer.android.com/reference/com/android/billingclient/api/BillingFlowParams.Builder#setobfuscatedprofileid to set this field for purchases made using the standard in-app billing flow.",
          "type": "string"
        }
      }
    },
    "MigrateBasePlanPricesResponse": {
      "description": "Response message for MigrateBasePlanPrices.",
      "properties": {},
      "id": "MigrateBasePlanPricesResponse",
      "type": "object"
    },
    "OneTimeProductTaxAndComplianceSettings": {
      "id": "OneTimeProductTaxAndComplianceSettings",
      "type": "object",
      "description": "Details about taxation, Google Play policy and legal compliance for one-time products.",
      "properties": {
        "productTaxCategoryCode": {
          "description": "Product tax category code to assign to the one-time product. Product tax category determines the transaction tax rates applied to the product. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/16408159) for more information.",
          "type": "string"
        },
        "isTokenizedDigitalAsset": {
          "type": "boolean",
          "description": "Whether this one-time product is declared as a product representing a tokenized digital asset."
        },
        "regionalProductAgeRatingInfos": {
          "description": "Regional age rating information. Currently this field is only supported for region code `US`.",
          "type": "array",
          "items": {
            "$ref": "RegionalProductAgeRatingInfo"
          }
        },
        "regionalTaxConfigs": {
          "description": "Regional tax configuration.",
          "type": "array",
          "items": {
            "$ref": "RegionalTaxConfig"
          }
        }
      }
    },
    "OneTimeProductDiscountedOffer": {
      "description": "Configuration specific to discounted offers.",
      "properties": {
        "redemptionLimit": {
          "type": "string",
          "format": "int64",
          "description": "Optional. The number of times this offer can be redeemed. If unset or set to 0, allows for unlimited offer redemptions. Otherwise must be a number between 1 and 50 inclusive."
        },
        "startTime": {
          "description": "Time when the offer will start being available.",
          "type": "string",
          "format": "google-datetime"
        },
        "endTime": {
          "description": "Time when the offer will stop being available.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "id": "OneTimeProductDiscountedOffer",
      "type": "object"
    },
    "OtherRegionsBasePlanConfig": {
      "description": "Pricing information for any new locations Play may launch in.",
      "properties": {
        "usdPrice": {
          "description": "Required. Price in USD to use for any new locations Play may launch in.",
          "$ref": "Money"
        },
        "eurPrice": {
          "description": "Required. Price in EUR to use for any new locations Play may launch in.",
          "$ref": "Money"
        },
        "newSubscriberAvailability": {
          "type": "boolean",
          "description": "Whether the base plan is available for new subscribers in any new locations Play may launch in. If not specified, this will default to false."
        }
      },
      "id": "OtherRegionsBasePlanConfig",
      "type": "object"
    },
    "BatchUpdateBasePlanStatesResponse": {
      "id": "BatchUpdateBasePlanStatesResponse",
      "type": "object",
      "description": "Response message for BatchUpdateBasePlanStates.",
      "properties": {
        "subscriptions": {
          "description": "The list of updated subscriptions. This list will match the requests one to one, in the same order.",
          "type": "array",
          "items": {
            "$ref": "Subscription"
          }
        }
      }
    },
    "SplitApkMetadata": {
      "id": "SplitApkMetadata",
      "type": "object",
      "description": "Holds data specific to Split APKs.",
      "properties": {
        "splitId": {
          "type": "string",
          "description": "Id of the split."
        },
        "isMasterSplit": {
          "description": "Indicates whether this APK is the main split of the module.",
          "type": "boolean"
        }
      }
    },
    "PurchaseOptionTaxAndComplianceSettings": {
      "id": "PurchaseOptionTaxAndComplianceSettings",
      "type": "object",
      "description": "Details about taxation, Google Play policy and legal compliance for one-time product purchase options.",
      "properties": {
        "withdrawalRightType": {
          "description": "Optional. Digital content or service classification for products distributed to users in eligible regions. If unset, it defaults to `WITHDRAWAL_RIGHT_DIGITAL_CONTENT`. Refer to the [Help Center article](https://support.google.com/googleplay/android-developer/answer/10463498) for more information.",
          "type": "string",
          "enumDescriptions": [
            "",
            "",
            ""
          ],
          "enum": [
            "WITHDRAWAL_RIGHT_TYPE_UNSPECIFIED",
            "WITHDRAWAL_RIGHT_DIGITAL_CONTENT",
            "WITHDRAWAL_RIGHT_SERVICE"
          ]
        }
      }
    },
    "CancelSurveyResult": {
      "description": "Result of the cancel survey when the subscription was canceled by the user.",
      "properties": {
        "reason": {
          "enum": [
            "CANCEL_SURVEY_REASON_UNSPECIFIED",
            "CANCEL_SURVEY_REASON_NOT_ENOUGH_USAGE",
            "CANCEL_SURVEY_REASON_TECHNICAL_ISSUES",
            "CANCEL_SURVEY_REASON_COST_RELATED",
            "CANCEL_SURVEY_REASON_FOUND_BETTER_APP",
            "CANCEL_SURVEY_REASON_OTHERS"
          ],
          "description": "The reason the user selected in the cancel survey.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified cancel survey reason.",
            "Not enough usage of the subscription.",
            "Technical issues while using the app.",
            "Cost related issues.",
            "The user found a better app.",
            "Other reasons."
          ]
        },
        "reasonUserInput": {
          "type": "string",
          "description": "Only set for CANCEL_SURVEY_REASON_OTHERS. This is the user's freeform response to the survey."
        }
      },
      "id": "CancelSurveyResult",
      "type": "object"
    },
    "InAppProduct": {
      "id": "InAppProduct",
      "type": "object",
      "description": "An in-app product. The resource for InappproductsService.",
      "properties": {
        "listings": {
          "type": "object",
          "description": "List of localized title and description data. Map key is the language of the localized data, as defined by BCP-47, e.g. \"en-US\".",
          "additionalProperties": {
            "$ref": "InAppProductListing"
          }
        },
        "packageName": {
          "description": "Package name of the parent app.",
          "type": "string"
        },
        "defaultPrice": {
          "$ref": "Price",
          "description": "Default price. Cannot be zero, as in-app products are never free. Always in the developer's Checkout merchant currency."
        },
        "trialPeriod": {
          "description": "Trial period, specified in ISO 8601 format. Acceptable values are anything between P7D (seven days) and P999D (999 days).",
          "type": "string"
        },
        "subscriptionTaxesAndComplianceSettings": {
          "description": "Details about taxes and legal compliance. Only applicable to subscription products.",
          "$ref": "SubscriptionTaxAndComplianceSettings"
        },
        "purchaseType": {
          "enum": [
            "purchaseTypeUnspecified",
            "managedUser",
            "subscription"
          ],
          "description": "The type of the product, e.g. a recurring subscription.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified purchase type.",
            "The default product type - one time purchase.",
            "In-app product with a recurring period."
          ]
        },
        "subscriptionPeriod": {
          "type": "string",
          "description": "Subscription period, specified in ISO 8601 format. Acceptable values are P1W (one week), P1M (one month), P3M (three months), P6M (six months), and P1Y (one year)."
        },
        "gracePeriod": {
          "description": "Grace period of the subscription, specified in ISO 8601 format. Allows developers to give their subscribers a grace period when the payment for the new recurrence period is declined. Acceptable values are P0D (zero days), P3D (three days), P7D (seven days), P14D (14 days), and P30D (30 days).",
          "type": "string"
        },
        "status": {
          "type": "string",
          "enumDescriptions": [
            "Unspecified status.",
            "The product is published and active in the store.",
            "The product is not published and therefore inactive in the store."
          ],
          "description": "The status of the product, e.g. whether it's active.",
          "enum": [
            "statusUnspecified",
            "active",
            "inactive"
          ]
        },
        "managedProductTaxesAndComplianceSettings": {
          "description": "Details about taxes and legal compliance. Only applicable to managed products.",
          "$ref": "ManagedProductTaxAndComplianceSettings"
        },
        "sku": {
          "type": "string",
          "description": "Stock-keeping-unit (SKU) of the product, unique within an app."
        },
        "defaultLanguage": {
          "description": "Default language of the localized data, as defined by BCP-47. e.g. \"en-US\".",
          "type": "string"
        },
        "prices": {
          "type": "object",
          "description": "Prices per buyer region. None of these can be zero, as in-app products are never free. Map key is region code, as defined by ISO 3166-2.",
          "additionalProperties": {
            "$ref": "Price"
          }
        }
      }
    },
    "BatchUpdateSubscriptionOfferStatesResponse": {
      "id": "BatchUpdateSubscriptionOfferStatesResponse",
      "type": "object",
      "description": "Response message for BatchUpdateSubscriptionOfferStates.",
      "properties": {
        "subscriptionOffers": {
          "description": "The updated subscription offers list.",
          "type": "array",
          "items": {
            "$ref": "SubscriptionOffer"
          }
        }
      }
    },
    "ExternalAccountIdentifiers": {
      "id": "ExternalAccountIdentifiers",
      "type": "object",
      "description": "User account identifier in the third-party service.",
      "properties": {
        "externalAccountId": {
          "type": "string",
          "description": "User account identifier in the third-party service. Only present if account linking happened as part of the subscription purchase flow."
        },
        "obfuscatedExternalAccountId": {
          "description": "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.",
          "type": "string"
        },
        "obfuscatedExternalProfileId": {
          "description": "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.",
          "type": "string"
        }
      }
    },
    "SubscriptionItemPriceChangeDetails": {
      "id": "SubscriptionItemPriceChangeDetails",
      "type": "object",
      "description": "Price change related information of a subscription item.",
      "properties": {
        "newPrice": {
          "description": "New recurring price for the subscription item.",
          "$ref": "Money"
        },
        "priceChangeState": {
          "enum": [
            "PRICE_CHANGE_STATE_UNSPECIFIED",
            "OUTSTANDING",
            "CONFIRMED",
            "APPLIED",
            "CANCELED"
          ],
          "type": "string",
          "enumDescriptions": [
            "Price change state unspecified. This value should not be used.",
            "Waiting for the user to agree for the price change.",
            "The price change is confirmed to happen for the user.",
            "The price change is applied, i.e. the user has started being charged the new price.",
            "The price change was canceled."
          ],
          "description": "State the price change is currently in."
        },
        "priceChangeMode": {
          "enum": [
            "PRICE_CHANGE_MODE_UNSPECIFIED",
            "PRICE_DECREASE",
            "PRICE_INCREASE",
            "OPT_OUT_PRICE_INCREASE"
          ],
          "type": "string",
          "enumDescriptions": [
            "Price change mode unspecified. This value should never be set.",
            "If the subscription price is decreasing.",
            "If the subscription price is increasing and the user needs to accept it.",
            "If the subscription price is increasing with opt out mode."
          ],
          "description": "Price change mode specifies how the subscription item price is changing."
        },
        "expectedNewPriceChargeTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "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."
        }
      }
    },
    "RevocationContextFullRefund": {
      "description": "Used to determine if the refund type in the RevocationContext is a full refund.",
      "properties": {},
      "id": "RevocationContextFullRefund",
      "type": "object"
    },
    "Testers": {
      "id": "Testers",
      "type": "object",
      "description": "The testers of an app. The resource for TestersService. Note: while it is possible in the Play Console UI to add testers via email lists, email lists are not supported by this resource.",
      "properties": {
        "googleGroups": {
          "description": "All testing Google Groups, as email addresses.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "SubscriptionPurchasesAcknowledgeRequest": {
      "id": "SubscriptionPurchasesAcknowledgeRequest",
      "type": "object",
      "description": "Request for the purchases.subscriptions.acknowledge API.",
      "properties": {
        "externalAccountIds": {
          "description": "Optional. User account identifier in your app.",
          "$ref": "ExternalAccountIds"
        },
        "developerPayload": {
          "type": "string",
          "description": "Payload to attach to the purchase."
        }
      }
    },
    "OneTimeProductRentPurchaseOption": {
      "description": "A purchase option that can be rented.",
      "properties": {
        "rentalPeriod": {
          "type": "string",
          "description": "Required. The amount of time a user has the entitlement for. Starts at purchase flow completion. Specified in ISO 8601 format."
        },
        "expirationPeriod": {
          "type": "string",
          "description": "Optional. The amount of time the user has after starting consuming the entitlement before it is revoked. Specified in ISO 8601 format."
        }
      },
      "id": "OneTimeProductRentPurchaseOption",
      "type": "object"
    },
    "TargetingUpdate": {
      "id": "TargetingUpdate",
      "type": "object",
      "description": "Update type for targeting. Note it is always a subset Targeting.",
      "properties": {
        "regions": {
          "$ref": "Regions",
          "description": "Additional regions are targeted by the recovery action."
        },
        "androidSdks": {
          "$ref": "AndroidSdks",
          "description": "Additional android sdk levels are targeted by the recovery action."
        },
        "allUsers": {
          "description": "All users are targeted.",
          "$ref": "AllUsers"
        }
      }
    },
    "SubscriptionOfferTargeting": {
      "id": "SubscriptionOfferTargeting",
      "type": "object",
      "description": "Defines the rule a user needs to satisfy to receive this offer.",
      "properties": {
        "upgradeRule": {
          "description": "Offer targeting rule for upgrading users' existing plans.",
          "$ref": "UpgradeTargetingRule"
        },
        "acquisitionRule": {
          "description": "Offer targeting rule for new user acquisition.",
          "$ref": "AcquisitionTargetingRule"
        }
      }
    },
    "RegionalBasePlanConfig": {
      "description": "Configuration for a base plan specific to a region.",
      "properties": {
        "newSubscriberAvailability": {
          "type": "boolean",
          "description": "Whether the base plan in the specified region is available for new subscribers. Existing subscribers will not have their subscription canceled if this value is set to false. If not specified, this will default to false."
        },
        "regionCode": {
          "description": "Required. Region code this configuration applies to, as defined by ISO 3166-2, e.g. \"US\".",
          "type": "string"
        },
        "price": {
          "$ref": "Money",
          "description": "The price of the base plan in the specified region. Must be set if the base plan is available to new subscribers. Must be set in the currency that is linked to the specified region."
        }
      },
      "id": "RegionalBasePlanConfig",
      "type": "object"
    },
    "TrackTargetedCountry": {
      "description": "Representation of a single country where the contents of a track can be made available.",
      "properties": {
        "countryCode": {
          "type": "string",
          "description": "The country that can be targeted, as a two-letter CLDR code."
        }
      },
      "id": "TrackTargetedCountry",
      "type": "object"
    },
    "TargetingRuleScopeAnySubscriptionInApp": {
      "id": "TargetingRuleScopeAnySubscriptionInApp",
      "type": "object",
      "description": "Represents the targeting rule scope corresponding to any subscription in the parent app.",
      "properties": {}
    },
    "TrackRelease": {
      "id": "TrackRelease",
      "type": "object",
      "description": "A release within a track.",
      "properties": {
        "countryTargeting": {
          "$ref": "CountryTargeting",
          "description": "Restricts a release to a specific set of countries. Note this is only allowed to be set for inProgress releases in the production track."
        },
        "versionCodes": {
          "type": "array",
          "items": {
            "type": "string",
            "format": "int64"
          },
          "description": "Version codes of all APKs in the release. Must include version codes to retain from previous releases."
        },
        "status": {
          "enum": [
            "statusUnspecified",
            "draft",
            "inProgress",
            "halted",
            "completed"
          ],
          "type": "string",
          "enumDescriptions": [
            "Unspecified status.",
            "The release's APKs are not being served to users.",
            "The release's APKs are being served to a fraction of users, determined by 'user_fraction'.",
            "The release's APKs will no longer be served to users. Users who already have these APKs are unaffected.",
            "The release will have no further changes. Its APKs are being served to all users, unless they are eligible to APKs of a more recent release."
          ],
          "description": "The status of the release."
        },
        "name": {
          "type": "string",
          "description": "The release name. Not required to be unique. If not set, the name is generated from the APK's version_name. If the release contains multiple APKs, the name is generated from the date."
        },
        "releaseNotes": {
          "type": "array",
          "items": {
            "$ref": "LocalizedText"
          },
          "description": "A description of what is new in this release."
        },
        "inAppUpdatePriority": {
          "type": "integer",
          "format": "int32",
          "description": "In-app update priority of the release. All newly added APKs in the release will be considered at this priority. Can take values in the range [0, 5], with 5 the highest priority. Defaults to 0. in_app_update_priority can not be updated once the release is rolled out. See https://developer.android.com/guide/playcore/in-app-updates."
        },
        "userFraction": {
          "description": "Fraction of users who are eligible for a staged release. 0 \u003c fraction \u003c 1. Can only be set when status is \"inProgress\" or \"halted\".",
          "type": "number",
          "format": "double"
        }
      }
    },
    "SystemFeature": {
      "id": "SystemFeature",
      "type": "object",
      "description": "Representation of a system feature.",
      "properties": {
        "name": {
          "description": "The name of the feature.",
          "type": "string"
        }
      }
    },
    "GeneratedStandaloneApk": {
      "id": "GeneratedStandaloneApk",
      "type": "object",
      "description": "Download metadata for a standalone APK.",
      "properties": {
        "downloadId": {
          "type": "string",
          "description": "Download ID, which uniquely identifies the APK to download. Should be supplied to `generatedapks.download` method."
        },
        "variantId": {
          "description": "ID of the generated variant.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "DeveloperComment": {
      "description": "Developer entry from conversation between user and developer.",
      "properties": {
        "text": {
          "type": "string",
          "description": "The content of the comment, i.e. reply body."
        },
        "lastModified": {
          "$ref": "Timestamp",
          "description": "The last time at which this comment was updated."
        }
      },
      "id": "DeveloperComment",
      "type": "object"
    },
    "PriceStepUpConsentDetails": {
      "id": "PriceStepUpConsentDetails",
      "type": "object",
      "description": "Information related to a price step-up that requires user consent.",
      "properties": {
        "consentDeadlineTime": {
          "description": "The deadline by which the user must provide consent. If consent is not provided by this time, the subscription will be canceled.",
          "type": "string",
          "format": "google-datetime"
        },
        "newPrice": {
          "$ref": "Money",
          "description": "The new price which requires user consent."
        },
        "state": {
          "description": "Output only. The state of the price step-up consent.",
          "readOnly": true,
          "enumDescriptions": [
            "Unspecified consent state.",
            "The user has not yet provided consent.",
            "The user has consented, and the new price is waiting to take effect.",
            "The user has consented, and the new price has taken effect."
          ],
          "enum": [
            "CONSENT_STATE_UNSPECIFIED",
            "PENDING",
            "CONFIRMED",
            "COMPLETED"
          ],
          "type": "string"
        }
      }
    },
    "BatchGetSubscriptionsResponse": {
      "id": "BatchGetSubscriptionsResponse",
      "type": "object",
      "description": "Response message for BatchGetSubscriptions endpoint.",
      "properties": {
        "subscriptions": {
          "description": "The list of requested subscriptions, in the same order as the request.",
          "type": "array",
          "items": {
            "$ref": "Subscription"
          }
        }
      }
    },
    "ReplacementCancellation": {
      "id": "ReplacementCancellation",
      "type": "object",
      "description": "Information specific to cancellations caused by subscription replacement.",
      "properties": {}
    },
    "AllUsers": {
      "id": "AllUsers",
      "type": "object",
      "description": "Object representation to describe all set of users.",
      "properties": {
        "isAllUsersRequested": {
          "description": "Required. Set to true if all set of users are needed.",
          "type": "boolean"
        }
      }
    },
    "DeviceFeatureTargeting": {
      "description": "Targeting for a device feature.",
      "properties": {
        "requiredFeature": {
          "$ref": "DeviceFeature",
          "description": "Feature of the device."
        }
      },
      "id": "DeviceFeatureTargeting",
      "type": "object"
    },
    "IntroductoryPriceInfo": {
      "id": "IntroductoryPriceInfo",
      "type": "object",
      "description": "Contains the introductory price information for a subscription.",
      "properties": {
        "introductoryPriceAmountMicros": {
          "type": "string",
          "format": "int64",
          "description": "Introductory price of the subscription, not including tax. The currency is the same as price_currency_code. Price is expressed in micro-units, where 1,000,000 micro-units represents one unit of the currency. For example, if the subscription price is €1.99, price_amount_micros is 1990000."
        },
        "introductoryPriceCurrencyCode": {
          "description": "ISO 4217 currency code for the introductory subscription price. For example, if the price is specified in British pounds sterling, price_currency_code is \"GBP\".",
          "type": "string"
        },
        "introductoryPricePeriod": {
          "type": "string",
          "description": "Introductory price period, specified in ISO 8601 format. Common values are (but not limited to) \"P1W\" (one week), \"P1M\" (one month), \"P3M\" (three months), \"P6M\" (six months), and \"P1Y\" (one year)."
        },
        "introductoryPriceCycles": {
          "type": "integer",
          "format": "int32",
          "description": "The number of billing period to offer introductory pricing."
        }
      }
    },
    "IntroductoryPriceOfferPhase": {
      "description": "Details about introductory price offer phase.",
      "properties": {},
      "id": "IntroductoryPriceOfferPhase",
      "type": "object"
    },
    "SubscriptionDeferralInfo": {
      "id": "SubscriptionDeferralInfo",
      "type": "object",
      "description": "A SubscriptionDeferralInfo contains the data needed to defer a subscription purchase to a future expiry time.",
      "properties": {
        "expectedExpiryTimeMillis": {
          "type": "string",
          "format": "int64",
          "description": "The expected expiry time for the subscription. If the current expiry time for the subscription is not the value specified here, the deferral will not occur."
        },
        "desiredExpiryTimeMillis": {
          "description": "The desired next expiry time to assign to the subscription, in milliseconds since the Epoch. The given time must be later/greater than the current expiry time for the subscription.",
          "type": "string",
          "format": "int64"
        }
      }
    },
    "Abi": {
      "id": "Abi",
      "type": "object",
      "description": "Represents an Abi.",
      "properties": {
        "alias": {
          "enum": [
            "UNSPECIFIED_CPU_ARCHITECTURE",
            "ARMEABI",
            "ARMEABI_V7A",
            "ARM64_V8A",
            "X86",
            "X86_64",
            "RISCV64"
          ],
          "description": "Alias for an abi.",
          "type": "string",
          "enumDescriptions": [
            "Unspecified abi.",
            "ARMEABI abi.",
            "ARMEABI_V7A abi.",
            "ARM64_V8A abi.",
            "X86 abi.",
            "X86_64 abi.",
            "RISCV64 abi."
          ]
        }
      }
    },
    "RegionalSubscriptionOfferConfig": {
      "description": "Configuration for a subscription offer in a single region.",
      "properties": {
        "newSubscriberAvailability": {
          "type": "boolean",
          "description": "Whether the subscription offer in the specified region is available for new subscribers. Existing subscribers will not have their subscription cancelled if this value is set to false. If not specified, this will default to false."
        },
        "regionCode": {
          "type": "string",
          "description": "Required. Immutable. Region code this configuration applies to, as defined by ISO 3166-2, e.g. \"US\"."
        }
      },
      "id": "RegionalSubscriptionOfferConfig",
      "type": "object"
    },
    "OfferTag": {
      "description": "Represents a custom tag specified for a product offer.",
      "properties": {
        "tag": {
          "type": "string",
          "description": "Must conform with RFC-1034. That is, this string can only contain lower-case letters (a-z), numbers (0-9), and hyphens (-), and be at most 20 characters."
        }
      },
      "id": "OfferTag",
      "type": "object"
    },
    "BatchDeleteOneTimeProductOffersRequest": {
      "id": "BatchDeleteOneTimeProductOffersRequest",
      "type": "object",
      "description": "Request message for BatchDeleteOneTimeProductOffers.",
      "properties": {
        "requests": {
          "description": "Required. A list of update requests of up to 100 elements. All requests must correspond to different offers.",
          "type": "array",
          "items": {
            "$ref": "DeleteOneTimeProductOfferRequest"
          }
        }
      }
    },
    "DeviceSelector": {
      "description": "Selector for a device group. A selector consists of a set of conditions on the device that should all match (logical AND) to determine a device group eligibility. For instance, if a selector specifies RAM conditions, device model inclusion and device model exclusion, a device is considered to match if: device matches RAM conditions AND device matches one of the included device models AND device doesn't match excluded device models",
      "properties": {
        "includedDeviceIds": {
          "type": "array",
          "items": {
            "$ref": "DeviceId"
          },
          "description": "Device models included by this selector."
        },
        "requiredSystemFeatures": {
          "description": "A device needs to have all these system features to be included by the selector.",
          "type": "array",
          "items": {
            "$ref": "SystemFeature"
          }
        },
        "deviceRam": {
          "description": "Conditions on the device's RAM.",
          "$ref": "DeviceRam"
        },
        "forbiddenSystemFeatures": {
          "type": "array",
          "items": {
            "$ref": "SystemFeature"
          },
          "description": "A device that has any of these system features is excluded by this selector, even if it matches all other conditions."
        },
        "excludedDeviceIds": {
          "type": "array",
          "items": {
            "$ref": "DeviceId"
          },
          "description": "Device models excluded by this selector, even if they match all other conditions."
        },
        "systemOnChips": {
          "description": "Optional. The SoCs included by this selector. Only works for Android S+ devices.",
          "type": "array",
          "items": {
            "$ref": "SystemOnChip"
          }
        }
      },
      "id": "DeviceSelector",
      "type": "object"
    },
    "GetSubscriptionOfferRequest": {
      "description": "Request message for GetSubscriptionOffer.",
      "properties": {
        "packageName": {
          "description": "Required. The parent app (package name) of the offer to get.",
          "type": "string"
        },
        "productId": {
          "description": "Required. The parent subscription (ID) of the offer to get.",
          "type": "string"
        },
        "offerId": {
          "description": "Required. The unique offer ID of the offer to get.",
          "type": "string"
        },
        "basePlanId": {
          "type": "string",
          "description": "Required. The parent base plan (ID) of the offer to get."
        }
      },
      "id": "GetSubscriptionOfferRequest",
      "type": "object"
    },
    "DeviceId": {
      "id": "DeviceId",
      "type": "object",
      "description": "Identifier of a device.",
      "properties": {
        "buildBrand": {
          "description": "Value of Build.BRAND.",
          "type": "string"
        },
        "buildDevice": {
          "description": "Value of Build.DEVICE.",
          "type": "string"
        }
      }
    },
    "BatchGetSubscriptionOffersRequest": {
      "description": "Request message for BatchGetSubscriptionOffers endpoint.",
      "properties": {
        "requests": {
          "type": "array",
          "items": {
            "$ref": "GetSubscriptionOfferRequest"
          },
          "description": "Required. A list of update requests of up to 100 elements. All requests must update different subscriptions."
        }
      },
      "id": "BatchGetSubscriptionOffersRequest",
      "type": "object"
    },
    "DeferSubscriptionPurchaseRequest": {
      "description": "Request for the v2 purchases.subscriptions.defer API.",
      "properties": {
        "deferralContext": {
          "$ref": "DeferralContext",
          "description": "Required. Details about the subscription deferral."
        }
      },
      "id": "DeferSubscriptionPurchaseRequest",
      "type": "object"
    },
    "RevokeSubscriptionPurchaseRequest": {
      "id": "RevokeSubscriptionPurchaseRequest",
      "type": "object",
      "description": "Request for the purchases.subscriptionsv2.revoke API.",
      "properties": {
        "revocationContext": {
          "description": "Required. Additional details around the subscription revocation.",
          "$ref": "RevocationContext"
        }
      }
    },
    "UserInitiatedCancellation": {
      "id": "UserInitiatedCancellation",
      "type": "object",
      "description": "Information specific to cancellations initiated by users.",
      "properties": {
        "cancelTime": {
          "type": "string",
          "format": "google-datetime",
          "description": "The time at which the subscription was canceled by the user. The user might still have access to the subscription after this time. Use line_items.expiry_time to determine if a user still has access."
        },
        "cancelSurveyResult": {
          "description": "Information provided by the user when they complete the subscription cancellation flow (cancellation reason survey).",
          "$ref": "CancelSurveyResult"
        }
      }
    },
    "RevokeSubscriptionPurchaseResponse": {
      "id": "RevokeSubscriptionPurchaseResponse",
      "type": "object",
      "description": "Response for the purchases.subscriptionsv2.revoke API.",
      "properties": {}
    },
    "PreorderDetails": {
      "id": "PreorderDetails",
      "type": "object",
      "description": "Details of a pre-order purchase.",
      "properties": {}
    }
  },
  "revision": "20260416",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/androidpublisher": {
          "description": "View and manage your Google Play Developer account"
        }
      }
    }
  },
  "baseUrl": "https://androidpublisher.googleapis.com/",
  "ownerName": "Google",
  "parameters": {
    "uploadType": {
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\").",
      "type": "string",
      "location": "query"
    },
    "callback": {
      "type": "string",
      "description": "JSONP",
      "location": "query"
    },
    "upload_protocol": {
      "location": "query",
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\")."
    },
    "access_token": {
      "location": "query",
      "description": "OAuth access token.",
      "type": "string"
    },
    "quotaUser": {
      "description": "Available to use for quota purposes for server-side applications. Can be any arbitrary string assigned to a user, but should not exceed 40 characters.",
      "type": "string",
      "location": "query"
    },
    "oauth_token": {
      "description": "OAuth 2.0 token for the current user.",
      "type": "string",
      "location": "query"
    },
    "$.xgafv": {
      "type": "string",
      "enum": [
        "1",
        "2"
      ],
      "location": "query",
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "description": "V1 error format."
    },
    "fields": {
      "description": "Selector specifying which fields to include in a partial response.",
      "type": "string",
      "location": "query"
    },
    "key": {
      "location": "query",
      "type": "string",
      "description": "API key. Your API key identifies your project and provides you with API access, quota, and reports. Required unless you provide an OAuth 2.0 token."
    },
    "prettyPrint": {
      "location": "query",
      "type": "boolean",
      "default": "true",
      "description": "Returns response with indentations and line breaks."
    },
    "alt": {
      "type": "string",
      "default": "json",
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "description": "Data format for response.",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "location": "query"
    }
  },
  "icons": {
    "x32": "http://www.google.com/images/icons/product/search-32.gif",
    "x16": "http://www.google.com/images/icons/product/search-16.gif"
  }
}
