{
  "documentationLink": "https://cloud.google.com/channel",
  "baseUrl": "https://cloudchannel.googleapis.com/",
  "title": "Cloud Channel API",
  "protocol": "rest",
  "name": "cloudchannel",
  "description": "The Cloud Channel API enables Google Cloud partners to have a single unified resale platform and APIs across all of Google Cloud including GCP, Workspace, Maps and Chrome.",
  "servicePath": "",
  "schemas": {
    "GoogleCloudChannelV1alpha1AssociationInfo": {
      "description": "Association links that an entitlement has to other entitlements.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1AssociationInfo",
      "properties": {
        "baseEntitlement": {
          "description": "The name of the base entitlement, for which this entitlement is an add-on.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerLink": {
      "description": "Entity representing a link between distributors and their indirect resellers in an n-tier resale channel.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerLink",
      "properties": {
        "channelPartnerCloudIdentityInfo": {
          "description": "Output only. Cloud Identity info of the channel partner (IR).",
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
          "readOnly": true
        },
        "linkState": {
          "description": "Required. State of the channel partner link.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "An invitation has been sent to the reseller to create a channel partner link.",
            "Status when the reseller is active.",
            "Status when the reseller has been revoked by the distributor.",
            "Status when the reseller is suspended by Google or distributor."
          ],
          "enum": [
            "CHANNEL_PARTNER_LINK_STATE_UNSPECIFIED",
            "INVITED",
            "ACTIVE",
            "REVOKED",
            "SUSPENDED"
          ]
        },
        "resellerCloudIdentityId": {
          "description": "Required. Cloud Identity ID of the linked reseller.",
          "type": "string"
        },
        "publicId": {
          "readOnly": true,
          "description": "Output only. Public identifier that a customer must use to generate a transfer token to move to this distributor-reseller combination.",
          "type": "string"
        },
        "partnerAdvantageInfo": {
          "description": "Output only. Partner Advantage information for this Channel Partner (IR).",
          "$ref": "GoogleCloudChannelV1alpha1PartnerAdvantageInfo",
          "readOnly": true
        },
        "updateTime": {
          "description": "Output only. Timestamp of when the channel partner link is updated.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "name": {
          "description": "Output only. Resource name for the channel partner link, in the format accounts/{account_id}/channelPartnerLinks/{id}.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Timestamp of when the channel partner link is created.",
          "type": "string"
        },
        "inviteLinkUri": {
          "readOnly": true,
          "description": "Output only. URI of the web page where partner accepts the link invitation.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RepricingConfigChannelPartnerGranularity": {
      "id": "GoogleCloudChannelV1alpha1RepricingConfigChannelPartnerGranularity",
      "properties": {},
      "deprecated": true,
      "description": "Applies the repricing configuration at the channel partner level. The channel partner value is derived from the resource name. Takes an empty json object. Deprecated: This is no longer supported. Use RepricingConfig.EntitlementGranularity instead.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListProductsResponse": {
      "id": "GoogleCloudChannelV1alpha1ListProductsResponse",
      "properties": {
        "products": {
          "description": "List of Products requested.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Product"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      },
      "description": "Response message for ListProducts.",
      "type": "object"
    },
    "GoogleCloudChannelV1OperationMetadata": {
      "description": "Provides contextual information about a google.longrunning.Operation.",
      "type": "object",
      "id": "GoogleCloudChannelV1OperationMetadata",
      "properties": {
        "operationType": {
          "description": "The RPC that initiated this Long Running Operation.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Long Running Operation was triggered by CreateEntitlement.",
            "Long Running Operation was triggered by ChangeRenewalSettings.",
            "Long Running Operation was triggered by StartPaidService.",
            "Long Running Operation was triggered by ActivateEntitlement.",
            "Long Running Operation was triggered by SuspendEntitlement.",
            "Long Running Operation was triggered by CancelEntitlement.",
            "Long Running Operation was triggered by TransferEntitlements.",
            "Long Running Operation was triggered by TransferEntitlementsToGoogle.",
            "Long Running Operation was triggered by ChangeOffer.",
            "Long Running Operation was triggered by ChangeParameters.",
            "Long Running Operation was triggered by ProvisionCloudIdentity."
          ],
          "enum": [
            "OPERATION_TYPE_UNSPECIFIED",
            "CREATE_ENTITLEMENT",
            "CHANGE_RENEWAL_SETTINGS",
            "START_PAID_SERVICE",
            "ACTIVATE_ENTITLEMENT",
            "SUSPEND_ENTITLEMENT",
            "CANCEL_ENTITLEMENT",
            "TRANSFER_ENTITLEMENTS",
            "TRANSFER_ENTITLEMENTS_TO_GOOGLE",
            "CHANGE_OFFER",
            "CHANGE_PARAMETERS",
            "PROVISION_CLOUD_IDENTITY"
          ]
        }
      }
    },
    "GoogleLongrunningOperation": {
      "id": "GoogleLongrunningOperation",
      "properties": {
        "done": {
          "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.",
          "type": "boolean"
        },
        "response": {
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.",
          "type": "object"
        },
        "metadata": {
          "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "error": {
          "$ref": "GoogleRpcStatus",
          "description": "The error result of the operation in case of failure or cancellation."
        },
        "name": {
          "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.",
          "type": "string"
        }
      },
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount": {
      "id": "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount",
      "properties": {
        "customerName": {
          "description": "If owned = true, the name of the customer that owns the Cloud Identity account. Customer_name uses the format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "customerType": {
          "description": "If existing = true, the type of the customer.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Domain-owning customer which needs domain verification to use services.",
            "Team customer which needs email verification to use services."
          ],
          "enum": [
            "CUSTOMER_TYPE_UNSPECIFIED",
            "DOMAIN",
            "TEAM"
          ]
        },
        "customerCloudIdentityId": {
          "description": "If existing = true, the Cloud Identity ID of the customer.",
          "type": "string"
        },
        "channelPartnerCloudIdentityId": {
          "description": "If existing = true, and is 2-tier customer, the channel partner of the customer.",
          "type": "string"
        },
        "existing": {
          "description": "Returns true if a Cloud Identity account exists for a specific domain.",
          "type": "boolean"
        },
        "owned": {
          "description": "Returns true if the Cloud Identity account is associated with a customer of the Channel Services partner (with active subscriptions or purchase consents).",
          "type": "boolean"
        }
      },
      "description": "Entity representing a Cloud Identity account that may be associated with a Channel Services API partner.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1MarketingInfo": {
      "id": "GoogleCloudChannelV1alpha1MarketingInfo",
      "properties": {
        "displayName": {
          "description": "Human readable name.",
          "type": "string"
        },
        "defaultLogo": {
          "description": "Default logo.",
          "$ref": "GoogleCloudChannelV1alpha1Media"
        },
        "description": {
          "description": "Human readable description. Description can contain HTML.",
          "type": "string"
        }
      },
      "description": "Represents the marketing information for a Product, SKU or Offer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RepricingConfig": {
      "description": "Configuration for repricing a Google bill over a period of time.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1RepricingConfig",
      "properties": {
        "entitlementGranularity": {
          "description": "Required. Applies the repricing configuration at the entitlement level. Note: If a ChannelPartnerRepricingConfig using RepricingConfig.EntitlementGranularity becomes effective, then no existing or future RepricingConfig.ChannelPartnerGranularity will apply to the RepricingConfig.EntitlementGranularity.entitlement. This is the recommended value for both CustomerRepricingConfig and ChannelPartnerRepricingConfig.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfigEntitlementGranularity"
        },
        "rebillingBasis": {
          "description": "Required. The RebillingBasis to use for this bill. Specifies the relative cost based on repricing costs you will apply.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Use the list cost, also known as the MSRP.",
            "Pass through all discounts except the Reseller Program Discount. If this is the default cost base and no adjustments are specified, the output cost will be exactly what the customer would see if they viewed the bill in the Google Cloud Console."
          ],
          "enum": [
            "REBILLING_BASIS_UNSPECIFIED",
            "COST_AT_LIST",
            "DIRECT_CUSTOMER_COST"
          ]
        },
        "conditionalOverrides": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ConditionalOverride"
          },
          "description": "The conditional overrides to apply for this configuration. If you list multiple overrides, only the first valid override is used. If you don't list any overrides, the API uses the normal adjustment and rebilling basis.",
          "type": "array"
        },
        "effectiveInvoiceMonth": {
          "$ref": "GoogleTypeDate",
          "description": "Required. The YearMonth when these adjustments activate. The Day field needs to be \"0\" since we only accept YearMonth repricing boundaries."
        },
        "channelPartnerGranularity": {
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfigChannelPartnerGranularity",
          "description": "Applies the repricing configuration at the channel partner level. Only ChannelPartnerRepricingConfig supports this value. Deprecated: This is no longer supported. Use RepricingConfig.entitlement_granularity instead.",
          "deprecated": true
        },
        "adjustment": {
          "description": "Required. Information about the adjustment.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingAdjustment"
        }
      }
    },
    "GoogleTypeMoney": {
      "description": "Represents an amount of money with its currency type.",
      "type": "object",
      "id": "GoogleTypeMoney",
      "properties": {
        "nanos": {
          "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.",
          "type": "integer"
        },
        "currencyCode": {
          "description": "The three-letter currency code defined in ISO 4217.",
          "type": "string"
        },
        "units": {
          "format": "int64",
          "description": "The whole units of the amount. For example if `currencyCode` is `\"USD\"`, then 1 unit is one US dollar.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ProvisionCloudIdentityRequest": {
      "id": "GoogleCloudChannelV1alpha1ProvisionCloudIdentityRequest",
      "properties": {
        "validateOnly": {
          "description": "Validate the request and preview the review, but do not post it.",
          "type": "boolean"
        },
        "cloudIdentityInfo": {
          "description": "CloudIdentity-specific customer information.",
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo"
        },
        "user": {
          "description": "Admin user information.",
          "$ref": "GoogleCloudChannelV1alpha1AdminUser"
        }
      },
      "description": "Request message for CloudChannelService.ProvisionCloudIdentity",
      "type": "object"
    },
    "GoogleCloudChannelV1CustomerEvent": {
      "description": "Represents Pub/Sub message content describing customer update.",
      "type": "object",
      "id": "GoogleCloudChannelV1CustomerEvent",
      "properties": {
        "eventType": {
          "description": "Type of event which happened for the customer.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Primary domain for customer was changed.",
            "Primary domain of the customer has been verified."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "PRIMARY_DOMAIN_CHANGED",
            "PRIMARY_DOMAIN_VERIFIED"
          ]
        },
        "customer": {
          "description": "Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChangeOfferRequest": {
      "description": "Request message for CloudChannelService.ChangeOffer.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ChangeOfferRequest",
      "properties": {
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement when setting up billing on a trial subscription. This field is only relevant for multi-currency accounts. It should be left empty for single currency accounts.",
          "type": "string"
        },
        "offer": {
          "description": "Required. New Offer. Format: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "parameters": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Parameter"
          },
          "description": "Optional. Parameters needed to purchase the Offer. To view the available Parameters refer to the Offer.parameter_definitions from the desired offer.",
          "type": "array"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order id provided by the reseller.",
          "type": "string"
        },
        "priceReferenceId": {
          "description": "Optional. Price reference ID for the offer. Only for offers that require additional price information. Used to guarantee that the pricing is consistent between quoting the offer and placing the order.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListTransferableSkusResponse": {
      "description": "Response message for CloudChannelService.ListTransferableSkus.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListTransferableSkusResponse",
      "properties": {
        "transferableSkus": {
          "description": "Information about existing SKUs for a customer that needs a transfer.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1TransferableSku"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListTransferableSkusRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Value": {
      "description": "Data type and value of a parameter.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Value",
      "properties": {
        "stringValue": {
          "description": "Represents a string value.",
          "type": "string"
        },
        "int64Value": {
          "format": "int64",
          "description": "Represents an int64 value.",
          "type": "string"
        },
        "doubleValue": {
          "description": "Represents a double value.",
          "type": "number",
          "format": "double"
        },
        "protoValue": {
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "description": "Represents an 'Any' proto value.",
          "type": "object"
        },
        "boolValue": {
          "description": "Represents a boolean value.",
          "type": "boolean"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse": {
      "id": "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse",
      "properties": {
        "entitlementChanges": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1EntitlementChange"
          },
          "description": "The list of entitlement changes.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to list the next page of results.",
          "type": "string"
        }
      },
      "description": "Response message for CloudChannelService.ListEntitlementChanges",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1DateRange": {
      "description": "A representation of usage or invoice date ranges.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1DateRange",
      "properties": {
        "invoiceEndDate": {
          "description": "The latest invoice date (inclusive). If this value is not the last day of a month, this will move it forward to the last day of the given month.",
          "$ref": "GoogleTypeDate"
        },
        "usageStartDateTime": {
          "$ref": "GoogleTypeDateTime",
          "description": "The earliest usage date time (inclusive). If you use time groupings (daily, weekly, etc), each group uses midnight to midnight (Pacific time). The usage start date is rounded down to include all usage from the specified date. We recommend that clients pass `usage_start_date_time` in Pacific time."
        },
        "usageEndDateTime": {
          "$ref": "GoogleTypeDateTime",
          "description": "The latest usage date time (exclusive). If you use time groupings (daily, weekly, etc), each group uses midnight to midnight (Pacific time). The usage end date is rounded down to include all usage from the specified date. We recommend that clients pass `usage_start_date_time` in Pacific time."
        },
        "invoiceStartDate": {
          "$ref": "GoogleTypeDate",
          "description": "The earliest invoice date (inclusive). If this value is not the first day of a month, this will move it back to the first day of the given month."
        }
      }
    },
    "GoogleTypeDecimal": {
      "id": "GoogleTypeDecimal",
      "properties": {
        "value": {
          "description": "The decimal value, as a string. The string representation consists of an optional sign, `+` (`U+002B`) or `-` (`U+002D`), followed by a sequence of zero or more decimal digits (\"the integer\"), optionally followed by a fraction, optionally followed by an exponent. An empty string **should** be interpreted as `0`. The fraction consists of a decimal point followed by zero or more decimal digits. The string must contain at least one digit in either the integer or the fraction. The number formed by the sign, the integer and the fraction is referred to as the significand. The exponent consists of the character `e` (`U+0065`) or `E` (`U+0045`) followed by one or more decimal digits. Services **should** normalize decimal values before storing them by: - Removing an explicitly-provided `+` sign (`+2.5` -\u003e `2.5`). - Replacing a zero-length integer value with `0` (`.5` -\u003e `0.5`). - Coercing the exponent character to upper-case, with explicit sign (`2.5e8` -\u003e `2.5E+8`). - Removing an explicitly-provided zero exponent (`2.5E0` -\u003e `2.5`). Services **may** perform additional normalization based on its own needs and the internal decimal implementation selected, such as shifting the decimal point and exponent value together (example: `2.5E-1` \u003c-\u003e `0.25`). Additionally, services **may** preserve trailing zeroes in the fraction to indicate increased precision, but are not required to do so. Note that only the `.` character is supported to divide the integer and the fraction; `,` **should not** be supported regardless of locale. Additionally, thousand separators **should not** be supported. If a service does support them, values **must** be normalized. The ENBF grammar is: DecimalString = '' | [Sign] Significand [Exponent]; Sign = '+' | '-'; Significand = Digits '.' | [Digits] '.' Digits; Exponent = ('e' | 'E') [Sign] Digits; Digits = { '0' | '1' | '2' | '3' | '4' | '5' | '6' | '7' | '8' | '9' }; Services **should** clearly document the range of supported values, the maximum supported precision (total number of digits), and, if applicable, the scale (number of digits after the decimal point), as well as how it behaves when receiving out-of-bounds values. Services **may** choose to accept values passed as input even when the value has a higher precision or scale than the service supports, and **should** round the value to fit the supported scale. Alternatively, the service **may** error with `400 Bad Request` (`INVALID_ARGUMENT` in gRPC) if precision would be lost. Services **should** error with `400 Bad Request` (`INVALID_ARGUMENT` in gRPC) if the service receives a value outside of the supported range.",
          "type": "string"
        }
      },
      "description": "A representation of a decimal value, such as 2.5. Clients may convert values into language-native decimal formats, such as Java's [BigDecimal](https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/math/BigDecimal.html) or Python's [decimal.Decimal](https://docs.python.org/3/library/decimal.html).",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse": {
      "description": "Response message for CloudChannelService.ListCustomerRepricingConfigs.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse",
      "properties": {
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListCustomerRepricingConfigsRequest.page_token to obtain that page.",
          "type": "string"
        },
        "customerRepricingConfigs": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
          },
          "description": "The repricing configs for this channel partner.",
          "type": "array"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Media": {
      "description": "Represents media information.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Media",
      "properties": {
        "title": {
          "description": "Title of the media.",
          "type": "string"
        },
        "content": {
          "description": "URL of the media.",
          "type": "string"
        },
        "type": {
          "description": "Type of the media.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Type of image."
          ],
          "enum": [
            "MEDIA_TYPE_UNSPECIFIED",
            "MEDIA_TYPE_IMAGE"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1PricePhase": {
      "description": "Specifies the price by the duration of months. For example, a 20% discount for the first six months, then a 10% discount starting on the seventh month.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PricePhase",
      "properties": {
        "price": {
          "$ref": "GoogleCloudChannelV1alpha1Price",
          "description": "Price of the phase. Present if there are no price tiers."
        },
        "lastPeriod": {
          "description": "Defines first period for the phase.",
          "type": "integer",
          "format": "int32"
        },
        "periodType": {
          "description": "Defines the phase period type.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Day.",
            "Month.",
            "Year."
          ],
          "enum": [
            "PERIOD_TYPE_UNSPECIFIED",
            "DAY",
            "MONTH",
            "YEAR"
          ]
        },
        "firstPeriod": {
          "description": "Defines first period for the phase.",
          "type": "integer",
          "format": "int32"
        },
        "priceTiers": {
          "description": "Price by the resource tiers.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PriceTier"
          }
        }
      }
    },
    "GoogleTypeDate": {
      "id": "GoogleTypeDate",
      "properties": {
        "year": {
          "format": "int32",
          "description": "Year of the date. Must be from 1 to 9999, or 0 to specify a date without a year.",
          "type": "integer"
        },
        "month": {
          "description": "Month of a year. Must be from 1 to 12, or 0 to specify a year without a month and day.",
          "type": "integer",
          "format": "int32"
        },
        "day": {
          "description": "Day of a month. Must be from 1 to 31 and valid for the year and month, or 0 to specify a year by itself or a year and month where the day isn't significant.",
          "type": "integer",
          "format": "int32"
        }
      },
      "description": "Represents a whole or partial calendar date, such as a birthday. The time of day and time zone are either specified elsewhere or are insignificant. The date is relative to the Gregorian Calendar. This can represent one of the following: * A full date, with non-zero year, month, and day values. * A month and day, with a zero year (for example, an anniversary). * A year on its own, with a zero month and a zero day. * A year and month, with a zero day (for example, a credit card expiration date). Related types: * google.type.TimeOfDay * google.type.DateTime * google.protobuf.Timestamp",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RunReportJobRequest": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1RunReportJobRequest",
      "properties": {
        "languageCode": {
          "description": "Optional. The BCP-47 language code, such as \"en-US\". If specified, the response is localized to the corresponding language code if the original data sources support it. Default is \"en-US\".",
          "type": "string"
        },
        "dateRange": {
          "description": "Optional. The range of usage or invoice dates to include in the result.",
          "$ref": "GoogleCloudChannelV1alpha1DateRange"
        },
        "filter": {
          "description": "Optional. A structured string that defines conditions on dimension columns to restrict the report output. Filters support logical operators (AND, OR, NOT) and conditional operators (=, !=, \u003c, \u003e, \u003c=, and \u003e=) using `column_id` as keys. For example: `(customer:\"accounts/C123abc/customers/S456def\" OR customer:\"accounts/C123abc/customers/S789ghi\") AND invoice_start_date.year \u003e= 2022`",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelReportsService.RunReportJob.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse": {
      "description": "Response message for ListPurchasableSkus.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse",
      "properties": {
        "purchasableSkus": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PurchasableSku"
          },
          "description": "The list of SKUs requested.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Constraints": {
      "description": "Represents the constraints for buying the Offer.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Constraints",
      "properties": {
        "customerConstraints": {
          "description": "Represents constraints required to purchase the Offer for a customer.",
          "$ref": "GoogleCloudChannelV1alpha1CustomerConstraints"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Opportunity": {
      "id": "GoogleCloudChannelV1alpha1Opportunity",
      "properties": {
        "opportunityLines": {
          "readOnly": true,
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1OpportunityLine"
          },
          "description": "Output only. Information about the Products added to the Opportunity. Present only after the Opportunity is Accepted. Unset otherwise. Can't be edited.",
          "type": "array"
        },
        "qualificationInfo": {
          "$ref": "GoogleCloudChannelV1alpha1QualificationInfo",
          "description": "Required. Information that will be used to qualify the Opportunity for approval and incentive eligibility. Required for Creating an Opportunity."
        },
        "stateDescription": {
          "readOnly": true,
          "description": "Output only. Contains the reason if the Opportunity was not accepted. Available in Limited view.",
          "type": "string"
        },
        "owner": {
          "description": "Output only. Name of the Google FSR who owns the Opportunity. Available in Limited view.",
          "type": "string",
          "readOnly": true
        },
        "source": {
          "description": "Output only. Represents if the Opportunity was created by Google or by Partner. Available in Limited view.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Created by Google sales rep.",
            "Created by Google Business.",
            "Created by Google programmatically.",
            "If the Opportunity was created by Partner."
          ],
          "enum": [
            "SOURCE_UNKNOWN",
            "GOOGLE",
            "GOOGLE_BDR",
            "GOOGLE_PROGRAMMATIC",
            "PARTNER"
          ],
          "readOnly": true
        },
        "createTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. Timestamp when the Opportunity was created.",
          "type": "string"
        },
        "opportunityTeamMembers": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1OpportunityTeamMember"
          },
          "readOnly": true,
          "description": "Output only. Information on the Partner users with access to the Opportunity. Present only after the Opportunity is Accepted. Unset otherwise. Can't be edited. Available in Limited view. Only lists the Partner Development Manager (PDM) roles in Limited view.",
          "type": "array"
        },
        "customerContacts": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CustomerContact"
          },
          "readOnly": true,
          "description": "Output only. List of Customer contacts for the Opportunity. Present only after the Opportunity is Accepted. Unset otherwise. Can't be edited.",
          "type": "array"
        },
        "customerDisplayName": {
          "description": "Output only. Customer display name that the Opportunity is associated with. This maps to the Vector Account name. Available in Limited view.",
          "type": "string",
          "readOnly": true
        },
        "updateTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. Timestamp when the Opportunity was last updated.",
          "type": "string"
        },
        "winLossInfo": {
          "readOnly": true,
          "description": "Output only. Information related to the Sales cycle. Present only after the Opportunity is closed. Unset otherwise. Can't be edited.",
          "$ref": "GoogleCloudChannelV1alpha1WinLossInfo"
        },
        "submitterEmail": {
          "description": "Optional. User email that created the Opportunity through an integrator. Only used if the Opportunity is created through an integrator. Can only be set during Opportunity creation. Can't be edited after it's set.",
          "type": "string"
        },
        "state": {
          "description": "Optional. State the Opportunity is in. Client can only set the state to DRAFT or SUBMITTED. Default: DRAFT. Available in Limited view.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Set this state if you are not ready to submit the Opportunity for Approval.",
            "Set this state to process the Approval.",
            "Can only be set by the system. Indicates that the Opportunity has been accepted.",
            "Can only be set by the system. Indicates that the Opportunity has not been accepted. Clients can edit the Opportunity and resubmit it for approval by setting the state back to SUBMITTED."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "DRAFT",
            "SUBMITTED",
            "ACCEPTED",
            "NOT_ACCEPTED"
          ]
        },
        "customerInfo": {
          "description": "Required. Information of the end customer used for matching to an existing customer account or for creating a new one. Required for Creating an Opportunity. Can't be edited after the Opportunity is Accepted. Available in Limited view.",
          "$ref": "GoogleCloudChannelV1alpha1CustomerInfo"
        },
        "isvSolutionConnectInfo": {
          "$ref": "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo",
          "description": "Optional. Optional information that can be provided for ISV deals during Create Opportunity. Can't be edited after the Opportunity is Accepted."
        },
        "creatorEmail": {
          "readOnly": true,
          "description": "Output only. User email that created the Opportunity. If the Opportunity is created through an integrator, this will be the integrator's service account.",
          "type": "string"
        },
        "rebateExtensions": {
          "description": "Output only. Information about the rebate extensions requested on the Opportunity. Present only after the Opportunity is Accepted. Unset otherwise. Can't be edited.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1RebateExtension"
          },
          "readOnly": true
        },
        "name": {
          "description": "Identifier. Resource name of an Opportunity in the form: opportunities/{opportunity_id}. Available in Limited view.",
          "type": "string"
        },
        "referenceOpportunityId": {
          "readOnly": true,
          "description": "Output only. Opportunity ID in the Partner Advantage Portal. This ID is meant for mapping the Opportunities to the old system, and has a 1 to 1 mapping with the opportunities in this Service. Available in Limited view.",
          "type": "string"
        },
        "stage": {
          "description": "The sales stage that the Opportunity is in. New Opportunities are created in Stage 0. Can only be updated after the Opportunity is ACCEPTED. Can't be updated to CLOSED. Available in Limited view.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Stage 0 - Qualify.",
            "Stage 1 - Refine.",
            "Stage 2 - Tech evaluation and Solution Development.",
            "Stage 3 - Proposal negotiation.",
            "Stage 4 - Migration or Implementation. Represents Closed/Won stage. Can only be set by the system.",
            "Closed lost. Can only be set by the system.",
            "Closed by Admin. Can only be set by the system."
          ],
          "enum": [
            "STAGE_UNSPECIFIED",
            "QUALIFY",
            "REFINE",
            "TECH_EVAL_SOL_DEV",
            "PROPOSAL_NEGOTIATION",
            "MIGRATION_IMPL",
            "CLOSED_LOST",
            "CLOSED_ADMIN"
          ]
        },
        "salesCycle": {
          "description": "Optional. Information related to the Sales cycle. Present only after the Opportunity is Accepted. Unset otherwise. Can be edited. Available in Limited view.",
          "$ref": "GoogleCloudChannelV1alpha1SalesCycle"
        },
        "opportunityInfo": {
          "description": "Required. Information about the Opportunity provided during deal submission. Required for Creating an Opportunity. Available in Limited view.",
          "$ref": "GoogleCloudChannelV1alpha1OpportunityInfo"
        },
        "ownerEmail": {
          "readOnly": true,
          "description": "Output only. Email of the Google FSR who owns the Opportunity. Available in Limited view.",
          "type": "string"
        },
        "opportunityType": {
          "description": "Optional. Indicates if the opportunity is an Regular/Independent Software Vendor/2-tier deal. If not specified, it will be treated as a Regular. Can't be edited after the Opportunity is Accepted.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Service or Sell 1-tier Opportunity. Default value.",
            "2-Tier Opportunity",
            "Independent Software Vendor Opportunity"
          ],
          "enum": [
            "OPPORTUNITY_TYPE_UNSPECIFIED",
            "REGULAR",
            "TWO_TIER",
            "ISV_SOLUTION_CONNECT"
          ]
        },
        "partnerInfo": {
          "$ref": "GoogleCloudChannelV1alpha1PartnerInfo",
          "description": "Optional. Opportunity information related to the sourcing Partner. Present only after the Opportunity is Accepted. Unset otherwise. Can be edited. Available in Limited view."
        }
      },
      "description": "An Opportunity is a pending sale from a customer likely to purchase Google Cloud products or services. Once closed, an Opportunity is either won (results in an order) or lost.",
      "type": "object"
    },
    "GoogleCloudChannelV1ReportJob": {
      "description": "The result of a RunReportJob operation. Contains the name to use in FetchReportResultsRequest.report_job and the status of the operation.",
      "type": "object",
      "id": "GoogleCloudChannelV1ReportJob",
      "properties": {
        "reportStatus": {
          "description": "The current status of report generation.",
          "$ref": "GoogleCloudChannelV1ReportStatus"
        },
        "name": {
          "description": "Required. The resource name of a report job. Name uses the format: `accounts/{account_id}/reportJobs/{report_job_id}`",
          "type": "string"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1PartnerInfo": {
      "description": "Partner Information provided after the Opportunity is Accepted.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PartnerInfo",
      "properties": {
        "contractExpiryDate": {
          "description": "Deprecated: This field is no longer used.",
          "deprecated": true,
          "$ref": "GoogleTypeDate"
        },
        "distributor": {
          "description": "Distributor in case of 2-tier deals. Format: partners/{id}. Can be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "gcpProjectNumbers": {
          "items": {
            "type": "string"
          },
          "description": "Optional. Google Cloud project numbers. Can be edited after the Opportunity is Accepted. Can only be numeric values.",
          "type": "array"
        },
        "approveTime": {
          "description": "Output only. Timestamp when the Opportunity was approved.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "rebateExpirationDate": {
          "$ref": "GoogleTypeDate",
          "description": "Output only. Rebate expiration date.",
          "readOnly": true
        },
        "partnerViewType": {
          "readOnly": true,
          "description": "Output only. Indicates what view the partner has access to.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Partner has access to all the fields in the Opportunity.",
            "Partner has access to limited fields in the Opportunity. Non-sourcing service Partners have limited view. No updates are allowed on the Opportunity in LIMITED view."
          ],
          "enum": [
            "PARTNER_VIEW_TYPE_UNSPECIFIED",
            "FULL",
            "LIMITED"
          ]
        },
        "subBillingAccountId": {
          "description": "Optional. Cloud Billing subaccount ID. Can be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "incentiveEligibility": {
          "description": "Output only. Whether Partner is eligible for incentives for this Opportunity.",
          "type": "boolean",
          "readOnly": true
        },
        "extensionsCount": {
          "format": "int32",
          "readOnly": true,
          "description": "Output only. Number of extensions for rebate.",
          "type": "integer"
        },
        "incentiveType": {
          "readOnly": true,
          "description": "Output only. Incentive type if the Opportunity is eligible for incentive: Deal Registration or Deal Referral.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Deal Registration incentive.",
            "Deal Referral incentive."
          ],
          "enum": [
            "INCENTIVE_TYPE_UNSPECIFIED",
            "DEAL_REGISTRATION",
            "DEAL_REFERRAL"
          ]
        },
        "submitTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. Timestamp when the Opportunity was last submitted.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SkuPurchaseGroup": {
      "description": "Represents a set of SKUs that must be purchased using the same billing account.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1SkuPurchaseGroup",
      "properties": {
        "billingAccountPurchaseInfos": {
          "description": "List of billing accounts that are eligible to purhcase these SKUs.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo"
          }
        },
        "skus": {
          "items": {
            "type": "string"
          },
          "description": "Resource names of the SKUs included in this group. Format: products/{product_id}/skus/{sku_id}.",
          "type": "array"
        }
      }
    },
    "GoogleCloudChannelV1ReportStatus": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1ReportStatus",
      "properties": {
        "state": {
          "description": "The current state of the report generation process.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Report processing started.",
            "Data generated from the report is being staged.",
            "Report data is available for access.",
            "Report failed."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "STARTED",
            "WRITING",
            "AVAILABLE",
            "FAILED"
          ]
        },
        "startTime": {
          "description": "The report generation's start time.",
          "type": "string",
          "format": "google-datetime"
        },
        "endTime": {
          "format": "google-datetime",
          "description": "The report generation's completion time.",
          "type": "string"
        }
      },
      "description": "Status of a report generation process.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistRequest": {
      "id": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistRequest",
      "properties": {
        "domain": {
          "description": "Required. Domain to fetch for Cloud Identity account customers, including domain and team customers. For team customers, please use the domain for their emails.",
          "type": "string"
        },
        "primaryAdminEmail": {
          "description": "Optional. Primary admin email to fetch for Cloud Identity account team customer.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.CheckCloudIdentityAccountsExist.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RepricingConfigEntitlementGranularity": {
      "description": "Applies the repricing configuration at the entitlement level.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1RepricingConfigEntitlementGranularity",
      "properties": {
        "entitlement": {
          "description": "Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerConstraints": {
      "id": "GoogleCloudChannelV1alpha1CustomerConstraints",
      "properties": {
        "allowedCustomerTypes": {
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Domain-owning customer which needs domain verification to use services.",
              "Team customer which needs email verification to use services."
            ],
            "enum": [
              "CUSTOMER_TYPE_UNSPECIFIED",
              "DOMAIN",
              "TEAM"
            ]
          },
          "description": "Allowed Customer Type.",
          "type": "array"
        },
        "allowedRegions": {
          "description": "Allowed geographical regions of the customer.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "promotionalOrderTypes": {
          "description": "Allowed Promotional Order Type. Present for Promotional offers.",
          "type": "array",
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Order used for new customers, trial conversions and upgrades.",
              "All orders for transferring an existing customer.",
              "Orders for modifying an existing customer's promotion on the same SKU."
            ],
            "enum": [
              "PROMOTIONAL_TYPE_UNSPECIFIED",
              "NEW_UPGRADE",
              "TRANSFER",
              "PROMOTION_SWITCH"
            ]
          }
        }
      },
      "description": "Represents constraints required to purchase the Offer for a customer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1OpportunityLine": {
      "id": "GoogleCloudChannelV1alpha1OpportunityLine",
      "properties": {
        "description": {
          "description": "Output only. Line item description.",
          "type": "string",
          "readOnly": true
        },
        "listPrice": {
          "$ref": "GoogleTypeMoney",
          "description": "Output only. List price.",
          "readOnly": true
        },
        "displayName": {
          "readOnly": true,
          "description": "Output only. Product display name.",
          "type": "string"
        },
        "salesPrice": {
          "description": "Output only. Sales price.",
          "$ref": "GoogleTypeMoney",
          "readOnly": true
        },
        "totalPrice": {
          "readOnly": true,
          "description": "Output only. Total price of the line.",
          "$ref": "GoogleTypeMoney"
        },
        "metric": {
          "readOnly": true,
          "description": "Output only. Unit of measure.",
          "type": "string"
        },
        "quantity": {
          "format": "int32",
          "readOnly": true,
          "description": "Output only. Quantity.",
          "type": "integer"
        }
      },
      "description": "Opportunity Line item.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Offer": {
      "description": "Represents an offer made to resellers for purchase. An offer is associated with a Sku, has a plan for payment, a price, and defines the constraints for buying.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Offer",
      "properties": {
        "marketingInfo": {
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo",
          "description": "Marketing information for the Offer."
        },
        "constraints": {
          "$ref": "GoogleCloudChannelV1alpha1Constraints",
          "description": "Constraints on transacting the Offer."
        },
        "sku": {
          "description": "SKU the offer is associated with.",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        },
        "dealCode": {
          "description": "The deal code of the offer to get a special promotion or discount.",
          "type": "string"
        },
        "plan": {
          "description": "Describes the payment plan for the Offer.",
          "$ref": "GoogleCloudChannelV1alpha1Plan"
        },
        "priceByResources": {
          "description": "Price for each monetizable resource type.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PriceByResource"
          }
        },
        "startTime": {
          "description": "Start of the Offer validity time.",
          "type": "string",
          "format": "google-datetime"
        },
        "name": {
          "description": "Resource Name of the Offer. Format: accounts/{account_id}/offers/{offer_id}",
          "type": "string"
        },
        "endTime": {
          "description": "Output only. End of the Offer validity time.",
          "type": "string",
          "format": "google-datetime",
          "readOnly": true
        },
        "parameterDefinitions": {
          "description": "Parameters required to use current Offer to purchase.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ParameterDefinition"
          }
        }
      }
    },
    "GoogleCloudChannelV1Period": {
      "id": "GoogleCloudChannelV1Period",
      "properties": {
        "duration": {
          "description": "Total duration of Period Type defined.",
          "type": "integer",
          "format": "int32"
        },
        "periodType": {
          "description": "Period Type.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Day.",
            "Month.",
            "Year."
          ],
          "enum": [
            "PERIOD_TYPE_UNSPECIFIED",
            "DAY",
            "MONTH",
            "YEAR"
          ]
        }
      },
      "description": "Represents period in days/months/years.",
      "type": "object"
    },
    "GoogleCloudChannelV1Report": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1Report",
      "properties": {
        "columns": {
          "items": {
            "$ref": "GoogleCloudChannelV1Column"
          },
          "description": "The list of columns included in the report. This defines the schema of the report results.",
          "type": "array"
        },
        "description": {
          "description": "A description of other aspects of the report, such as the products it supports.",
          "type": "string"
        },
        "name": {
          "description": "Required. The report's resource name. Specifies the account and report used to generate report data. The report_id identifier is a UID (for example, `613bf59q`). Name uses the format: accounts/{account_id}/reports/{report_id}",
          "type": "string"
        },
        "displayName": {
          "description": "A human-readable name for this report.",
          "type": "string"
        }
      },
      "description": "The ID and description of a report that was used to generate report data. For example, \"Google Cloud Daily Spend\", \"Google Workspace License Activity\", etc.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CustomerContact": {
      "id": "GoogleCloudChannelV1alpha1CustomerContact",
      "properties": {
        "primary": {
          "description": "Output only. Is Primary contact for this Opportunity?",
          "type": "boolean",
          "readOnly": true
        },
        "givenName": {
          "description": "Output only. Contact First Name.",
          "type": "string",
          "readOnly": true
        },
        "title": {
          "description": "Output only. Contact Title.",
          "type": "string",
          "readOnly": true
        },
        "role": {
          "description": "Output only. Contact Role.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other role.",
            "Administrator.",
            "Billing Contact.",
            "Business Decision Maker.",
            "Business User.",
            "Change Champion.",
            "Chronicle SIEM Contact.",
            "Chronicle SOAR Contact.",
            "Economic Buyer.",
            "Evaluator.",
            "Executive Sponsor.",
            "Influencer.",
            "Main Decision Maker.",
            "Ordering Contact.",
            "Product Contact.",
            "Technical Contact.",
            "Technical Decision Maker."
          ],
          "enum": [
            "ROLE_UNSPECIFIED",
            "OTHER_ROLE",
            "ADMIN",
            "BILLING_CONTACT",
            "BUSINESS_DECISION_MAKER",
            "BUSINESS_USER",
            "CHANGE_CHAMPION",
            "CHRONICLE_SIEM_CONTACT",
            "CHRONICLE_SOAR_CONTACT",
            "ECONOMIC_BUYER",
            "EVALUATOR",
            "EXECUTIVE_SPONSOR",
            "INFLUENCER",
            "MAIN_DECISION_MAKER",
            "ORDERING_CONTACT",
            "PRODUCT_CONTACT",
            "TECH_CONTACT",
            "TECH_DECISION_MAKER"
          ],
          "readOnly": true
        },
        "familyName": {
          "readOnly": true,
          "description": "Output only. Contact Last Name.",
          "type": "string"
        }
      },
      "description": "Customer Contact.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Entitlement": {
      "description": "An entitlement is a representation of a customer's ability to use a service.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Entitlement",
      "properties": {
        "numUnits": {
          "format": "int32",
          "description": "Number of units for a commitment-based Offer. For example, for seat-based Offers, this would be the number of seats; for license-based Offers, this would be the number of licenses. Required for creating commitment-based Offers. Deprecated: Use `parameters` instead.",
          "deprecated": true,
          "type": "integer"
        },
        "provisionedService": {
          "readOnly": true,
          "description": "Output only. Service provisioning details for the entitlement.",
          "$ref": "GoogleCloudChannelV1alpha1ProvisionedService"
        },
        "maxUnits": {
          "format": "int32",
          "description": "Maximum number of units for a non commitment-based Offer, such as Flexible, Trial or Free entitlements. For commitment-based entitlements, this is a read-only field, which only the internal support team can update. Deprecated: Use `parameters` instead.",
          "deprecated": true,
          "type": "integer"
        },
        "name": {
          "description": "Output only. Resource name of an entitlement in the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. The time at which the entitlement is created.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Optional. This purchase order (PO) information is for resellers to use for their company tracking usage. If a purchaseOrderId value is given, it appears in the API responses and shows up in the invoice. The property accepts up to 80 plain text characters. This is only supported for Google Workspace entitlements.",
          "type": "string"
        },
        "provisioningState": {
          "readOnly": true,
          "description": "Output only. Current provisioning state of the entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "The entitlement is currently active.",
            "The entitlement was canceled. After an entitlement is `CANCELED`, its status will not change. Deprecated: Canceled entitlements will no longer be visible.",
            "The entitlement reached end of term and was not renewed. After an entitlement is `COMPLETE`, its status will not change. Deprecated: This is represented as ProvisioningState=SUSPENDED and suspensionReason in (TRIAL_ENDED, RENEWAL_WITH_TYPE_CANCEL)",
            "The entitlement is pending. Deprecated: This is represented as ProvisioningState=SUSPENDED and suspensionReason=PENDING_TOS_ACCEPTANCE",
            "The entitlement is currently suspended."
          ],
          "enumDeprecated": [
            false,
            false,
            true,
            true,
            true,
            false
          ],
          "enum": [
            "PROVISIONING_STATE_UNSPECIFIED",
            "ACTIVE",
            "CANCELED",
            "COMPLETE",
            "PENDING",
            "SUSPENDED"
          ]
        },
        "associationInfo": {
          "$ref": "GoogleCloudChannelV1alpha1AssociationInfo",
          "description": "Association information to other entitlements."
        },
        "offer": {
          "description": "Required. The offer resource name for which the entitlement is to be created. Takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "priceReferenceId": {
          "description": "Optional. Price reference ID for the offer. Only for offers that require additional price information. Used to guarantee that the pricing is consistent between quoting the offer and placing the order.",
          "type": "string"
        },
        "channelPartnerId": {
          "description": "Cloud Identity ID of a channel partner who will be the direct reseller for the customer's order. This field is generally used in 2-tier ordering, where the order is placed by a top-level distributor on behalf of their channel partner or reseller. Required for distributors. Deprecated: `channel_partner_id` has been moved to the Customer.",
          "deprecated": true,
          "type": "string"
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement.",
          "type": "string"
        },
        "updateTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time at which the entitlement is updated.",
          "type": "string"
        },
        "parameters": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Parameter"
          },
          "description": "Extended entitlement parameters. When creating an entitlement, valid parameter names and values are defined in the Offer.parameter_definitions. For Google Workspace, the following Parameters may be accepted as input: - max_units: The maximum assignable units for a flexible offer OR - num_units: The total commitment for commitment-based offers The response may additionally include the following output-only Parameters: - assigned_units: The number of licenses assigned to users. For Google Cloud billing subaccounts, the following Parameter may be accepted as input: - display_name: The display name of the billing subaccount.",
          "type": "array"
        },
        "trialSettings": {
          "description": "Output only. Settings for trial offers.",
          "$ref": "GoogleCloudChannelV1alpha1TrialSettings",
          "readOnly": true
        },
        "assignedUnits": {
          "description": "The current number of users that are assigned a license for the product defined in provisioned_service.skuId. Read-only. Deprecated: Use `parameters` instead.",
          "deprecated": true,
          "type": "integer",
          "format": "int32"
        },
        "commitmentSettings": {
          "description": "Commitment settings for a commitment-based Offer. Required for commitment based offers.",
          "$ref": "GoogleCloudChannelV1alpha1CommitmentSettings"
        },
        "suspensionReasons": {
          "description": "Output only. Enumerable of all current suspension reasons for an entitlement.",
          "type": "array",
          "readOnly": true,
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Entitlement was manually suspended by the Reseller.",
              "Trial ended.",
              "Entitlement renewal was canceled.",
              "Entitlement was automatically suspended on creation for pending ToS acceptance on customer.",
              "Other reasons (internal reasons, abuse, etc.)."
            ],
            "enum": [
              "SUSPENSION_REASON_UNSPECIFIED",
              "RESELLER_INITIATED",
              "TRIAL_ENDED",
              "RENEWAL_WITH_TYPE_CANCEL",
              "PENDING_TOS_ACCEPTANCE",
              "OTHER"
            ]
          }
        }
      }
    },
    "GoogleProtobufEmpty": {
      "id": "GoogleProtobufEmpty",
      "properties": {},
      "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest": {
      "id": "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest",
      "properties": {
        "renewalSettings": {
          "description": "Required. New renewal settings.",
          "$ref": "GoogleCloudChannelV1alpha1RenewalSettings"
        },
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.ChangeRenewalSettings.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1DiscountComponent": {
      "id": "GoogleCloudChannelV1alpha1DiscountComponent",
      "properties": {
        "discountType": {
          "description": "Type of the discount.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Regional discount.",
            "Promotional discount.",
            "Sales-provided discount.",
            "Reseller margin.",
            "Deal code discount."
          ],
          "enum": [
            "DISCOUNT_TYPE_UNSPECIFIED",
            "REGIONAL_DISCOUNT",
            "PROMOTIONAL_DISCOUNT",
            "SALES_DISCOUNT",
            "RESELLER_MARGIN",
            "DEAL_CODE"
          ]
        },
        "discountAbsolute": {
          "description": "Fixed value discount.",
          "$ref": "GoogleTypeMoney"
        },
        "discountPercentage": {
          "format": "double",
          "description": "Discount percentage, represented as decimal. For example, a 20% discount will be represented as 0.2.",
          "type": "number"
        }
      },
      "description": "Represents a single component of the total discount applicable on a Price.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse": {
      "description": "Response message for ListSkuGroupBillableSkus.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse",
      "properties": {
        "billableSkus": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1BillableSku"
          },
          "description": "The list of billable SKUs in the requested SKU group.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListSkuGroupBillableSkusRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Column": {
      "description": "The definition of a report column. Specifies the data properties in the corresponding position of the report rows.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Column",
      "properties": {
        "columnId": {
          "description": "The unique name of the column (for example, customer_domain, channel_partner, customer_cost). You can use column IDs in RunReportJobRequest.filter. To see all reports and their columns, call CloudChannelReportsService.ListReports.",
          "type": "string"
        },
        "displayName": {
          "description": "The column's display name.",
          "type": "string"
        },
        "dataType": {
          "description": "The type of the values for this column.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "ReportValues for this column will use string_value.",
            "ReportValues for this column will use int_value.",
            "ReportValues for this column will use decimal_value.",
            "ReportValues for this column will use money_value.",
            "ReportValues for this column will use date_value.",
            "ReportValues for this column will use date_time_value."
          ],
          "enum": [
            "DATA_TYPE_UNSPECIFIED",
            "STRING",
            "INT",
            "DECIMAL",
            "MONEY",
            "DATE",
            "DATE_TIME"
          ]
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1TrialSettings": {
      "id": "GoogleCloudChannelV1alpha1TrialSettings",
      "properties": {
        "trial": {
          "description": "Determines if the entitlement is in a trial or not: * `true` - The entitlement is in trial. * `false` - The entitlement is not in trial.",
          "type": "boolean"
        },
        "endTime": {
          "format": "google-datetime",
          "description": "Date when the trial ends. The value is in milliseconds using the UNIX Epoch format. See an example [Epoch converter](https://www.epochconverter.com).",
          "type": "string"
        }
      },
      "description": "Settings for trial offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RegisterSubscriberRequest": {
      "id": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest",
      "properties": {
        "integrator": {
          "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
          "type": "string"
        },
        "account": {
          "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
          "type": "string"
        },
        "serviceAccount": {
          "description": "Required. Service account that provides subscriber access to the registered topic.",
          "type": "string"
        }
      },
      "description": "Request Message for RegisterSubscriber.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse": {
      "description": "Response message for CloudChannelService.QueryOpportunities",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse",
      "properties": {
        "opportunities": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "description": "The opportunities for the specified partner.",
          "type": "array"
        },
        "totalSize": {
          "description": "Total Number of Opportunties for the given filter.",
          "type": "integer",
          "format": "int32"
        },
        "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"
        }
      }
    },
    "GoogleTypePostalAddress": {
      "description": "Represents a postal address, such as for postal delivery or payments addresses. With a postal address, a postal service can deliver items to a premise, P.O. box, or similar. A postal address is not intended to model geographical locations like roads, towns, or mountains. In typical usage, an address would be created by user input or from importing existing data, depending on the type of process. Advice on address input or editing: - Use an internationalization-ready address widget such as https://github.com/google/libaddressinput. - Users should not be presented with UI elements for input or editing of fields outside countries where that field is used. For more guidance on how to use this schema, see: https://support.google.com/business/answer/6397478.",
      "type": "object",
      "id": "GoogleTypePostalAddress",
      "properties": {
        "postalCode": {
          "description": "Optional. Postal code of the address. Not all countries use or require postal codes to be present, but where they are used, they may trigger additional validation with other parts of the address (for example, state or zip code validation in the United States).",
          "type": "string"
        },
        "recipients": {
          "items": {
            "type": "string"
          },
          "description": "Optional. The recipient at the address. This field may, under certain circumstances, contain multiline information. For example, it might contain \"care of\" information.",
          "type": "array"
        },
        "sortingCode": {
          "description": "Optional. Additional, country-specific, sorting code. This is not used in most regions. Where it is used, the value is either a string like \"CEDEX\", optionally followed by a number (for example, \"CEDEX 7\"), or just a number alone, representing the \"sector code\" (Jamaica), \"delivery area indicator\" (Malawi) or \"post office indicator\" (Côte d'Ivoire).",
          "type": "string"
        },
        "addressLines": {
          "items": {
            "type": "string"
          },
          "description": "Unstructured address lines describing the lower levels of an address. Because values in `address_lines` do not have type information and may sometimes contain multiple values in a single field (for example, \"Austin, TX\"), it is important that the line order is clear. The order of address lines should be \"envelope order\" for the country or region of the address. In places where this can vary (for example, Japan), `address_language` is used to make it explicit (for example, \"ja\" for large-to-small ordering and \"ja-Latn\" or \"en\" for small-to-large). In this way, the most specific line of an address can be selected based on the language. The minimum permitted structural representation of an address consists of a `region_code` with all remaining information placed in the `address_lines`. It would be possible to format such an address very approximately without geocoding, but no semantic reasoning could be made about any of the address components until it was at least partially resolved. Creating an address only containing a `region_code` and `address_lines` and then geocoding is the recommended way to handle completely unstructured addresses (as opposed to guessing which parts of the address should be localities or administrative areas).",
          "type": "array"
        },
        "sublocality": {
          "description": "Optional. Sublocality of the address. For example, this can be a neighborhood, borough, or district.",
          "type": "string"
        },
        "organization": {
          "description": "Optional. The name of the organization at the address.",
          "type": "string"
        },
        "languageCode": {
          "description": "Optional. BCP-47 language code of the contents of this address (if known). This is often the UI language of the input form or is expected to match one of the languages used in the address' country/region, or their transliterated equivalents. This can affect formatting in certain countries, but is not critical to the correctness of the data and will never affect any validation or other non-formatting related operations. If this value is not known, it should be omitted (rather than specifying a possibly incorrect default). Examples: \"zh-Hant\", \"ja\", \"ja-Latn\", \"en\".",
          "type": "string"
        },
        "regionCode": {
          "description": "Required. CLDR region code of the country/region of the address. This is never inferred and it is up to the user to ensure the value is correct. See https://cldr.unicode.org/ and https://www.unicode.org/cldr/charts/30/supplemental/territory_information.html for details. Example: \"CH\" for Switzerland.",
          "type": "string"
        },
        "locality": {
          "description": "Optional. Generally refers to the city or town portion of the address. Examples: US city, IT comune, UK post town. In regions of the world where localities are not well defined or do not fit into this structure well, leave `locality` empty and use `address_lines`.",
          "type": "string"
        },
        "revision": {
          "description": "The schema revision of the `PostalAddress`. This must be set to 0, which is the latest revision. All new revisions **must** be backward compatible with old revisions.",
          "type": "integer",
          "format": "int32"
        },
        "administrativeArea": {
          "description": "Optional. Highest administrative subdivision which is used for postal addresses of a country or region. For example, this can be a state, a province, an oblast, or a prefecture. For Spain, this is the province and not the autonomous community (for example, \"Barcelona\" and not \"Catalonia\"). Many countries don't use an administrative area in postal addresses. For example, in Switzerland, this should be left unpopulated.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Row": {
      "id": "GoogleCloudChannelV1alpha1Row",
      "properties": {
        "values": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ReportValue"
          },
          "description": "The list of values in the row.",
          "type": "array"
        },
        "partitionKey": {
          "description": "The key for the partition this row belongs to. This field is empty if the report is not partitioned.",
          "type": "string"
        }
      },
      "deprecated": true,
      "description": "A row of report values.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ProvisionedService": {
      "id": "GoogleCloudChannelV1alpha1ProvisionedService",
      "properties": {
        "provisioningId": {
          "readOnly": true,
          "description": "Output only. Provisioning ID of the entitlement. For Google Workspace, this is the underlying Subscription ID. For Google Cloud, this is the Billing Account ID of the billing subaccount.",
          "type": "string"
        },
        "productId": {
          "readOnly": true,
          "description": "Output only. The product pertaining to the provisioning resource as specified in the Offer.",
          "type": "string"
        },
        "skuId": {
          "readOnly": true,
          "description": "Output only. The SKU pertaining to the provisioning resource as specified in the Offer.",
          "type": "string"
        }
      },
      "description": "Service provisioned for an entitlement.",
      "type": "object"
    },
    "GoogleCloudChannelV1TransferEntitlementsResponse": {
      "id": "GoogleCloudChannelV1TransferEntitlementsResponse",
      "properties": {
        "entitlements": {
          "description": "The transferred entitlements.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1Entitlement"
          }
        }
      },
      "description": "Response message for CloudChannelService.TransferEntitlements. This is put in the response field of google.longrunning.Operation.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ImportCustomerRequest": {
      "description": "Request message for CloudChannelService.ImportCustomer",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ImportCustomerRequest",
      "properties": {
        "channelPartnerId": {
          "description": "Optional. Cloud Identity ID of a channel partner who will be the direct reseller for the customer's order. This field is required for 2-tier transfer scenarios and can be provided via the request Parent binding as well.",
          "type": "string"
        },
        "cloudIdentityId": {
          "description": "Required. Customer's Cloud Identity ID",
          "type": "string"
        },
        "customer": {
          "description": "Optional. Specifies the customer that will receive imported Cloud Identity information. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "domain": {
          "description": "Required. Customer domain.",
          "type": "string"
        },
        "primaryAdminEmail": {
          "description": "Required. Customer's primary admin email.",
          "type": "string"
        },
        "authToken": {
          "description": "Optional. The super admin of the resold customer generates this token to authorize a reseller to access their Cloud Identity and purchase entitlements on their behalf. You can omit this token after authorization. See https://support.google.com/a/answer/7643790 for more details.",
          "type": "string"
        },
        "overwriteIfExists": {
          "description": "Required. Choose to overwrite an existing customer if found. This must be set to true if there is an existing customer with a conflicting region code or domain.",
          "type": "boolean"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListSubscribersResponse": {
      "description": "Response Message for ListSubscribers.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListSubscribersResponse",
      "properties": {
        "topic": {
          "description": "Name of the topic registered with the reseller.",
          "type": "string"
        },
        "serviceAccounts": {
          "description": "List of service accounts which have subscriber access to the topic.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "nextPageToken": {
          "description": "A token that can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SkuGroup": {
      "id": "GoogleCloudChannelV1alpha1SkuGroup",
      "properties": {
        "displayName": {
          "description": "Unique human readable identifier for the SKU group.",
          "type": "string"
        },
        "name": {
          "description": "Resource name of SKU group. Format: accounts/{account}/skuGroups/{sku_group}. Example: \"accounts/C01234/skuGroups/3d50fd57-3157-4577-a5a9-a219b8490041\".",
          "type": "string"
        }
      },
      "description": "Represents the SKU group information.",
      "type": "object"
    },
    "GoogleCloudChannelV1CommitmentSettings": {
      "id": "GoogleCloudChannelV1CommitmentSettings",
      "properties": {
        "renewalSettings": {
          "description": "Optional. Renewal settings applicable for a commitment-based Offer.",
          "$ref": "GoogleCloudChannelV1RenewalSettings"
        },
        "endTime": {
          "description": "Output only. Commitment end timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "startTime": {
          "description": "Output only. Commitment start timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        }
      },
      "description": "Commitment settings for commitment-based offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1RunReportJobResponse": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1RunReportJobResponse",
      "properties": {
        "reportJob": {
          "description": "Pass `report_job.name` to FetchReportResultsRequest.report_job to retrieve the report's results.",
          "$ref": "GoogleCloudChannelV1ReportJob"
        },
        "reportMetadata": {
          "$ref": "GoogleCloudChannelV1ReportResultsMetadata",
          "description": "The metadata for the report's results (display name, columns, row count, and date range). If you view this before the operation finishes, you may see incomplete data."
        }
      },
      "description": "Response message for CloudChannelReportsService.RunReportJob.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsRequest": {
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsRequest",
      "properties": {
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "entitlements": {
          "description": "Required. The new entitlements to create or transfer.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          }
        },
        "enableDelegatedAdmin": {
          "description": "Optional. If true, grants delegated admin rights for fulfilled entitlements to the channel partner. Applicable only if you provide an Entitlement.channel_partner_id.",
          "deprecated": true,
          "type": "boolean"
        },
        "authToken": {
          "description": "The super admin of the resold customer generates this token to authorize a reseller to access their Cloud Identity and purchase entitlements on their behalf. You can omit this token after authorization. See https://support.google.com/a/answer/7643790 for more details.",
          "type": "string"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.TransferEntitlements.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferableSku": {
      "id": "GoogleCloudChannelV1alpha1TransferableSku",
      "properties": {
        "numUnits": {
          "format": "int32",
          "description": "Number of units for a commitment-based Offer. For example, for seat-based offers, this would be the number of seats; for license-based offers, this would be the number of licenses. Deprecated: Use `ListTransferableOffers` API instead.",
          "deprecated": true,
          "type": "integer"
        },
        "purchaseEligibility": {
          "description": "Describes the purchase eligibility of a SKU. Deprecated: Use `transfer_eligibility` instead.",
          "deprecated": true,
          "$ref": "GoogleCloudChannelV1alpha1PurchaseEligibility"
        },
        "skuId": {
          "description": "The SKU pertaining to the provisioning resource as specified in the Offer. Deprecated: Use `sku.name` instead.",
          "deprecated": true,
          "type": "string"
        },
        "legacySku": {
          "description": "Optional. The customer to transfer has an entitlement with the populated legacy SKU.",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        },
        "maxUnits": {
          "format": "int32",
          "description": "Maximum number of units for a non-commitment-based offer, such as Flexible or Trial. Deprecated: Use `ListTransferableOffers` API instead.",
          "deprecated": true,
          "type": "integer"
        },
        "skuDisplayName": {
          "description": "Human readable SKU name. This field can be used by resellers if the transferable SKU is not available in their offers. Deprecated: Use `sku.marketing_info.display_name` instead.",
          "deprecated": true,
          "type": "string"
        },
        "assignedUnits": {
          "format": "int32",
          "description": "The current number of users that are assigned a license for the sku_id. This cannot be reduced during a transfer. Deprecated: Use `ListTransferableOffers` API instead.",
          "deprecated": true,
          "type": "integer"
        },
        "transferEligibility": {
          "description": "Describes the transfer eligibility of a SKU.",
          "$ref": "GoogleCloudChannelV1alpha1TransferEligibility"
        },
        "isCommitment": {
          "description": "Whether a transferable SKU is commitment-based or not. Deprecated: Use `ListTransferableOffers` API instead.",
          "deprecated": true,
          "type": "boolean"
        },
        "commitmentEndTimestamp": {
          "format": "google-datetime",
          "description": "Commitment end timestamp. Deprecated: Use `ListTransferableOffers` API instead.",
          "deprecated": true,
          "type": "string"
        },
        "sku": {
          "$ref": "GoogleCloudChannelV1alpha1Sku",
          "description": "The SKU pertaining to the provisioning resource as specified in the Offer."
        },
        "productId": {
          "description": "The product pertaining to the provisioning resource as specified in the Offer. Deprecated: Use `sku.product.name` instead.",
          "deprecated": true,
          "type": "string"
        }
      },
      "description": "TransferableSku represents information a reseller needs to view existing provisioned services for a customer that they do not own. Read-only.",
      "type": "object"
    },
    "GoogleCloudChannelV1Column": {
      "description": "The definition of a report column. Specifies the data properties in the corresponding position of the report rows.",
      "type": "object",
      "id": "GoogleCloudChannelV1Column",
      "properties": {
        "columnId": {
          "description": "The unique name of the column (for example, customer_domain, channel_partner, customer_cost). You can use column IDs in RunReportJobRequest.filter. To see all reports and their columns, call CloudChannelReportsService.ListReports.",
          "type": "string"
        },
        "displayName": {
          "description": "The column's display name.",
          "type": "string"
        },
        "dataType": {
          "description": "The type of the values for this column.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "ReportValues for this column will use string_value.",
            "ReportValues for this column will use int_value.",
            "ReportValues for this column will use decimal_value.",
            "ReportValues for this column will use money_value.",
            "ReportValues for this column will use date_value.",
            "ReportValues for this column will use date_time_value."
          ],
          "enum": [
            "DATA_TYPE_UNSPECIFIED",
            "STRING",
            "INT",
            "DECIMAL",
            "MONEY",
            "DATE",
            "DATE_TIME"
          ]
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1PriceTier": {
      "description": "Defines price at resource tier level. For example, an offer with following definition : * Tier 1: Provide 25% discount for all seats between 1 and 25. * Tier 2: Provide 10% discount for all seats between 26 and 100. * Tier 3: Provide flat 15% discount for all seats above 100. Each of these tiers is represented as a PriceTier.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PriceTier",
      "properties": {
        "lastResource": {
          "format": "int32",
          "description": "Last resource for which the tier price applies.",
          "type": "integer"
        },
        "price": {
          "$ref": "GoogleCloudChannelV1alpha1Price",
          "description": "Price of the tier."
        },
        "firstResource": {
          "format": "int32",
          "description": "First resource for which the tier price applies.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudChannelV1alpha1BillingAccount": {
      "id": "GoogleCloudChannelV1alpha1BillingAccount",
      "properties": {
        "currencyCode": {
          "description": "Output only. The 3-letter currency code defined in ISO 4217.",
          "type": "string",
          "readOnly": true
        },
        "name": {
          "description": "Output only. Resource name of the billing account. Format: accounts/{account_id}/billingAccounts/{billing_account_id}.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "description": "Output only. The time when this billing account was created.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "displayName": {
          "description": "Display name of the billing account.",
          "type": "string"
        },
        "regionCode": {
          "readOnly": true,
          "description": "Output only. The CLDR region code.",
          "type": "string"
        }
      },
      "description": "Represents a billing account.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListCustomersResponse": {
      "id": "GoogleCloudChannelV1alpha1ListCustomersResponse",
      "properties": {
        "customers": {
          "description": "The customers belonging to a reseller or distributor.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Customer"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListCustomersRequest.page_token to obtain that page.",
          "type": "string"
        }
      },
      "description": "Response message for CloudChannelService.ListCustomers.",
      "type": "object"
    },
    "GoogleCloudChannelV1RenewalSettings": {
      "description": "Renewal settings for renewable Offers.",
      "type": "object",
      "id": "GoogleCloudChannelV1RenewalSettings",
      "properties": {
        "paymentPlan": {
          "description": "Describes how a reseller will be billed.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Commitment.",
            "No commitment.",
            "Free.",
            "Trial.",
            "Price and ordering not available through API."
          ],
          "enum": [
            "PAYMENT_PLAN_UNSPECIFIED",
            "COMMITMENT",
            "FLEXIBLE",
            "FREE",
            "TRIAL",
            "OFFLINE"
          ]
        },
        "enableRenewal": {
          "description": "If false, the plan will be completed at the end date.",
          "type": "boolean"
        },
        "resizeUnitCount": {
          "description": "If true and enable_renewal = true, the unit (for example seats or licenses) will be set to the number of active units at renewal time.",
          "type": "boolean"
        },
        "paymentCycle": {
          "description": "Describes how frequently the reseller will be billed, such as once per month.",
          "$ref": "GoogleCloudChannelV1Period"
        }
      }
    },
    "GoogleCloudChannelV1AssociationInfo": {
      "id": "GoogleCloudChannelV1AssociationInfo",
      "properties": {
        "baseEntitlement": {
          "description": "The name of the base entitlement, for which this entitlement is an add-on.",
          "type": "string"
        }
      },
      "description": "Association links that an entitlement has to other entitlements.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1PartnerAdvantageInfo": {
      "id": "GoogleCloudChannelV1alpha1PartnerAdvantageInfo",
      "properties": {
        "productAuthorization": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ProductAuthorization"
          },
          "description": "A list of this Channel Partner's product authorizations.",
          "type": "array"
        }
      },
      "description": "Partner Advantage information for a Channel Partner.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CustomerRepricingConfig": {
      "description": "Configuration for how a reseller will reprice a Customer.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1CustomerRepricingConfig",
      "properties": {
        "name": {
          "readOnly": true,
          "description": "Output only. Resource name of the CustomerRepricingConfig. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
          "type": "string"
        },
        "repricingConfig": {
          "description": "Required. The configuration for bill modifications made by a reseller before sending it to customers.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfig"
        },
        "updateTime": {
          "description": "Output only. Timestamp of an update to the repricing rule. If `update_time` is after RepricingConfig.effective_invoice_month then it indicates this was set mid-month.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RebateExtension": {
      "id": "GoogleCloudChannelV1alpha1RebateExtension",
      "properties": {
        "extensionReason": {
          "readOnly": true,
          "description": "Output only. Extension Reason.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Customer Engagement Delayed.",
            "Proof of Concept Longer Than Expected.",
            "Complex Deal"
          ],
          "enum": [
            "EXTENSION_REASON_UNSPECIFIED",
            "OTHER_EXTENSION_REASON",
            "CUSTOMER_ENGAGEMENT_DELAYED",
            "PROOF_OF_CONCEPT_LONGER_THAN_EXPECTED",
            "COMPLEX_DEAL"
          ]
        },
        "extensionRejectionReason": {
          "description": "Output only. Extension Rejection Reason.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Lack of Partner Engagement.",
            "Negative Customer Feedback",
            "PPS Rejection."
          ],
          "enum": [
            "EXTENSION_REJECTION_REASON_UNSPECIFIED",
            "OTHER_EXTENSION_REJECTION_REASON",
            "LACK_OF_PARTNER_ENGAGEMENT",
            "NEGATIVE_CUSTOMER_FEEDBACK",
            "PPS_REJECTION"
          ],
          "readOnly": true
        },
        "requestNumber": {
          "description": "Output only. Extension Request number.",
          "type": "string",
          "readOnly": true
        },
        "comments": {
          "description": "Output only. Comments.",
          "type": "string",
          "readOnly": true
        },
        "extensionStatus": {
          "readOnly": true,
          "description": "Output only. Extension Status.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Submitted.",
            "Approved.",
            "Rejected."
          ],
          "enum": [
            "EXTENSION_STATUS_UNSPECIFIED",
            "SUBMITTED",
            "APPROVED",
            "REJECTED"
          ]
        }
      },
      "description": "Rebate Extension.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CloudIdentityInfo": {
      "id": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
      "properties": {
        "primaryDomain": {
          "readOnly": true,
          "description": "Output only. The primary domain name.",
          "type": "string"
        },
        "alternateEmail": {
          "description": "The alternate email.",
          "type": "string"
        },
        "phoneNumber": {
          "description": "Phone number associated with the Cloud Identity.",
          "type": "string"
        },
        "adminConsoleUri": {
          "readOnly": true,
          "description": "Output only. URI of Customer's Admin console dashboard.",
          "type": "string"
        },
        "eduData": {
          "description": "Edu information about the customer.",
          "$ref": "GoogleCloudChannelV1alpha1EduData"
        },
        "languageCode": {
          "description": "Language code.",
          "type": "string"
        },
        "customerType": {
          "description": "CustomerType indicates verification type needed for using services.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Domain-owning customer which needs domain verification to use services.",
            "Team customer which needs email verification to use services."
          ],
          "enum": [
            "CUSTOMER_TYPE_UNSPECIFIED",
            "DOMAIN",
            "TEAM"
          ]
        },
        "isDomainVerified": {
          "readOnly": true,
          "description": "Output only. Whether the domain is verified. This field is not returned for a Customer's cloud_identity_info resource. Partners can use the domains.get() method of the Workspace SDK's Directory API, or listen to the PRIMARY_DOMAIN_VERIFIED Pub/Sub event in to track domain verification of their resolve Workspace customers.",
          "type": "boolean"
        }
      },
      "description": "Cloud Identity information for the Cloud Channel Customer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Sku": {
      "description": "Represents a product's purchasable Stock Keeping Unit (SKU). SKUs represent the different variations of the product. For example, Google Workspace Business Standard and Google Workspace Business Plus are Google Workspace product SKUs.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Sku",
      "properties": {
        "name": {
          "description": "Resource Name of the SKU. Format: products/{product_id}/skus/{sku_id}",
          "type": "string"
        },
        "product": {
          "description": "Product the SKU is associated with.",
          "$ref": "GoogleCloudChannelV1alpha1Product"
        },
        "marketingInfo": {
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo",
          "description": "Marketing information for the SKU."
        }
      }
    },
    "GoogleTypeTimeZone": {
      "description": "Represents a time zone from the [IANA Time Zone Database](https://www.iana.org/time-zones).",
      "type": "object",
      "id": "GoogleTypeTimeZone",
      "properties": {
        "version": {
          "description": "Optional. IANA Time Zone Database version number. For example \"2019a\".",
          "type": "string"
        },
        "id": {
          "description": "IANA Time Zone Database time zone. For example \"America/New_York\".",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1TransferableOffer": {
      "id": "GoogleCloudChannelV1alpha1TransferableOffer",
      "properties": {
        "offer": {
          "description": "Offer with parameter constraints updated to allow the Transfer.",
          "$ref": "GoogleCloudChannelV1alpha1Offer"
        },
        "priceReferenceId": {
          "description": "Optional. Price reference ID for the offer. Only for offers that require additional price information. Used to guarantee that the pricing is consistent between quoting the offer and placing the order.",
          "type": "string"
        }
      },
      "description": "TransferableOffer represents an Offer that can be used in Transfer. Read-only.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse": {
      "description": "Response message for ListPurchasableOffers.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse",
      "properties": {
        "purchasableOffers": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PurchasableOffer"
          },
          "description": "The list of Offers requested.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1QualificationInfo": {
      "description": "Qualification information for the Opportunity.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1QualificationInfo",
      "properties": {
        "publicSector": {
          "description": "Optional. Whether or not the customer is a public sector organization that requires competing offers from multiple vendors. Can't be edited after the Opportunity is Accepted. Default: false.",
          "type": "boolean"
        },
        "campaignCode": {
          "description": "Optional. Valid campaign name for the selected customer's region and products. Ex: \"CA-0072131 - 2023 H1 - PPF - Modernize SaaS apps onto GCP\".",
          "type": "string"
        },
        "decisionPhase": {
          "description": "Required. Decision Phase.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Initial research and information gathering",
            "Currently in-trial or looking to trial/pilot",
            "Final decision"
          ],
          "enum": [
            "DECISION_PHASE_UNSPECIFIED",
            "INFORMATION_GATHERING",
            "TRIAL_OR_PILOT",
            "FINAL_DECISION"
          ]
        },
        "quantity": {
          "format": "int32",
          "description": "Optional. Number of seats or licenses. Default: 1. Can't be edited after the Opportunity is Accepted.",
          "type": "integer"
        },
        "need": {
          "description": "Optional. Need. Can't be edited after the Opportunity is Accepted. Required for Regular and 2-Tier Opportunity, optional for ISV Opportunity.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Clear need.",
            "Compelling need.",
            "No need."
          ],
          "enum": [
            "NEED_UNSPECIFIED",
            "CLEAR_NEED",
            "COMPELLING_NEED",
            "NO_NEED"
          ]
        },
        "dealSize": {
          "description": "Required. Target budget/estimated cost. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleTypeMoney"
        },
        "msspDeal": {
          "description": "Optional. Flag to highlight if the partner will also act as MSSP (Managed Security Service Provided).",
          "type": "boolean"
        },
        "timeline": {
          "description": "Optional. Timeline. Can't be edited after the Opportunity is Accepted. Required for Regular and 2-Tier Opportunity, optional for ISV Opportunity.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Confirmed no decision date.",
            "Refused to give date.",
            "Specific decision dates given.",
            "Vague decision dates given."
          ],
          "enum": [
            "TIMELINE_UNSPECIFIED",
            "CONFIRMED_NO_DECISION_DATE",
            "REFUSED_TO_GIVE_DATE",
            "SPECIFIC_DECISION_DATES_GIVEN",
            "VAGUE_DECISION_DATES_GIVEN"
          ]
        },
        "operationType": {
          "description": "Required. Transaction Operation type for which the Opportunity is being created.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "New.",
            "Renewal.",
            "Add-on.",
            "Expansion - user increase or upgrade."
          ],
          "enum": [
            "OPERATION_TYPE_UNSPECIFIED",
            "NEW",
            "RENEWAL",
            "ADD_ON",
            "EXPANSION"
          ]
        },
        "estimatedCloseDate": {
          "description": "Required. Target deal close date in UTC. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleTypeDate"
        },
        "budget": {
          "description": "Optional. Budget. Can't be edited after the Opportunity is Accepted. Required for Regular and 2-Tier Opportunity, optional for ISV Opportunity.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Budget exists, not specified.",
            "Confirmed no budget.",
            "Exact budget given.",
            "Refuse to disclose."
          ],
          "enum": [
            "BUDGET_UNSPECIFIED",
            "BUDGET_EXISTS_NOT_SPECIFIED",
            "CONFIRMED_NO_BUDGET",
            "EXACT_BUDGET_GIVEN",
            "REFUSE_TO_DISCLOSE"
          ]
        },
        "authority": {
          "description": "Optional. Authority. Can't be edited after the Opportunity is Accepted. Required for Regular and 2-Tier Opportunity, optional for ISV Opportunity.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Confirmed no authority decided.",
            "Don't know the authority.",
            "Clearly identified process.",
            "Vague understanding."
          ],
          "enum": [
            "AUTHORITY_UNSPECIFIED",
            "CONFIRMED_NO_AUTHORITY_DECIDED",
            "DONT_KNOW",
            "CLEARLY_IDENTIFIED_PROCESS",
            "VAGUE_UNDERSTANDING"
          ]
        },
        "productLineInfo": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo"
          },
          "description": "Optional. Product line information for the Opportunity.",
          "type": "array"
        },
        "publicTenderAttestation": {
          "description": "Optional. For the Partner to attest if this is a U.S. Public Tender opportunity. Only required for Public Sector opportunities. Can't be edited after the Opportunity is Accepted.",
          "type": "boolean"
        },
        "dealNumber": {
          "readOnly": true,
          "description": "Output only. System generated unique deal identifier.",
          "type": "string"
        },
        "legalLanguageAccepted": {
          "description": "Required. Is the legal_language accepted? Must be true for the Opportunity to be created. Can't be edited after the Opportunity is Accepted. T&C is listed here: https://docs.google.com/document/d/1UvQQtoZ6xiBCGoz0nJFNo-O80iR9faeHzQdWUfnEGTg/edit",
          "type": "boolean"
        },
        "contractLengthMonths": {
          "format": "int32",
          "description": "Required. Contract terms in months. Can't be edited for ISV Opportunity after they are Accepted.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudChannelV1Parameter": {
      "id": "GoogleCloudChannelV1Parameter",
      "properties": {
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "value": {
          "description": "Value of the parameter.",
          "$ref": "GoogleCloudChannelV1Value"
        },
        "editable": {
          "readOnly": true,
          "description": "Output only. Specifies whether this parameter is allowed to be changed. For example, for a Google Workspace Business Starter entitlement in commitment plan, num_units is editable when entitlement is active.",
          "type": "boolean"
        }
      },
      "description": "Definition for extended entitlement parameters.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CreateEntitlementRequest": {
      "id": "GoogleCloudChannelV1alpha1CreateEntitlementRequest",
      "properties": {
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "entitlement": {
          "description": "Required. The entitlement to create.",
          "$ref": "GoogleCloudChannelV1alpha1Entitlement"
        },
        "cloudIdentityInfo": {
          "description": "Optional Cloud Identity information for the customer. Used when placing the first order for Cloud Identity and Google Workspace products. Defaults to DOMAIN customer_type. Deprecated: Call `ProvisionCloudIdentity` before creating an entitlement.",
          "deprecated": true,
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo"
        },
        "enableDelegatedAdmin": {
          "description": "Optional. If true, grants delegated admin rights to the channel partner for fulfilled entitlements. Applicable only if you provide Entitlement.channel_partner_id. Deprecated.",
          "deprecated": true,
          "type": "boolean"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.CreateEntitlement",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest": {
      "id": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest",
      "properties": {
        "integrator": {
          "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
          "type": "string"
        },
        "account": {
          "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
          "type": "string"
        },
        "serviceAccount": {
          "description": "Required. Service account to unregister from subscriber access to the topic.",
          "type": "string"
        }
      },
      "description": "Request Message for UnregisterSubscriber.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType": {
      "description": "A Cloud identity type, if you can provision it, and why. Used in the ListProvisionableCloudIdentityTypes response.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType",
      "properties": {
        "customerType": {
          "description": "Customer Type",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Domain-owning customer which needs domain verification to use services.",
            "Team customer which needs email verification to use services."
          ],
          "enum": [
            "CUSTOMER_TYPE_UNSPECIFIED",
            "DOMAIN",
            "TEAM"
          ]
        },
        "isEligible": {
          "description": "If you can create a customer with that type.",
          "type": "boolean"
        },
        "ineligibilityReason": {
          "description": "Optional. Only shown if is_eligible = false.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Transfer is required to have a Cloud Identity with that domain.",
            "Reseller already owns a Domain customer with that domain.",
            "Only Team customers can be created for this domain",
            "Domain is in the process of converting from Team to Domain.",
            "Deprecated: All combinations of skus are now allowed so the concept of conflicting skus no longer exists.",
            "Dasher customer already exists, and the reseller has purchase relationship with the customer."
          ],
          "enumDeprecated": [
            false,
            true,
            false,
            false,
            false,
            true,
            false
          ],
          "enum": [
            "REASON_UNSPECIFIED",
            "TRANSFER_REQUIRED",
            "DOMAIN_CUSTOMER_EXISTS",
            "TEAM_CUSTOMER_EXISTS",
            "TAKEOVER_IN_PROGRESS",
            "CONFLICTING_SKUS_EXIST",
            "IMPORT_REQUIRED"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1PercentageAdjustment": {
      "id": "GoogleCloudChannelV1alpha1PercentageAdjustment",
      "properties": {
        "percentage": {
          "description": "The percentage of the bill to adjust. For example: Mark down by 1% =\u003e \"-1.00\" Mark up by 1% =\u003e \"1.00\" Pass-Through =\u003e \"0.00\"",
          "$ref": "GoogleTypeDecimal"
        }
      },
      "description": "An adjustment that applies a flat markup or markdown to an entire bill.",
      "type": "object"
    },
    "GoogleTypePhoneNumber": {
      "id": "GoogleTypePhoneNumber",
      "properties": {
        "extension": {
          "description": "The phone number's extension. The extension is not standardized in ITU recommendations, except for being defined as a series of numbers with a maximum length of 40 digits. Other than digits, some other dialing characters such as ',' (indicating a wait) or '#' may be stored here. Note that no regions currently use extensions with short codes, so this field is normally only set in conjunction with an E.164 number. It is held separately from the E.164 number to allow for short code extensions in the future.",
          "type": "string"
        },
        "e164Number": {
          "description": "The phone number, represented as a leading plus sign ('+'), followed by a phone number that uses a relaxed ITU E.164 format consisting of the country calling code (1 to 3 digits) and the subscriber number, with no additional spaces or formatting. For example: - correct: \"+15552220123\" - incorrect: \"+1 (555) 222-01234 x123\" The ITU E.164 format limits the latter to 12 digits, but in practice not all countries respect that, so we relax that restriction here. National-only numbers are not allowed. References: - https://www.itu.int/rec/T-REC-E.164-201011-I - https://en.wikipedia.org/wiki/E.164. - https://en.wikipedia.org/wiki/List_of_country_calling_codes",
          "type": "string"
        },
        "shortCode": {
          "$ref": "GoogleTypePhoneNumberShortCode",
          "description": "A short code. Reference(s): - https://wikipedia.org/wiki/Short_code"
        }
      },
      "description": "An object representing a phone number, suitable as an API wire format. This representation: - should not be used for locale-specific formatting of a phone number, such as \"+1 (650) 253-0000 ext. 123\" - is not designed for efficient storage - may not be suitable for dialing - specialized libraries (see references) should be used to parse the number for that purpose To do something meaningful with this number, such as format it for various use-cases, convert it to an `i18n.phonenumbers.PhoneNumber` object first. For instance, in Java this would be: com.google.type.PhoneNumber wireProto = com.google.type.PhoneNumber.newBuilder().build(); com.google.i18n.phonenumbers.Phonenumber.PhoneNumber phoneNumber = PhoneNumberUtil.getInstance().parse(wireProto.getE164Number(), \"ZZ\"); if (!wireProto.getExtension().isEmpty()) { phoneNumber.setExtension(wireProto.getExtension()); } Reference(s): - https://github.com/google/libphonenumber",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1StartPaidServiceRequest": {
      "id": "GoogleCloudChannelV1alpha1StartPaidServiceRequest",
      "properties": {
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        },
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.StartPaidService.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Price": {
      "id": "GoogleCloudChannelV1alpha1Price",
      "properties": {
        "discountComponents": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1DiscountComponent"
          },
          "description": "Breakdown of the discount into its components. This will be empty if there is no discount present.",
          "type": "array"
        },
        "pricePeriod": {
          "$ref": "GoogleCloudChannelV1alpha1Period",
          "description": "The time period with respect to which base and effective prices are defined. Example: 1 month, 6 months, 1 year, etc."
        },
        "externalPriceUri": {
          "description": "Link to external price list, such as link to Google Voice rate card.",
          "type": "string"
        },
        "effectivePrice": {
          "$ref": "GoogleTypeMoney",
          "description": "Effective Price after applying the discounts."
        },
        "basePrice": {
          "description": "Base price.",
          "$ref": "GoogleTypeMoney"
        },
        "discount": {
          "description": "Discount percentage, represented as decimal. For example, a 20% discount will be represent as 0.2.",
          "type": "number",
          "format": "double"
        }
      },
      "description": "Represents the price of the Offer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest": {
      "description": "Request message for CloudChannelService.AssignChannelPartner.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest",
      "properties": {
        "enableDelegatedAdmin": {
          "description": "Optional. If true, grants delegated admin rights to the channel partner for fulfilled entitlements. Applicable only if you provide a channel_partner_id.",
          "type": "boolean"
        },
        "channelPartnerId": {
          "description": "Required. Cloud Identity ID of the channel partner who will be the indirect reseller for the customer's entitlement. An indirect reseller needs to accept an invitation from the top-level distributor, sent by calling CloudChannelService.CreateChannelPartnerLink. This field is used in 2-tier entitlement purchases, where the purchase is placed by a top-level distributor on behalf of their indirect reseller. Cost allocation for this entitlement can be done for the partner in reports, and the indirect reseller will have delegated admin access to the customer. Required for entitlement purchases for a distributor account only. If there is no partner to assign to this customer, use the distributor's own Cloud Identity ID.",
          "type": "string"
        }
      }
    },
    "GoogleRpcStatus": {
      "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).",
      "type": "object",
      "id": "GoogleRpcStatus",
      "properties": {
        "code": {
          "format": "int32",
          "description": "The status code, which should be an enum value of google.rpc.Code.",
          "type": "integer"
        },
        "message": {
          "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client.",
          "type": "string"
        },
        "details": {
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "type": "array",
          "items": {
            "additionalProperties": {
              "type": "any",
              "description": "Properties of the object. Contains field @type with type URL."
            },
            "type": "object"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ConditionalOverride": {
      "id": "GoogleCloudChannelV1alpha1ConditionalOverride",
      "properties": {
        "adjustment": {
          "description": "Required. Information about the applied override's adjustment.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingAdjustment"
        },
        "repricingCondition": {
          "$ref": "GoogleCloudChannelV1alpha1RepricingCondition",
          "description": "Required. Specifies the condition which, if met, will apply the override."
        },
        "rebillingBasis": {
          "description": "Required. The RebillingBasis to use for the applied override. Shows the relative cost based on your repricing costs.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Use the list cost, also known as the MSRP.",
            "Pass through all discounts except the Reseller Program Discount. If this is the default cost base and no adjustments are specified, the output cost will be exactly what the customer would see if they viewed the bill in the Google Cloud Console."
          ],
          "enum": [
            "REBILLING_BASIS_UNSPECIFIED",
            "COST_AT_LIST",
            "DIRECT_CUSTOMER_COST"
          ]
        }
      },
      "description": "Specifies the override to conditionally apply.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ReportStatus": {
      "description": "Status of a report generation process.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1ReportStatus",
      "properties": {
        "endTime": {
          "format": "google-datetime",
          "description": "The report generation's completion time.",
          "type": "string"
        },
        "state": {
          "description": "The current state of the report generation process.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Report processing started.",
            "Data generated from the report is being staged.",
            "Report data is available for access.",
            "Report failed."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "STARTED",
            "WRITING",
            "AVAILABLE",
            "FAILED"
          ]
        },
        "startTime": {
          "format": "google-datetime",
          "description": "The report generation's start time.",
          "type": "string"
        }
      }
    },
    "GoogleTypeDateTime": {
      "id": "GoogleTypeDateTime",
      "properties": {
        "hours": {
          "description": "Optional. Hours of day in 24 hour format. Should be from 0 to 23, defaults to 0 (midnight). An API may choose to allow the value \"24:00:00\" for scenarios like business closing time.",
          "type": "integer",
          "format": "int32"
        },
        "day": {
          "description": "Optional. Day of month. Must be from 1 to 31 and valid for the year and month, or 0 if specifying a datetime without a day.",
          "type": "integer",
          "format": "int32"
        },
        "minutes": {
          "format": "int32",
          "description": "Optional. Minutes of hour of day. Must be from 0 to 59, defaults to 0.",
          "type": "integer"
        },
        "nanos": {
          "description": "Optional. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999, defaults to 0.",
          "type": "integer",
          "format": "int32"
        },
        "month": {
          "format": "int32",
          "description": "Optional. Month of year. Must be from 1 to 12, or 0 if specifying a datetime without a month.",
          "type": "integer"
        },
        "utcOffset": {
          "format": "google-duration",
          "description": "UTC offset. Must be whole seconds, between -18 hours and +18 hours. For example, a UTC offset of -4:00 would be represented as { seconds: -14400 }.",
          "type": "string"
        },
        "timeZone": {
          "$ref": "GoogleTypeTimeZone",
          "description": "Time zone."
        },
        "seconds": {
          "format": "int32",
          "description": "Optional. Seconds of minutes of the time. Must normally be from 0 to 59, defaults to 0. An API may allow the value 60 if it allows leap-seconds.",
          "type": "integer"
        },
        "year": {
          "description": "Optional. Year of date. Must be from 1 to 9999, or 0 if specifying a datetime without a year.",
          "type": "integer",
          "format": "int32"
        }
      },
      "description": "Represents civil time (or occasionally physical time). This type can represent a civil time in one of a few possible ways: * When utc_offset is set and time_zone is unset: a civil time on a calendar day with a particular offset from UTC. * When time_zone is set and utc_offset is unset: a civil time on a calendar day in a particular time zone. * When neither time_zone nor utc_offset is set: a civil time on a calendar day in local time. The date is relative to the Proleptic Gregorian Calendar. If year, month, or day are 0, the DateTime is considered not to have a specific year, month, or day respectively. This type may also be used to represent a physical time if all the date and time fields are set and either case of the `time_offset` oneof is set. Consider using `Timestamp` message for physical time instead. If your use case also would like to store the user's timezone, that can be done in another field. This type is more flexible than some applications may want. Make sure to document and validate your application's limitations.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangeQuantityRequest": {
      "id": "GoogleCloudChannelV1alpha1ChangeQuantityRequest",
      "properties": {
        "maxUnits": {
          "format": "int32",
          "description": "New max units for the entitlement. It represents the maximum units a flexible offer is allowed to assign. Required for flexible offers.",
          "type": "integer"
        },
        "externalCorrelationId": {
          "description": "An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement. Optional.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order ID provided by the reseller. Optional.",
          "type": "string"
        },
        "requestId": {
          "description": "You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "numUnits": {
          "format": "int32",
          "description": "New num units for the entitlement. For seat-based offers, this is the number of seats. For license based offers, this is the number of licenses. Required for commitment based offers.",
          "type": "integer"
        }
      },
      "description": "Request message for CloudChannelService.ChangeQuantityRequest.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse": {
      "description": "Response message for QueryEligibleBillingAccounts.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse",
      "properties": {
        "skuPurchaseGroups": {
          "description": "List of SKU purchase groups where each group represents a set of SKUs that must be purchased using the same billing account. Each SKU from [QueryEligibleBillingAccountsRequest.skus] will appear in exactly one SKU group.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1SkuPurchaseGroup"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChangeParametersRequest": {
      "description": "Request message for CloudChannelService.ChangeParameters.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ChangeParametersRequest",
      "properties": {
        "parameters": {
          "description": "Required. Entitlement parameters to update. You can only change editable parameters. To view the available Parameters for a request, refer to the Offer.parameter_definitions from the desired offer.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Parameter"
          }
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        },
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order ID provided by the reseller.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityEvent": {
      "id": "GoogleCloudChannelV1alpha1OpportunityEvent",
      "properties": {
        "opportunity": {
          "description": "Resource name of the opportunity. Format: opportunities/{opportunity}",
          "type": "string"
        },
        "eventType": {
          "description": "Type of event which happened for the opportunity.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "New opportunity created.",
            "Existing opportunity updated.",
            "Partner has been detached from the opportunity and can no longer access it."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "CREATED",
            "UPDATED",
            "PARTNER_DETACHED"
          ]
        },
        "partner": {
          "description": "Resource name of the partner. Format: partners/{partner}",
          "type": "string"
        }
      },
      "description": "Represents Pub/Sub message content describing opportunity updates.",
      "type": "object"
    },
    "GoogleCloudChannelV1SubscriberEvent": {
      "description": "Represents information which resellers will get as part of notification from Pub/Sub.",
      "type": "object",
      "id": "GoogleCloudChannelV1SubscriberEvent",
      "properties": {
        "entitlementEvent": {
          "description": "Entitlement event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1EntitlementEvent"
        },
        "customerEvent": {
          "$ref": "GoogleCloudChannelV1CustomerEvent",
          "description": "Customer event sent as part of Pub/Sub event to partners."
        }
      }
    },
    "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse": {
      "description": "Response Message for UnregisterSubscriber.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse",
      "properties": {
        "topic": {
          "description": "Name of the topic the service account subscriber access was removed from.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SuspendEntitlementRequest": {
      "id": "GoogleCloudChannelV1alpha1SuspendEntitlementRequest",
      "properties": {
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        },
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.SuspendEntitlement.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig": {
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig",
      "properties": {
        "updateTime": {
          "description": "Output only. Timestamp of an update to the repricing rule. If `update_time` is after RepricingConfig.effective_invoice_month then it indicates this was set mid-month.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "repricingConfig": {
          "description": "Required. The configuration for bill modifications made by a reseller before sending it to ChannelPartner.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfig"
        },
        "name": {
          "readOnly": true,
          "description": "Output only. Resource name of the ChannelPartnerRepricingConfig. Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
          "type": "string"
        }
      },
      "description": "Configuration for how a distributor will rebill a channel partner (also known as a distributor-authorized reseller).",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ReportValue": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1ReportValue",
      "properties": {
        "dateTimeValue": {
          "$ref": "GoogleTypeDateTime",
          "description": "A value of type `google.type.DateTime` (year, month, day, hour, minute, second, and UTC offset or timezone.)"
        },
        "stringValue": {
          "description": "A value of type `string`.",
          "type": "string"
        },
        "intValue": {
          "format": "int64",
          "description": "A value of type `int`.",
          "type": "string"
        },
        "dateValue": {
          "$ref": "GoogleTypeDate",
          "description": "A value of type `google.type.Date` (year, month, day)."
        },
        "decimalValue": {
          "$ref": "GoogleTypeDecimal",
          "description": "A value of type `google.type.Decimal`, representing non-integer numeric values."
        },
        "moneyValue": {
          "$ref": "GoogleTypeMoney",
          "description": "A value of type `google.type.Money` (currency code, whole units, decimal units)."
        }
      },
      "description": "A single report value.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1EntitlementChange": {
      "description": "Change event entry for Entitlement order history",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1EntitlementChange",
      "properties": {
        "changeType": {
          "description": "The change action type.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "New Entitlement was created.",
            "Price plan associated with an Entitlement was changed.",
            "Number of seats committed for a commitment Entitlement was changed.",
            "An annual Entitlement was renewed.",
            "Entitlement was suspended.",
            "Entitlement was activated.",
            "Entitlement was cancelled.",
            "Entitlement was upgraded or downgraded for ex. from Google Workspace Business Standard to Google Workspace Business Plus.",
            "The settings for renewal of an Entitlement have changed.",
            "Use for Google Workspace subscription. Either a trial was converted to a paid subscription or a new subscription with no trial is created.",
            "License cap was changed for the entitlement.",
            "The suspension details have changed (but it is still suspended).",
            "The trial end date was extended.",
            "Entitlement started trial."
          ],
          "enum": [
            "CHANGE_TYPE_UNSPECIFIED",
            "CREATED",
            "PRICE_PLAN_SWITCHED",
            "COMMITMENT_CHANGED",
            "RENEWED",
            "SUSPENDED",
            "ACTIVATED",
            "CANCELLED",
            "SKU_CHANGED",
            "RENEWAL_SETTING_CHANGED",
            "PAID_SUBSCRIPTION_STARTED",
            "LICENSE_CAP_CHANGED",
            "SUSPENSION_DETAILS_CHANGED",
            "TRIAL_END_DATE_EXTENDED",
            "TRIAL_STARTED"
          ]
        },
        "otherChangeReason": {
          "description": "e.g. purchase_number change reason, entered by CRS.",
          "type": "string"
        },
        "offer": {
          "description": "Required. Resource name of the Offer at the time of change. Takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "operatorType": {
          "description": "Operator type responsible for the change.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Customer service representative.",
            "System auto job.",
            "Customer user.",
            "Reseller user."
          ],
          "enum": [
            "OPERATOR_TYPE_UNSPECIFIED",
            "CUSTOMER_SERVICE_REPRESENTATIVE",
            "SYSTEM",
            "CUSTOMER",
            "RESELLER"
          ]
        },
        "parameters": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Parameter"
          },
          "description": "Extended parameters, such as: purchase_order_number, gcp_details; internal_correlation_id, long_running_operation_id, order_id; etc.",
          "type": "array"
        },
        "operator": {
          "description": "Human-readable identifier that shows what operator made a change. When the operator_type is RESELLER, this is the user's email address. For all other operator types, this is empty.",
          "type": "string"
        },
        "suspensionReason": {
          "description": "Suspension reason for the Entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Entitlement was manually suspended by the Reseller.",
            "Trial ended.",
            "Entitlement renewal was canceled.",
            "Entitlement was automatically suspended on creation for pending ToS acceptance on customer.",
            "Other reasons (internal reasons, abuse, etc.)."
          ],
          "enum": [
            "SUSPENSION_REASON_UNSPECIFIED",
            "RESELLER_INITIATED",
            "TRIAL_ENDED",
            "RENEWAL_WITH_TYPE_CANCEL",
            "PENDING_TOS_ACCEPTANCE",
            "OTHER"
          ]
        },
        "createTime": {
          "format": "google-datetime",
          "description": "The submitted time of the change.",
          "type": "string"
        },
        "entitlement": {
          "description": "Required. Resource name of an entitlement in the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        },
        "cancellationReason": {
          "description": "Cancellation reason for the Entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Reseller triggered a cancellation of the service.",
            "Relationship between the reseller and customer has ended due to a transfer.",
            "Entitlement transferred away from reseller while still keeping other entitlement(s) with the reseller."
          ],
          "enum": [
            "CANCELLATION_REASON_UNSPECIFIED",
            "SERVICE_TERMINATED",
            "RELATIONSHIP_ENDED",
            "PARTIAL_TRANSFER"
          ]
        },
        "activationReason": {
          "description": "The Entitlement's activation reason",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Reseller reactivated a suspended Entitlement.",
            "Customer accepted pending terms of service.",
            "Reseller updated the renewal settings on an entitlement that was suspended due to cancellation, and this update reactivated the entitlement.",
            "Other reasons (Activated temporarily for cancellation, added a payment plan to a trial entitlement, etc.)"
          ],
          "enum": [
            "ACTIVATION_REASON_UNSPECIFIED",
            "RESELLER_REVOKED_SUSPENSION",
            "CUSTOMER_ACCEPTED_PENDING_TOS",
            "RENEWAL_SETTINGS_CHANGED",
            "OTHER_ACTIVATION_REASON"
          ]
        },
        "provisionedService": {
          "description": "Service provisioned for an Entitlement.",
          "$ref": "GoogleCloudChannelV1alpha1ProvisionedService"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ActivateEntitlementRequest": {
      "description": "Request message for CloudChannelService.ActivateEntitlement.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ActivateEntitlementRequest",
      "properties": {
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RepricingAdjustment": {
      "id": "GoogleCloudChannelV1alpha1RepricingAdjustment",
      "properties": {
        "percentageAdjustment": {
          "$ref": "GoogleCloudChannelV1alpha1PercentageAdjustment",
          "description": "Flat markup or markdown on an entire bill."
        }
      },
      "description": "A type that represents the various adjustments you can apply to a bill.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListEntitlementsResponse": {
      "description": "Response message for CloudChannelService.ListEntitlements.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListEntitlementsResponse",
      "properties": {
        "entitlements": {
          "description": "The reseller customer's entitlements.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          }
        },
        "nextPageToken": {
          "description": "A token to list the next page of results. Pass to ListEntitlementsRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1Entitlement": {
      "description": "An entitlement is a representation of a customer's ability to use a service.",
      "type": "object",
      "id": "GoogleCloudChannelV1Entitlement",
      "properties": {
        "parameters": {
          "description": "Extended entitlement parameters. When creating an entitlement, valid parameter names and values are defined in the Offer.parameter_definitions. For Google Workspace, the following Parameters may be accepted as input: - max_units: The maximum assignable units for a flexible offer OR - num_units: The total commitment for commitment-based offers The response may additionally include the following output-only Parameters: - assigned_units: The number of licenses assigned to users. For Google Cloud billing subaccounts, the following Parameter may be accepted as input: - display_name: The display name of the billing subaccount.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1Parameter"
          }
        },
        "trialSettings": {
          "readOnly": true,
          "$ref": "GoogleCloudChannelV1TrialSettings",
          "description": "Output only. Settings for trial offers."
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement.",
          "type": "string"
        },
        "updateTime": {
          "description": "Output only. The time at which the entitlement is updated.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "suspensionReasons": {
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Entitlement was manually suspended by the Reseller.",
              "Trial ended.",
              "Entitlement renewal was canceled.",
              "Entitlement was automatically suspended on creation for pending ToS acceptance on customer.",
              "Other reasons (internal reasons, abuse, etc.)."
            ],
            "enum": [
              "SUSPENSION_REASON_UNSPECIFIED",
              "RESELLER_INITIATED",
              "TRIAL_ENDED",
              "RENEWAL_WITH_TYPE_CANCEL",
              "PENDING_TOS_ACCEPTANCE",
              "OTHER"
            ]
          },
          "readOnly": true,
          "description": "Output only. Enumerable of all current suspension reasons for an entitlement.",
          "type": "array"
        },
        "commitmentSettings": {
          "description": "Commitment settings for a commitment-based Offer. Required for commitment based offers.",
          "$ref": "GoogleCloudChannelV1CommitmentSettings"
        },
        "name": {
          "description": "Output only. Resource name of an entitlement in the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "readOnly": true,
          "format": "google-datetime",
          "description": "Output only. The time at which the entitlement is created.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Optional. This purchase order (PO) information is for resellers to use for their company tracking usage. If a purchaseOrderId value is given, it appears in the API responses and shows up in the invoice. The property accepts up to 80 plain text characters. This is only supported for Google Workspace entitlements.",
          "type": "string"
        },
        "provisionedService": {
          "description": "Output only. Service provisioning details for the entitlement.",
          "$ref": "GoogleCloudChannelV1ProvisionedService",
          "readOnly": true
        },
        "priceReferenceId": {
          "description": "Optional. Price reference ID for the offer. Only for offers that require additional price information. Used to guarantee that the pricing is consistent between quoting the offer and placing the order.",
          "type": "string"
        },
        "provisioningState": {
          "description": "Output only. Current provisioning state of the entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "The entitlement is currently active.",
            "The entitlement is currently suspended."
          ],
          "enum": [
            "PROVISIONING_STATE_UNSPECIFIED",
            "ACTIVE",
            "SUSPENDED"
          ],
          "readOnly": true
        },
        "associationInfo": {
          "description": "Association information to other entitlements.",
          "$ref": "GoogleCloudChannelV1AssociationInfo"
        },
        "offer": {
          "description": "Required. The offer resource name for which the entitlement is to be created. Takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ReportJob": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1ReportJob",
      "properties": {
        "reportStatus": {
          "$ref": "GoogleCloudChannelV1alpha1ReportStatus",
          "description": "The current status of report generation."
        },
        "name": {
          "description": "Required. The resource name of a report job. Name uses the format: `accounts/{account_id}/reportJobs/{report_job_id}`",
          "type": "string"
        }
      },
      "description": "The result of a RunReportJob operation. Contains the name to use in FetchReportResultsRequest.report_job and the status of the operation.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangePlanRequest": {
      "description": "Request message for CloudChannelService.ChangePlan.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ChangePlanRequest",
      "properties": {
        "offer": {
          "description": "Required. New Offer applicable to a new plan. The offer takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "requestId": {
          "description": "You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "numUnits": {
          "description": "New num units for the entitlement. For seat-based offers, this is the number of seats. For license based offers, this is the number of licenses. Required for commitment based offers.",
          "type": "integer",
          "format": "int32"
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement when setting up billing on a trial subscription. This field is only relevant for multi-currency accounts. It should be left empty for single currency accounts.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Purchase order ID provided by the reseller. Optional",
          "type": "string"
        },
        "maxUnits": {
          "description": "New max units for the entitlement. It represents the maximum units a flexible offer is allowed to assign. Required for flexible offers.",
          "type": "integer",
          "format": "int32"
        },
        "externalCorrelationId": {
          "description": "An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement. Optional.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityInfo": {
      "id": "GoogleCloudChannelV1alpha1OpportunityInfo",
      "properties": {
        "productFamily": {
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Google Cloud Platform.",
              "Google Workspace.",
              "Maps.",
              "Chrome",
              "PSO"
            ],
            "enum": [
              "PRODUCT_FAMILY_UNSPECIFIED",
              "GOOGLE_CLOUD_PLATFORM",
              "GOOGLE_WORKSPACE",
              "MAPS",
              "CHROME",
              "PSO"
            ]
          },
          "description": "Optional. Product Family the Opportunity belongs to. For MVP, only 1 Product Family is supported. Required for ISV Solution Connect Opportunity. Not allowed for Non-ISV Opportunities, as derived from the Product Category.",
          "type": "array"
        },
        "productCategory": {
          "items": {
            "type": "string",
            "enumDescriptions": [
              "Not used.",
              "Google Gemini AI.",
              "GCP AI.",
              "GCP Analytics.",
              "GCP Anthos.",
              "GCP Apigee.",
              "GCP Appsheet.",
              "GCP Compute.",
              "GCP Databases.",
              "GCP Distributed Cloud.",
              "GCP Duet AI.",
              "GCP GPU.",
              "GCP Looker.",
              "GCP Network.",
              "GCP Other.",
              "GCP Other Security. Not currently supported.",
              "GCP Platform.",
              "GCP SCCE. Not currently supported.",
              "GCP Serverless.",
              "GCP Storage.",
              "GCP Support.",
              "Google Cloud Identity.",
              "Google Maps.",
              "Google Vault.",
              "Google Voice.",
              "Google Workspace Core.",
              "Google Workspace Edu.",
              "Google Agentspace. Use GCP_GEMINI_ENTERPRISE instead.",
              "Chrome OS - Enterprise",
              "Chrome OS - Education",
              "PSO - Training",
              "PSO - Consulting",
              "GCP - Google Secops",
              "GCP - Google Threat Intelligence",
              "GCP - Chrome Enterprise Premium",
              "GCP - reCAPTCHA",
              "GCP - Managed Hunt",
              "GCP - Managed Defense",
              "GCP - Web Risk",
              "GCP - Mandiant Consulting Services",
              "GCP Security Command Center",
              "GCP - Gemini Enterprise"
            ],
            "enumDeprecated": [
              false,
              true,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              true,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false,
              false
            ],
            "enum": [
              "PRODUCT_CATEGORY_UNSPECIFIED",
              "GOOGLE_GEMINI_AI",
              "GCP_AI",
              "GCP_ANALYTICS",
              "GCP_ANTHOS",
              "GCP_APIGEE",
              "GCP_APPSHEET",
              "GCP_COMPUTE",
              "GCP_DATABASES",
              "GCP_DISTRIBUTED_CLOUD",
              "GCP_DUET_AI",
              "GCP_GPU",
              "GCP_LOOKER",
              "GCP_NETWORK",
              "GCP_OTHER",
              "GCP_OTHER_SECURITY",
              "GCP_PLATFORM",
              "GCP_SCCE",
              "GCP_SERVERLESS",
              "GCP_STORAGE",
              "GCP_SUPPORT",
              "GOOGLE_CLOUD_IDENTITY",
              "GOOGLE_MAPS",
              "GOOGLE_VAULT",
              "GOOGLE_VOICE",
              "GOOGLE_WORKSPACE_CORE",
              "GOOGLE_WORKSPACE_EDU",
              "GCP_AGENTSPACE",
              "CHROME_OS_ENTERPRISE",
              "CHROME_OS_EDUCATION",
              "PSO_TRAINING",
              "PSO_CONSULTING",
              "GCP_GOOGLE_SECOPS",
              "GCP_GOOGLE_THREAT_INTELLIGENCE",
              "GCP_CHROME_ENTERPRISE_PREMIUM",
              "GCP_RECAPTCHA",
              "GCP_MANAGED_HUNT",
              "GCP_MANAGED_DEFENSE",
              "GCP_WEBRISK",
              "GCP_MANDIANT_CONSULTING_SERVICES",
              "GCP_SCC",
              "GCP_GEMINI_ENTERPRISE"
            ]
          },
          "description": "Optional. Product Category the Opportunity belongs to. For MVP, only 1 Product Category is supported. Required for non-ISV Opportunities. For ISV Solution Connect, the Product Category should be empty. Can't be edited after the Opportunity is Accepted.",
          "type": "array"
        },
        "opportunityAmount": {
          "readOnly": true,
          "description": "Output only. Total estimate for the Opportunity calculated based on the Opportunity Line items.",
          "$ref": "GoogleTypeMoney"
        },
        "displayName": {
          "description": "Optional. Display name for the Opportunity. Available in Limited view. Maximum character length: 120.",
          "type": "string"
        },
        "partnerEntity": {
          "description": "Required. Partner who sources the deal. In case of 2-tier Partners, this is the Distributor id. Format: partners/{id}",
          "type": "string"
        },
        "indirectPartnerEntity": {
          "description": "Optional. If a 2-tier deal provide the Indirect Reseller involved. Format: partners/{id}",
          "type": "string"
        },
        "gcpWatermark": {
          "readOnly": true,
          "format": "double",
          "description": "Output only. GCP Watermark.",
          "type": "number"
        },
        "description": {
          "description": "Optional. Opportunity description. Available in Limited view.",
          "type": "string"
        },
        "confidential": {
          "description": "Optional. Flag to identify if the Opportunity is confidential and needs to have restricted access. Default: false.",
          "type": "boolean"
        }
      },
      "description": "Contains details about the Opportunity.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1OperationMetadata": {
      "id": "GoogleCloudChannelV1alpha1OperationMetadata",
      "properties": {
        "operationType": {
          "description": "The RPC that initiated this Long Running Operation.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Long Running Operation was triggered by CreateEntitlement.",
            "Long Running Operation was triggered by ChangeQuantity.",
            "Long Running Operation was triggered by ChangeRenewalSettings.",
            "Long Running Operation was triggered by ChangePlan.",
            "Long Running Operation was triggered by StartPaidService.",
            "Long Running Operation was triggered by ChangeSku.",
            "Long Running Operation was triggered by ActivateEntitlement.",
            "Long Running Operation was triggered by SuspendEntitlement.",
            "Long Running Operation was triggered by CancelEntitlement.",
            "Long Running Operation was triggered by TransferEntitlements.",
            "Long Running Operation was triggered by TransferEntitlementsToGoogle.",
            "Long Running Operation was triggered by ChangeOffer.",
            "Long Running Operation was triggered by ChangeParameters.",
            "Long Running Operation was triggered by ProvisionCloudIdentity."
          ],
          "enum": [
            "OPERATION_TYPE_UNSPECIFIED",
            "CREATE_ENTITLEMENT",
            "CHANGE_QUANTITY",
            "CHANGE_RENEWAL_SETTINGS",
            "CHANGE_PLAN",
            "START_PAID_SERVICE",
            "CHANGE_SKU",
            "ACTIVATE_ENTITLEMENT",
            "SUSPEND_ENTITLEMENT",
            "CANCEL_ENTITLEMENT",
            "TRANSFER_ENTITLEMENTS",
            "TRANSFER_ENTITLEMENTS_TO_GOOGLE",
            "CHANGE_OFFER",
            "CHANGE_PARAMETERS",
            "PROVISION_CLOUD_IDENTITY"
          ]
        }
      },
      "description": "Provides contextual information about a google.longrunning.Operation.",
      "type": "object"
    },
    "GoogleCloudChannelV1ReportResultsMetadata": {
      "description": "The features describing the data. Returned by CloudChannelReportsService.RunReportJob and CloudChannelReportsService.FetchReportResults.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1ReportResultsMetadata",
      "properties": {
        "rowCount": {
          "format": "int64",
          "description": "The total number of rows of data in the final report.",
          "type": "string"
        },
        "dateRange": {
          "$ref": "GoogleCloudChannelV1DateRange",
          "description": "The date range of reported usage."
        },
        "report": {
          "$ref": "GoogleCloudChannelV1Report",
          "description": "Details of the completed report."
        },
        "precedingDateRange": {
          "$ref": "GoogleCloudChannelV1DateRange",
          "description": "The usage dates immediately preceding `date_range` with the same duration. Use this to calculate trending usage and costs. This is only populated if you request trending data. For example, if `date_range` is July 1-15, `preceding_date_range` will be June 16-30."
        }
      }
    },
    "GoogleCloudChannelV1alpha1Report": {
      "description": "The ID and description of a report that was used to generate report data. For example, \"Google Cloud Daily Spend\", \"Google Workspace License Activity\", etc.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1Report",
      "properties": {
        "columns": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Column"
          },
          "description": "The list of columns included in the report. This defines the schema of the report results.",
          "type": "array"
        },
        "description": {
          "description": "A description of other aspects of the report, such as the products it supports.",
          "type": "string"
        },
        "name": {
          "description": "Required. The report's resource name. Specifies the account and report used to generate report data. The report_id identifier is a UID (for example, `613bf59q`). Name uses the format: accounts/{account_id}/reports/{report_id}",
          "type": "string"
        },
        "displayName": {
          "description": "A human-readable name for this report.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1WinLossInfo": {
      "id": "GoogleCloudChannelV1alpha1WinLossInfo",
      "properties": {
        "lostMainReason": {
          "readOnly": true,
          "description": "Output only. Lost main reason.",
          "type": "string"
        },
        "wonReason": {
          "readOnly": true,
          "description": "Output only. Won reason.",
          "type": "string"
        },
        "lostRejectedReasonDetails": {
          "readOnly": true,
          "description": "Output only. Lost rejected reason details.",
          "type": "string"
        },
        "winLossProducts": {
          "description": "Output only. Win/loss products.",
          "type": "array",
          "readOnly": true,
          "items": {
            "type": "string"
          }
        },
        "lostReason": {
          "description": "Output only. Lost reason.",
          "type": "string",
          "readOnly": true
        },
        "winLossAdditionalContext": {
          "description": "Output only. Win/loss additional context.",
          "type": "string",
          "readOnly": true
        },
        "winMainReason": {
          "description": "Output only. Win main reason.",
          "type": "string",
          "readOnly": true
        }
      },
      "description": "Win Loss Details.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Customer": {
      "description": "Entity representing a customer of a reseller or distributor.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Customer",
      "properties": {
        "domain": {
          "description": "Required. The customer's primary domain. Must match the primary contact email's domain.",
          "type": "string"
        },
        "alternateEmail": {
          "description": "Secondary contact email. You need to provide an alternate email to create different domains if a primary contact email already exists. Users will receive a notification with credentials when you create an admin.google.com account. Secondary emails are also recovery email addresses. Alternate emails are optional when you create Team customers.",
          "type": "string"
        },
        "name": {
          "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "description": "Output only. Time when the customer was created.",
          "type": "string",
          "format": "google-datetime",
          "readOnly": true
        },
        "correlationId": {
          "description": "Optional. External CRM ID for the customer. Populated only if a CRM ID exists for this customer.",
          "type": "string"
        },
        "languageCode": {
          "description": "Optional. The BCP-47 language code, such as \"en-US\" or \"sr-Latn\". For more information, see https://www.unicode.org/reports/tr35/#Unicode_locale_identifier.",
          "type": "string"
        },
        "orgPostalAddress": {
          "description": "Required. The organization address for the customer. To enforce US laws and embargoes, we require a region, postal code, and address lines. You must provide valid addresses for every customer. To set the customer's language, use the Customer-level language code.",
          "$ref": "GoogleTypePostalAddress"
        },
        "cloudIdentityId": {
          "description": "Output only. The customer's Cloud Identity ID if the customer has a Cloud Identity resource.",
          "type": "string",
          "readOnly": true
        },
        "orgDisplayName": {
          "description": "Required. Name of the organization that the customer entity represents.",
          "type": "string"
        },
        "customerAttestationState": {
          "description": "Optional. Indicate if a customer is attesting about the correctness of provided information. Only required if creating a GCP Entitlement. NOTE: This field will be mandatory for all new GCP customers starting Aug 31st, 2026 and this field will also be required for all existing customers purchasing new GCP Entitlements.",
          "type": "string",
          "enumDescriptions": [
            "Default value if not set yet",
            "Customer is exempt from attesting based on exemption list at https://cloud.google.com/terms/direct-tos-exemptions. Contact information of customer will be mandatory.",
            "Customer is not exempt and has verified the information provided is correct. Contact information of customer will be mandatory."
          ],
          "enum": [
            "CUSTOMER_ATTESTATION_STATE_UNSPECIFIED",
            "EXEMPT",
            "NON_EXEMPT_AND_INFO_VERIFIED"
          ]
        },
        "adminConsoleUrl": {
          "description": "Output only. URL of Customer's Admin console dashboard. Populated only if a Cloud Identity resource exists for this customer. Deprecated: Use CloudIdentityInfo.admin_console_uri instead.",
          "deprecated": true,
          "type": "string",
          "readOnly": true
        },
        "cloudIdentityInfo": {
          "description": "Output only. Cloud Identity information for the customer. Populated only if a Cloud Identity account exists for this customer.",
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
          "readOnly": true
        },
        "channelPartnerId": {
          "description": "Cloud Identity ID of the customer's channel partner. Populated only if a channel partner exists for this customer.",
          "type": "string"
        },
        "primaryContactInfo": {
          "description": "Primary contact info.",
          "$ref": "GoogleCloudChannelV1alpha1ContactInfo"
        },
        "updateTime": {
          "description": "Output only. Time when the customer was updated.",
          "type": "string",
          "format": "google-datetime",
          "readOnly": true
        }
      }
    },
    "GoogleCloudChannelV1alpha1PriceByResource": {
      "description": "Represents price by resource type.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PriceByResource",
      "properties": {
        "price": {
          "$ref": "GoogleCloudChannelV1alpha1Price",
          "description": "Price of the Offer. Present if there are no price phases."
        },
        "pricePhases": {
          "description": "Specifies the price by time range.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PricePhase"
          }
        },
        "resourceType": {
          "description": "Resource Type. Example: SEAT",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Seat.",
            "Monthly active user.",
            "GB (used for storage SKUs).",
            "Active licensed users(for Voice SKUs).",
            "Voice usage.",
            "For IaaS SKUs like Google Cloud, monetization is based on usage accrued on your billing account irrespective of the type of monetizable resource. This enum represents an aggregated resource/container for all usage SKUs on a billing account. Currently, only applicable to Google Cloud.",
            "For Google Cloud subscriptions like Anthos or SAP."
          ],
          "enum": [
            "RESOURCE_TYPE_UNSPECIFIED",
            "SEAT",
            "MAU",
            "GB",
            "LICENSED_USER",
            "MINUTES",
            "IAAS_USAGE",
            "SUBSCRIPTION"
          ]
        }
      }
    },
    "GoogleCloudChannelV1TrialSettings": {
      "id": "GoogleCloudChannelV1TrialSettings",
      "properties": {
        "trial": {
          "description": "Determines if the entitlement is in a trial or not: * `true` - The entitlement is in trial. * `false` - The entitlement is not in trial.",
          "type": "boolean"
        },
        "endTime": {
          "format": "google-datetime",
          "description": "Date when the trial ends. The value is in milliseconds using the UNIX Epoch format. See an example [Epoch converter](https://www.epochconverter.com).",
          "type": "string"
        }
      },
      "description": "Settings for trial offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CustomerInfo": {
      "id": "GoogleCloudChannelV1alpha1CustomerInfo",
      "properties": {
        "customerDetails": {
          "$ref": "GoogleCloudChannelV1alpha1CustomerDetails",
          "description": "Required. Firm details needed for creating a new customer or for mapping to an existing customer. Available in Limited view."
        },
        "region": {
          "description": "Required. Geographical region where end customer is located Note: Partner needs to have Sell authorization in this region to qualify for deal registration incentives.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "Australia & New Zealand",
            "Central & Eastern Europe",
            "Germany, Austria, & Switzerland",
            "France",
            "India",
            "Japan",
            "LATAM - Brazil",
            "LATAM - Spanish speaking",
            "Northern Europe",
            "North America",
            "Other Asia Pacific",
            "Southern Europe and Emerging Markets",
            "UK & Ireland"
          ],
          "enum": [
            "REGION_UNSPECIFIED",
            "ANZ",
            "CEE",
            "DACH",
            "FRANCE",
            "INDIA",
            "JAPAN",
            "LATAM_BRAZIL",
            "LATAM_SPANISH_SPEAKING",
            "NE",
            "NORTH_AMERICA",
            "OTHER_ASIA_PACIFIC",
            "SEEMEA",
            "UK_AND_I"
          ]
        },
        "contact": {
          "description": "Optional. Primary Customer contact that will be added to the Opportunity Contact Roles.",
          "$ref": "GoogleCloudChannelV1alpha1Contact"
        }
      },
      "description": "Customer Information provided during Opportunity Creation",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest": {
      "description": "Request message for CloudChannelService.ListProvisionableCloudIdentityTypes",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest",
      "properties": {
        "domain": {
          "description": "Required. The customer's domain.",
          "type": "string"
        },
        "channelPartnerId": {
          "description": "Optional. The Cloud Identity Id of the channel partner under the account to list ProvisionableCloudIdentityTypes for",
          "type": "string"
        },
        "primaryAdminEmail": {
          "description": "Optional. The primary admin email of the customer.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Parameter": {
      "description": "Definition for extended entitlement parameters.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Parameter",
      "properties": {
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "editable": {
          "readOnly": true,
          "description": "Output only. Specifies whether this parameter is allowed to be changed. For example, for a Google Workspace Business Starter entitlement in commitment plan, num_units is editable when entitlement is active.",
          "type": "boolean"
        },
        "value": {
          "$ref": "GoogleCloudChannelV1alpha1Value",
          "description": "Value of the parameter."
        }
      }
    },
    "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo": {
      "id": "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo",
      "properties": {
        "productCategory": {
          "description": "Optional. Product Category for which info is being provided. Required for Non-ISV Opportunities.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Google Gemini AI.",
            "GCP AI.",
            "GCP Analytics.",
            "GCP Anthos.",
            "GCP Apigee.",
            "GCP Appsheet.",
            "GCP Compute.",
            "GCP Databases.",
            "GCP Distributed Cloud.",
            "GCP Duet AI.",
            "GCP GPU.",
            "GCP Looker.",
            "GCP Network.",
            "GCP Other.",
            "GCP Other Security. Not currently supported.",
            "GCP Platform.",
            "GCP SCCE. Not currently supported.",
            "GCP Serverless.",
            "GCP Storage.",
            "GCP Support.",
            "Google Cloud Identity.",
            "Google Maps.",
            "Google Vault.",
            "Google Voice.",
            "Google Workspace Core.",
            "Google Workspace Edu.",
            "Google Agentspace. Use GCP_GEMINI_ENTERPRISE instead.",
            "Chrome OS - Enterprise",
            "Chrome OS - Education",
            "PSO - Training",
            "PSO - Consulting",
            "GCP - Google Secops",
            "GCP - Google Threat Intelligence",
            "GCP - Chrome Enterprise Premium",
            "GCP - reCAPTCHA",
            "GCP - Managed Hunt",
            "GCP - Managed Defense",
            "GCP - Web Risk",
            "GCP - Mandiant Consulting Services",
            "GCP Security Command Center",
            "GCP - Gemini Enterprise"
          ],
          "enumDeprecated": [
            false,
            true,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            true,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false,
            false
          ],
          "enum": [
            "PRODUCT_CATEGORY_UNSPECIFIED",
            "GOOGLE_GEMINI_AI",
            "GCP_AI",
            "GCP_ANALYTICS",
            "GCP_ANTHOS",
            "GCP_APIGEE",
            "GCP_APPSHEET",
            "GCP_COMPUTE",
            "GCP_DATABASES",
            "GCP_DISTRIBUTED_CLOUD",
            "GCP_DUET_AI",
            "GCP_GPU",
            "GCP_LOOKER",
            "GCP_NETWORK",
            "GCP_OTHER",
            "GCP_OTHER_SECURITY",
            "GCP_PLATFORM",
            "GCP_SCCE",
            "GCP_SERVERLESS",
            "GCP_STORAGE",
            "GCP_SUPPORT",
            "GOOGLE_CLOUD_IDENTITY",
            "GOOGLE_MAPS",
            "GOOGLE_VAULT",
            "GOOGLE_VOICE",
            "GOOGLE_WORKSPACE_CORE",
            "GOOGLE_WORKSPACE_EDU",
            "GCP_AGENTSPACE",
            "CHROME_OS_ENTERPRISE",
            "CHROME_OS_EDUCATION",
            "PSO_TRAINING",
            "PSO_CONSULTING",
            "GCP_GOOGLE_SECOPS",
            "GCP_GOOGLE_THREAT_INTELLIGENCE",
            "GCP_CHROME_ENTERPRISE_PREMIUM",
            "GCP_RECAPTCHA",
            "GCP_MANAGED_HUNT",
            "GCP_MANAGED_DEFENSE",
            "GCP_WEBRISK",
            "GCP_MANDIANT_CONSULTING_SERVICES",
            "GCP_SCC",
            "GCP_GEMINI_ENTERPRISE"
          ]
        },
        "quantity": {
          "description": "Optional. Number of seats or licenses. Default: 1. Can't be edited after the Opportunity is Accepted.",
          "type": "integer",
          "format": "int32"
        },
        "productFamily": {
          "description": "Optional. Product Family for which info is being provided. Required for ISV Opportunities.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Google Cloud Platform.",
            "Google Workspace.",
            "Maps.",
            "Chrome",
            "PSO"
          ],
          "enum": [
            "PRODUCT_FAMILY_UNSPECIFIED",
            "GOOGLE_CLOUD_PLATFORM",
            "GOOGLE_WORKSPACE",
            "MAPS",
            "CHROME",
            "PSO"
          ]
        },
        "dealSize": {
          "$ref": "GoogleTypeMoney",
          "description": "Required. Target budget/estimated cost. Can't be edited after the Opportunity is Accepted."
        }
      },
      "description": "Product line information for the Opportunity.",
      "type": "object"
    },
    "GoogleCloudChannelV1Value": {
      "id": "GoogleCloudChannelV1Value",
      "properties": {
        "boolValue": {
          "description": "Represents a boolean value.",
          "type": "boolean"
        },
        "int64Value": {
          "description": "Represents an int64 value.",
          "type": "string",
          "format": "int64"
        },
        "doubleValue": {
          "format": "double",
          "description": "Represents a double value.",
          "type": "number"
        },
        "protoValue": {
          "description": "Represents an 'Any' proto value.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "stringValue": {
          "description": "Represents a string value.",
          "type": "string"
        }
      },
      "description": "Data type and value of a parameter.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListTransferableSkusRequest": {
      "id": "GoogleCloudChannelV1alpha1ListTransferableSkusRequest",
      "properties": {
        "languageCode": {
          "description": "The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\". Optional.",
          "type": "string"
        },
        "authToken": {
          "description": "Optional. The super admin of the resold customer generates this token to authorize a reseller to access their Cloud Identity and purchase entitlements on their behalf. You can omit this token after authorization. See https://support.google.com/a/answer/7643790 for more details.",
          "type": "string"
        },
        "customerName": {
          "description": "A reseller is required to create a customer and use the resource name of the created customer here. Customer_name uses the format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "pageSize": {
          "description": "The requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 SKUs. The maximum value is 1000; the server will coerce values above 1000. Optional.",
          "type": "integer",
          "format": "int32"
        },
        "cloudIdentityId": {
          "description": "Customer's Cloud Identity ID",
          "type": "string"
        },
        "pageToken": {
          "description": "A token for a page of results other than the first page. Obtained using ListTransferableSkusResponse.next_page_token of the previous CloudChannelService.ListTransferableSkus call. Optional.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.ListTransferableSkus",
      "type": "object"
    },
    "GoogleTypePhoneNumberShortCode": {
      "id": "GoogleTypePhoneNumberShortCode",
      "properties": {
        "regionCode": {
          "description": "Required. The BCP-47 region code of the location where calls to this short code can be made, such as \"US\" and \"BB\". Reference(s): - http://www.unicode.org/reports/tr35/#unicode_region_subtag",
          "type": "string"
        },
        "number": {
          "description": "Required. The short code digits, without a leading plus ('+') or country calling code. For example \"611\".",
          "type": "string"
        }
      },
      "description": "An object representing a short code, which is a phone number that is typically much shorter than regular phone numbers and can be used to address messages in MMS and SMS systems, as well as for abbreviated dialing (For example \"Text 611 to see how many minutes you have remaining on your plan.\"). Short codes are restricted to a region and are not internationally dialable, which means the same short code can exist in different regions, with different usage and pricing, even if those regions share the same country calling code (For example: US and CA).",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CommitmentSettings": {
      "id": "GoogleCloudChannelV1alpha1CommitmentSettings",
      "properties": {
        "startTime": {
          "description": "Output only. Commitment start timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "renewalSettings": {
          "$ref": "GoogleCloudChannelV1alpha1RenewalSettings",
          "description": "Optional. Renewal settings applicable for a commitment-based Offer."
        },
        "endTime": {
          "description": "Output only. Commitment end timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        }
      },
      "description": "Commitment settings for commitment-based offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest": {
      "description": "Request message for CloudChannelService.TransferEntitlementsToGoogle.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest",
      "properties": {
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "entitlements": {
          "description": "Required. The entitlements to transfer to Google.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1EntitlementEvent": {
      "description": "Represents Pub/Sub message content describing entitlement update.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1EntitlementEvent",
      "properties": {
        "eventType": {
          "description": "Type of event which happened for the entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "A new entitlement was created.",
            "The offer type associated with an entitlement was changed. This is not triggered if an entitlement converts from a commit offer to a flexible offer as part of a renewal.",
            "Annual commitment for a commit plan was changed.",
            "An annual entitlement was renewed.",
            "Entitlement was suspended.",
            "Entitlement was unsuspended.",
            "Entitlement was cancelled.",
            "Entitlement was upgraded or downgraded (e.g. from Google Workspace Business Standard to Google Workspace Business Plus).",
            "The renewal settings of an entitlement has changed.",
            "Paid service has started on trial entitlement.",
            "License was assigned to or revoked from a user.",
            "License cap was changed for the entitlement."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "CREATED",
            "PRICE_PLAN_SWITCHED",
            "COMMITMENT_CHANGED",
            "RENEWED",
            "SUSPENDED",
            "ACTIVATED",
            "CANCELLED",
            "SKU_CHANGED",
            "RENEWAL_SETTING_CHANGED",
            "PAID_SERVICE_STARTED",
            "LICENSE_ASSIGNMENT_CHANGED",
            "LICENSE_CAP_CHANGED"
          ]
        },
        "entitlement": {
          "description": "Resource name of an entitlement of the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        }
      }
    },
    "GoogleLongrunningListOperationsResponse": {
      "id": "GoogleLongrunningListOperationsResponse",
      "properties": {
        "operations": {
          "items": {
            "$ref": "GoogleLongrunningOperation"
          },
          "description": "A list of operations that matches the specified filter in the request.",
          "type": "array"
        },
        "unreachable": {
          "items": {
            "type": "string"
          },
          "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        }
      },
      "description": "The response message for Operations.ListOperations.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Period": {
      "id": "GoogleCloudChannelV1alpha1Period",
      "properties": {
        "duration": {
          "description": "Total duration of Period Type defined.",
          "type": "integer",
          "format": "int32"
        },
        "periodType": {
          "description": "Period Type.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Day.",
            "Month.",
            "Year."
          ],
          "enum": [
            "PERIOD_TYPE_UNSPECIFIED",
            "DAY",
            "MONTH",
            "YEAR"
          ]
        }
      },
      "description": "Represents period in days/months/years.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Contact": {
      "id": "GoogleCloudChannelV1alpha1Contact",
      "properties": {
        "email": {
          "description": "Required. Email.",
          "type": "string"
        },
        "phone": {
          "description": "Optional. Phone number. Only supports setting e164_number.",
          "$ref": "GoogleTypePhoneNumber"
        },
        "givenName": {
          "description": "Required. Contact's first name.",
          "type": "string"
        },
        "familyName": {
          "description": "Required. Contact's last name.",
          "type": "string"
        }
      },
      "description": "Contact Details.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsResponse": {
      "description": "Response message for CloudChannelService.TransferEntitlements. This is put in the response field of google.longrunning.Operation.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsResponse",
      "properties": {
        "entitlements": {
          "description": "The transferred entitlements.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse": {
      "id": "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse",
      "properties": {
        "channelPartnerRepricingConfigs": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
          },
          "description": "The repricing configs for this channel partner.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListChannelPartnerRepricingConfigsRequest.page_token to obtain that page.",
          "type": "string"
        }
      },
      "description": "Response message for CloudChannelService.ListChannelPartnerRepricingConfigs.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1BillableSku": {
      "id": "GoogleCloudChannelV1alpha1BillableSku",
      "properties": {
        "skuDisplayName": {
          "description": "Unique human readable name for the SKU.",
          "type": "string"
        },
        "service": {
          "description": "Resource name of Service which contains Repricing SKU. Format: services/{service}. Example: \"services/B7D9-FDCB-15D8\".",
          "type": "string"
        },
        "sku": {
          "description": "Resource name of Billable SKU. Format: billableSkus/{sku}. Example: billableSkus/6E1B-6634-470F\".",
          "type": "string"
        },
        "serviceDisplayName": {
          "description": "Unique human readable name for the Service.",
          "type": "string"
        }
      },
      "description": "Represents the Billable SKU information.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1FetchReportResultsResponse": {
      "description": "Response message for CloudChannelReportsService.FetchReportResults. Contains a tabular representation of the report results.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1FetchReportResultsResponse",
      "properties": {
        "reportMetadata": {
          "description": "The metadata for the report results (display name, columns, row count, and date ranges).",
          "$ref": "GoogleCloudChannelV1alpha1ReportResultsMetadata"
        },
        "nextPageToken": {
          "description": "Pass this token to FetchReportResultsRequest.page_token to retrieve the next page of results.",
          "type": "string"
        },
        "rows": {
          "description": "The report's lists of values. Each row follows the settings and ordering of the columns from `report_metadata`.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Row"
          }
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1PurchaseEligibility": {
      "description": "Specifies purchase eligibility of a SKU.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PurchaseEligibility",
      "properties": {
        "ineligibilityReason": {
          "description": "Specified the reason for ineligibility.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Reseller needs to accept TOS before purchasing the SKU."
          ],
          "enum": [
            "REASON_UNSPECIFIED",
            "ACCEPT_TOS"
          ]
        },
        "isEligible": {
          "description": "Whether reseller is eligible to purchase the SKU.",
          "type": "boolean"
        },
        "description": {
          "description": "Localized description if reseller is not eligible to purchase the SKU.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1DateRange": {
      "description": "A representation of usage or invoice date ranges.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1DateRange",
      "properties": {
        "invoiceEndDate": {
          "$ref": "GoogleTypeDate",
          "description": "The latest invoice date (inclusive). If this value is not the last day of a month, this will move it forward to the last day of the given month."
        },
        "usageStartDateTime": {
          "$ref": "GoogleTypeDateTime",
          "description": "The earliest usage date time (inclusive). If you use time groupings (daily, weekly, etc), each group uses midnight to midnight (Pacific time). The usage start date is rounded down to include all usage from the specified date. We recommend that clients pass `usage_start_date_time` in Pacific time."
        },
        "usageEndDateTime": {
          "$ref": "GoogleTypeDateTime",
          "description": "The latest usage date time (exclusive). If you use time groupings (daily, weekly, etc), each group uses midnight to midnight (Pacific time). The usage end date is rounded down to include all usage from the specified date. We recommend that clients pass `usage_start_date_time` in Pacific time."
        },
        "invoiceStartDate": {
          "$ref": "GoogleTypeDate",
          "description": "The earliest invoice date (inclusive). If this value is not the first day of a month, this will move it back to the first day of the given month."
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListSkusResponse": {
      "id": "GoogleCloudChannelV1alpha1ListSkusResponse",
      "properties": {
        "skus": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Sku"
          },
          "description": "The list of SKUs requested.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      },
      "description": "Response message for ListSkus.",
      "type": "object"
    },
    "GoogleCloudChannelV1EntitlementEvent": {
      "id": "GoogleCloudChannelV1EntitlementEvent",
      "properties": {
        "entitlement": {
          "description": "Resource name of an entitlement of the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        },
        "eventType": {
          "description": "Type of event which happened for the entitlement.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "A new entitlement was created.",
            "The offer type associated with an entitlement was changed. This is not triggered if an entitlement converts from a commit offer to a flexible offer as part of a renewal.",
            "Annual commitment for a commit plan was changed.",
            "An annual entitlement was renewed.",
            "Entitlement was suspended.",
            "Entitlement was unsuspended.",
            "Entitlement was cancelled.",
            "Entitlement was upgraded or downgraded (e.g. from Google Workspace Business Standard to Google Workspace Business Plus).",
            "The renewal settings of an entitlement has changed.",
            "Paid service has started on trial entitlement.",
            "License was assigned to or revoked from a user.",
            "License cap was changed for the entitlement."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "CREATED",
            "PRICE_PLAN_SWITCHED",
            "COMMITMENT_CHANGED",
            "RENEWED",
            "SUSPENDED",
            "ACTIVATED",
            "CANCELLED",
            "SKU_CHANGED",
            "RENEWAL_SETTING_CHANGED",
            "PAID_SERVICE_STARTED",
            "LICENSE_ASSIGNMENT_CHANGED",
            "LICENSE_CAP_CHANGED"
          ]
        }
      },
      "description": "Represents Pub/Sub message content describing entitlement update.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ReportResultsMetadata": {
      "description": "The features describing the data. Returned by CloudChannelReportsService.RunReportJob and CloudChannelReportsService.FetchReportResults.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ReportResultsMetadata",
      "properties": {
        "report": {
          "$ref": "GoogleCloudChannelV1alpha1Report",
          "description": "Details of the completed report."
        },
        "precedingDateRange": {
          "description": "The usage dates immediately preceding `date_range` with the same duration. Use this to calculate trending usage and costs. This is only populated if you request trending data. For example, if `date_range` is July 1-15, `preceding_date_range` will be June 16-30.",
          "$ref": "GoogleCloudChannelV1alpha1DateRange"
        },
        "rowCount": {
          "description": "The total number of rows of data in the final report.",
          "type": "string",
          "format": "int64"
        },
        "dateRange": {
          "description": "The date range of reported usage.",
          "$ref": "GoogleCloudChannelV1alpha1DateRange"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1TransferEligibility": {
      "id": "GoogleCloudChannelV1alpha1TransferEligibility",
      "properties": {
        "ineligibilityReason": {
          "description": "Specified the reason for ineligibility.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Reseller needs to accept TOS before transferring the SKU.",
            "Reseller not eligible to sell the SKU.",
            "SKU subscription is suspended",
            "The reseller is not authorized to transact on this Product. See https://support.google.com/channelservices/answer/9759265"
          ],
          "enum": [
            "REASON_UNSPECIFIED",
            "PENDING_TOS_ACCEPTANCE",
            "SKU_NOT_ELIGIBLE",
            "SKU_SUSPENDED",
            "CHANNEL_PARTNER_NOT_AUTHORIZED_FOR_SKU"
          ]
        },
        "isEligible": {
          "description": "Whether reseller is eligible to transfer the SKU.",
          "type": "boolean"
        },
        "description": {
          "description": "Localized description if reseller is not eligible to transfer the SKU.",
          "type": "string"
        }
      },
      "description": "Specifies transfer eligibility of a SKU.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1SubscriberEvent": {
      "description": "Represents information which resellers will get as part of notification from Pub/Sub.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1SubscriberEvent",
      "properties": {
        "customerEvent": {
          "$ref": "GoogleCloudChannelV1alpha1CustomerEvent",
          "description": "Customer event sent as part of Pub/Sub event to partners."
        },
        "channelPartnerEvent": {
          "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerEvent",
          "description": "Channel Partner event sent as part of Pub/Sub event to partners."
        },
        "opportunityEvent": {
          "$ref": "GoogleCloudChannelV1alpha1OpportunityEvent",
          "description": "Opportunity event sent as part of Pub/Sub event to partners/integrators."
        },
        "entitlementEvent": {
          "$ref": "GoogleCloudChannelV1alpha1EntitlementEvent",
          "description": "Entitlement event sent as part of Pub/Sub event to partners."
        }
      }
    },
    "GoogleCloudChannelV1alpha1Plan": {
      "description": "The payment plan for the Offer. Describes how to make a payment.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Plan",
      "properties": {
        "paymentCycle": {
          "description": "Describes how frequently the reseller will be billed, such as once per month.",
          "$ref": "GoogleCloudChannelV1alpha1Period"
        },
        "billingAccount": {
          "description": "Reseller Billing account to charge after an offer transaction. Only present for Google Cloud offers.",
          "type": "string"
        },
        "paymentPlan": {
          "description": "Describes how a reseller will be billed.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Commitment.",
            "No commitment.",
            "Free.",
            "Trial.",
            "Price and ordering not available through API."
          ],
          "enum": [
            "PAYMENT_PLAN_UNSPECIFIED",
            "COMMITMENT",
            "FLEXIBLE",
            "FREE",
            "TRIAL",
            "OFFLINE"
          ]
        },
        "trialPeriod": {
          "$ref": "GoogleCloudChannelV1alpha1Period",
          "description": "Present for Offers with a trial period. For trial-only Offers, a paid service needs to start before the trial period ends for continued service. For Regular Offers with a trial period, the regular pricing goes into effect when trial period ends, or if paid service is started before the end of the trial period."
        },
        "paymentType": {
          "description": "Specifies when the payment needs to happen.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Prepay. Amount has to be paid before service is rendered.",
            "Postpay. Reseller is charged at the end of the Payment cycle."
          ],
          "enum": [
            "PAYMENT_TYPE_UNSPECIFIED",
            "PREPAY",
            "POSTPAY"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1SkuGroupCondition": {
      "description": "A condition that applies the override if a line item SKU is found in the SKU group.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1SkuGroupCondition",
      "properties": {
        "skuGroup": {
          "description": "Specifies a SKU group (https://cloud.google.com/skus/sku-groups). Resource name of SKU group. Format: accounts/{account}/skuGroups/{sku_group}. Example: \"accounts/C01234/skuGroups/3d50fd57-3157-4577-a5a9-a219b8490041\".",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RegisterSubscriberResponse": {
      "id": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse",
      "properties": {
        "topic": {
          "description": "Name of the topic the subscriber will listen to.",
          "type": "string"
        }
      },
      "description": "Response Message for RegisterSubscriber.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1AdminUser": {
      "id": "GoogleCloudChannelV1alpha1AdminUser",
      "properties": {
        "givenName": {
          "description": "Given name of the admin user.",
          "type": "string"
        },
        "familyName": {
          "description": "Family name of the admin user.",
          "type": "string"
        },
        "email": {
          "description": "Primary email of the admin user.",
          "type": "string"
        }
      },
      "description": "Information needed to create an Admin User for Google Workspace.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1UpdateChannelPartnerLinkRequest": {
      "id": "GoogleCloudChannelV1alpha1UpdateChannelPartnerLinkRequest",
      "properties": {
        "channelPartnerLink": {
          "description": "Required. The channel partner link to update. Only channel_partner_link.link_state is allowed for updates.",
          "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
        },
        "updateMask": {
          "format": "google-fieldmask",
          "description": "Required. The update mask that applies to the resource. The only allowable value for an update mask is channel_partner_link.link_state.",
          "type": "string"
        }
      },
      "description": "Request message for CloudChannelService.UpdateChannelPartnerLink",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1PurchasableSku": {
      "id": "GoogleCloudChannelV1alpha1PurchasableSku",
      "properties": {
        "sku": {
          "description": "SKU",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        }
      },
      "description": "SKU that you can purchase. This is used in ListPurchasableSku API response.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RenewalSettings": {
      "id": "GoogleCloudChannelV1alpha1RenewalSettings",
      "properties": {
        "disableCommitment": {
          "description": "If true, disables commitment-based offer on renewal and switches to flexible or pay as you go. Deprecated: Use `payment_plan` instead.",
          "deprecated": true,
          "type": "boolean"
        },
        "paymentOption": {
          "deprecated": true,
          "description": "Set if enable_renewal=true. Deprecated: Use `payment_cycle` instead.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Paid in yearly installments.",
            "Paid in monthly installments."
          ],
          "enum": [
            "PAYMENT_OPTION_UNSPECIFIED",
            "ANNUAL",
            "MONTHLY"
          ]
        },
        "scheduledRenewalOffer": {
          "readOnly": true,
          "description": "Output only. The offer resource name that the entitlement will renew on at the end date. Takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "enableRenewal": {
          "description": "If false, the plan will be completed at the end date.",
          "type": "boolean"
        },
        "resizeUnitCount": {
          "description": "If true and enable_renewal = true, the unit (for example seats or licenses) will be set to the number of active units at renewal time.",
          "type": "boolean"
        },
        "paymentCycle": {
          "description": "Describes how frequently the reseller will be billed, such as once per month.",
          "$ref": "GoogleCloudChannelV1alpha1Period"
        },
        "paymentPlan": {
          "description": "Describes how a reseller will be billed.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Commitment.",
            "No commitment.",
            "Free.",
            "Trial.",
            "Price and ordering not available through API."
          ],
          "enum": [
            "PAYMENT_PLAN_UNSPECIFIED",
            "COMMITMENT",
            "FLEXIBLE",
            "FREE",
            "TRIAL",
            "OFFLINE"
          ]
        }
      },
      "description": "Renewal settings for renewable Offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1SalesCycle": {
      "description": "Information on the sales cycle.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1SalesCycle",
      "properties": {
        "closeDate": {
          "readOnly": true,
          "description": "Output only. For open opportunities, this is the expected close date. For closed opportunities, this is the contract signed date. Available in Limited view.",
          "$ref": "GoogleTypeDate"
        },
        "closeDatePushCount": {
          "readOnly": true,
          "format": "int32",
          "description": "Output only. Number of times close date is pushed/changed.",
          "type": "integer"
        },
        "partnerReadyToClose": {
          "description": "Partner ready to close info. Can be edited after the Opportunity is Accepted.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Stage 4 - Migration or Implementation. Represents Closed/Won stage.",
            "Closed lost."
          ],
          "enum": [
            "PARTNER_CLOSE_STAGE_UNSPECIFIED",
            "MIGRATION_IMPL",
            "CLOSED_LOST"
          ]
        },
        "prmSiteDetails": {
          "readOnly": true,
          "description": "Output only. PRM site details.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse": {
      "description": "Response message for CloudChannelService.ListProvisionableCloudIdentityTypes",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse",
      "properties": {
        "cloudIdentityTypes": {
          "description": "List of cloud identity types and if you can provision them for the domain.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChangeSkuRequest": {
      "description": "Request message for CloudChannelService.ChangeSku.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ChangeSkuRequest",
      "properties": {
        "numUnits": {
          "description": "New num units for the entitlement. For seat-based offers, this is the number of seats. For license based offers, this is the number of licenses. Required for commitment based offers.",
          "type": "integer",
          "format": "int32"
        },
        "offer": {
          "description": "Required. New Offer applicable to a new SKU. The offer takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "requestId": {
          "description": "You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement when setting up billing on a trial subscription. This field is only relevant for multi-currency accounts. It should be left empty for single currency accounts.",
          "type": "string"
        },
        "purchaseOrderId": {
          "description": "Purchase order ID provided by the reseller. Optional",
          "type": "string"
        },
        "externalCorrelationId": {
          "description": "An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement. Optional.",
          "type": "string"
        },
        "maxUnits": {
          "format": "int32",
          "description": "New max units for the entitlement. It represents the maximum units a flexible offer is allowed to assign. Required for flexible offers.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RunReportJobResponse": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1RunReportJobResponse",
      "properties": {
        "reportMetadata": {
          "$ref": "GoogleCloudChannelV1alpha1ReportResultsMetadata",
          "description": "The metadata for the report's results (display name, columns, row count, and date range). If you view this before the operation finishes, you may see incomplete data."
        },
        "reportJob": {
          "$ref": "GoogleCloudChannelV1alpha1ReportJob",
          "description": "Pass `report_job.name` to FetchReportResultsRequest.report_job to retrieve the report's results."
        }
      },
      "description": "Response message for CloudChannelReportsService.RunReportJob.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListOffersResponse": {
      "description": "Response message for ListOffers.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListOffersResponse",
      "properties": {
        "offers": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Offer"
          },
          "description": "The list of Offers requested. The pricing information for each Offer only includes the base price. Effective prices and discounts aren't populated.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ParameterDefinition": {
      "id": "GoogleCloudChannelV1alpha1ParameterDefinition",
      "properties": {
        "minValue": {
          "$ref": "GoogleCloudChannelV1alpha1Value",
          "description": "Minimal value of the parameter, if applicable. Inclusive. For example, minimal commitment when purchasing Anthos is 0.01. Applicable to INT64 and DOUBLE parameter types."
        },
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "maxValue": {
          "$ref": "GoogleCloudChannelV1alpha1Value",
          "description": "Maximum value of the parameter, if applicable. Inclusive. For example, maximum seats when purchasing Google Workspace Business Standard. Applicable to INT64 and DOUBLE parameter types."
        },
        "allowedValues": {
          "description": "If not empty, parameter values must be drawn from this list. For example, [us-west1, us-west2, ...] Applicable to STRING parameter type.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Value"
          }
        },
        "parameterType": {
          "description": "Data type of the parameter. Minimal value, Maximum value and allowed values will use specified data type here.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Int64 type.",
            "String type.",
            "Double type.",
            "Boolean type."
          ],
          "enum": [
            "PARAMETER_TYPE_UNSPECIFIED",
            "INT64",
            "STRING",
            "DOUBLE",
            "BOOLEAN"
          ]
        },
        "optional": {
          "description": "If set to true, parameter is optional to purchase this Offer.",
          "type": "boolean"
        }
      },
      "description": "Parameter's definition. Specifies what parameter is required to use the current Offer to purchase.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ContactInfo": {
      "id": "GoogleCloudChannelV1alpha1ContactInfo",
      "properties": {
        "email": {
          "description": "The customer account's contact email. Required for entitlements that create admin.google.com accounts, and serves as the customer's username for those accounts. Use this email to invite Team customers.",
          "type": "string"
        },
        "phone": {
          "description": "The customer account's contact phone number.",
          "type": "string"
        },
        "title": {
          "description": "Optional. The customer account contact's job title.",
          "type": "string"
        },
        "firstName": {
          "description": "The customer account contact's first name. Optional for Team customers.",
          "type": "string"
        },
        "lastName": {
          "description": "The customer account contact's last name. Optional for Team customers.",
          "type": "string"
        },
        "displayName": {
          "readOnly": true,
          "description": "Output only. The customer account contact's display name, formatted as a combination of the customer's first and last name.",
          "type": "string"
        }
      },
      "description": "Contact information for a customer account.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListReportsResponse": {
      "description": "Response message for CloudChannelReportsService.ListReports.",
      "type": "object",
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1ListReportsResponse",
      "properties": {
        "reports": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Report"
          },
          "description": "The reports available to the partner.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "Pass this token to FetchReportResultsRequest.page_token to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerDetails": {
      "description": "Customer details used to create a new customer or map to existing customers.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1CustomerDetails",
      "properties": {
        "employeeCount": {
          "format": "int32",
          "description": "Required. Workforce size.",
          "type": "integer"
        },
        "domain": {
          "description": "Required. Customer's primary website domain. Available in Limited view.",
          "type": "string"
        },
        "address": {
          "$ref": "GoogleTypePostalAddress",
          "description": "Required. Customer address."
        },
        "organizationName": {
          "description": "Required. Name of the Customer Organization. Available in Limited view.",
          "type": "string"
        },
        "industry": {
          "description": "Required. Customer's Primary Industry.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Advertising & Marketing.",
            "Agriculture",
            "Automotive.",
            "Business & Professional Services.",
            "Consumer Packaged Goods.",
            "Education.",
            "Electrical & Electronics.",
            "Energy & Utilities.",
            "Financial Services.",
            "Food, Beverage & Restaurants.",
            "Gaming.",
            "Healthcare & Life Sciences.",
            "Industrial Goods & Manufacturing.",
            "Government.",
            "Logistics.",
            "Manufacturing & Industrial.",
            "Media & Entertainment.",
            "Non-Profit.",
            "Other.",
            "Public Sector & EDU.",
            "Retail & Consumer.",
            "Retail & Wholesale.",
            "Software & Internet.",
            "Telecommunications.",
            "Telecommunications, Media & Gaming.",
            "Tourism & Leisure."
          ],
          "enum": [
            "INDUSTRY_UNSPECIFIED",
            "ADVERTISING_MARKETING",
            "AGRICULTURE",
            "AUTOMOTIVE",
            "BUSINESS_SERVICES",
            "CONSUMER_GOODS",
            "EDUCATION",
            "ELECTRICAL_ELECTRONICS",
            "ENERGY",
            "FINANCIAL_SERVICES",
            "FOOD",
            "GAMING",
            "HEALTHCARE",
            "INDUSTRIAL_GOODS",
            "GOVERNMENT",
            "LOGISTICS",
            "MANUFACTURING",
            "MEDIA",
            "NON_PROFIT",
            "OTHER",
            "PUBLIC_SECTOR",
            "RETAIL_CONSUMER",
            "RETAIL_WHOLESALE",
            "SOFTWARE",
            "TELECOMMUNICATIONS",
            "TELECOMMUNICATIONS_MEDIA",
            "TOURISM"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerEvent": {
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerEvent",
      "properties": {
        "channelPartner": {
          "description": "Resource name for the Channel Partner Link. Channel_partner uses the format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}",
          "type": "string"
        },
        "eventType": {
          "description": "Type of event which happened for the channel partner.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "The Channel Partner link state changed.",
            "The Channel Partner's Partner Advantage information changed. This can entail the Channel Partner's authorization to sell a product in a particular region."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "LINK_STATE_CHANGED",
            "PARTNER_ADVANTAGE_INFO_CHANGED"
          ]
        }
      },
      "description": "Represents Pub/Sub messages about updates to a Channel Partner. You can retrieve updated values through the ChannelPartnerLinks API.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1FetchReportResultsRequest": {
      "description": "Request message for CloudChannelReportsService.FetchReportResults.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1FetchReportResultsRequest",
      "properties": {
        "pageSize": {
          "format": "int32",
          "description": "Optional. Requested page size of the report. The server may return fewer results than requested. If you don't specify a page size, the server uses a sensible default (may change over time). The maximum value is 30,000; the server will change larger values to 30,000.",
          "type": "integer"
        },
        "pageToken": {
          "description": "Optional. A token that specifies a page of results beyond the first page. Obtained through FetchReportResultsResponse.next_page_token of the previous CloudChannelReportsService.FetchReportResults call.",
          "type": "string"
        },
        "partitionKeys": {
          "description": "Optional. List of keys specifying which report partitions to return. If empty, returns all partitions.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1RepricingCondition": {
      "id": "GoogleCloudChannelV1alpha1RepricingCondition",
      "properties": {
        "skuGroupCondition": {
          "description": "SKU Group condition for override.",
          "$ref": "GoogleCloudChannelV1alpha1SkuGroupCondition"
        }
      },
      "description": "Represents the various repricing conditions you can use for a conditional override.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo": {
      "description": "Represents a billing account that can be used to make a purchase.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo",
      "properties": {
        "billingAccount": {
          "description": "The billing account resource.",
          "$ref": "GoogleCloudChannelV1alpha1BillingAccount"
        }
      }
    },
    "GoogleCloudChannelV1alpha1PurchasableOffer": {
      "description": "Offer that you can purchase for a customer. This is used in the ListPurchasableOffer API response.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1PurchasableOffer",
      "properties": {
        "priceReferenceId": {
          "description": "Optional. Price reference ID for the offer. Only for offers that require additional price information. Used to guarantee that the pricing is consistent between quoting the offer and placing the order.",
          "type": "string"
        },
        "offer": {
          "description": "Offer.",
          "$ref": "GoogleCloudChannelV1alpha1Offer"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityTeamMember": {
      "id": "GoogleCloudChannelV1alpha1OpportunityTeamMember",
      "properties": {
        "accessLevel": {
          "readOnly": true,
          "description": "Output only. Access Level. Available in Limited view.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "View only.",
            "Modify."
          ],
          "enum": [
            "ACCESS_LEVEL_UNSPECIFIED",
            "VIEW_ONLY",
            "MODIFY"
          ]
        },
        "name": {
          "description": "Output only. Name. Available in Limited view.",
          "type": "string",
          "readOnly": true
        },
        "email": {
          "readOnly": true,
          "description": "Output only. Email. Available in Limited view.",
          "type": "string"
        }
      },
      "description": "Opportunity Team Member.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListTransferableOffersRequest": {
      "description": "Request message for CloudChannelService.ListTransferableOffers",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListTransferableOffersRequest",
      "properties": {
        "sku": {
          "description": "Required. The SKU to look up Offers for.",
          "type": "string"
        },
        "languageCode": {
          "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
          "type": "string"
        },
        "billingAccount": {
          "description": "Optional. The Billing Account to look up Offers for. Format: accounts/{account_id}/billingAccounts/{billing_account_id}. This field is only relevant for multi-currency accounts. It should be left empty for single currency accounts.",
          "type": "string"
        },
        "cloudIdentityId": {
          "description": "Customer's Cloud Identity ID",
          "type": "string"
        },
        "pageToken": {
          "description": "A token for a page of results other than the first page. Obtained using ListTransferableOffersResponse.next_page_token of the previous CloudChannelService.ListTransferableOffers call.",
          "type": "string"
        },
        "customerName": {
          "description": "A reseller should create a customer and use the resource name of that customer here.",
          "type": "string"
        },
        "pageSize": {
          "description": "Requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 offers. The maximum value is 1000; the server will coerce values above 1000.",
          "type": "integer",
          "format": "int32"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListTransferableOffersResponse": {
      "description": "Response message for CloudChannelService.ListTransferableOffers.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListTransferableOffersResponse",
      "properties": {
        "transferableOffers": {
          "description": "Information about Offers for a customer that can be used for transfer.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1TransferableOffer"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListTransferableOffersRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerEvent": {
      "description": "Represents Pub/Sub message content describing customer update.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1CustomerEvent",
      "properties": {
        "customer": {
          "description": "Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "eventType": {
          "description": "Type of event which happened for the customer.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Primary domain for customer was changed.",
            "Primary domain of the customer has been verified."
          ],
          "enum": [
            "TYPE_UNSPECIFIED",
            "PRIMARY_DOMAIN_CHANGED",
            "PRIMARY_DOMAIN_VERIFIED"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse": {
      "id": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse",
      "properties": {
        "cloudIdentityAccounts": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount"
          },
          "description": "The Cloud Identity accounts associated with the domain.",
          "type": "array"
        }
      },
      "description": "Response message for CloudChannelService.CheckCloudIdentityAccountsExist.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo": {
      "id": "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo",
      "properties": {
        "deliveryModel": {
          "description": "Delivery Model. Can't be edited after the Opportunity is Accepted.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Data to customer BigQuery.",
            "VM on Customer Tenancy.",
            "SaaS on Google Cloud."
          ],
          "enum": [
            "DELIVERY_MODEL_UNSPECIFIED",
            "OTHER_DELIVERY_MODEL",
            "DATA_TO_CUSTOMER_BIGQUERY",
            "VM_ON_CUSTOMER_TENANCY",
            "SAAS_ON_GOOGLE_CLOUD"
          ]
        },
        "contractVehicle": {
          "description": "Contract Vehicle. Can't be edited after the Opportunity is Accepted.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Google Cloud Marketplace.",
            "Partner contract.",
            "Not known at this time."
          ],
          "enum": [
            "CONTRACT_VEHICLE_UNSPECIFIED",
            "CLOUD_MARKETPLACE",
            "PARTNER_CONTRACT",
            "UNKNOWN"
          ]
        },
        "supportLevel": {
          "description": "Support Level. Can't be edited after the Opportunity is Accepted.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Technical support.",
            "Transaction related support (POC/Google Cloud Marketplace/Procurement).",
            "Upselling/renewal/cross-selling support.",
            "Align sales/account strategy.",
            "Already in touch with Google Cloud sales."
          ],
          "enum": [
            "SUPPORT_LEVEL_UNSPECIFIED",
            "OTHER_SUPPORT_LEVEL",
            "TECH",
            "TRANSACTION",
            "UPSELL_RENEW_CROSS_SELL",
            "ALIGN_SALES_ACCOUNT",
            "ALREADY_CONTACT"
          ]
        },
        "notes": {
          "description": "Optional. Notes. Only available for ISV Opportunities. ISV and Googler use this field to keep each other up to date on selling activity to the customer. Maximum character length: 5000.",
          "type": "string"
        },
        "isvSolutionConnectDeal": {
          "description": "Is the deal an ISV solution connect deal? Can't be edited after the Opportunity is Accepted. Default: false.",
          "type": "boolean"
        },
        "customerContactRequested": {
          "description": "Has customer requested to be contacted? Can't be edited after the Opportunity is Accepted. Must be marked as true in order for an ISV oppty to be accepted. Default: false.",
          "type": "boolean"
        },
        "nextStep": {
          "description": "Optional. Next Step. Only available for ISV Opportunities. Summarizes between the ISV and Googler what the next action is on and who should take it. Maximum character length: 255.",
          "type": "string"
        }
      },
      "description": "Information about a ISV Solution Connect Deal.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSkuGroupsResponse": {
      "description": "Response message for ListSkuGroups.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListSkuGroupsResponse",
      "properties": {
        "skuGroups": {
          "description": "The list of SKU groups requested.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1SkuGroup"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListSkuGroupsRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1ProvisionedService": {
      "description": "Service provisioned for an entitlement.",
      "type": "object",
      "id": "GoogleCloudChannelV1ProvisionedService",
      "properties": {
        "provisioningId": {
          "description": "Output only. Provisioning ID of the entitlement. For Google Workspace, this is the underlying Subscription ID. For Google Cloud, this is the Billing Account ID of the billing subaccount.",
          "type": "string",
          "readOnly": true
        },
        "productId": {
          "description": "Output only. The product pertaining to the provisioning resource as specified in the Offer.",
          "type": "string",
          "readOnly": true
        },
        "skuId": {
          "description": "Output only. The SKU pertaining to the provisioning resource as specified in the Offer.",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "GoogleCloudChannelV1alpha1CancelEntitlementRequest": {
      "description": "Request message for CloudChannelService.CancelEntitlement.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1CancelEntitlementRequest",
      "properties": {
        "requestId": {
          "description": "Optional. You can specify an optional unique request ID, and if you need to retry your request, the server will know to ignore the request if it's complete. For example, you make an initial request and the request times out. If you make the request again with the same request ID, the server can check if it received the original operation with the same request ID. If it did, it will ignore the second request. The request ID must be a valid [UUID](https://tools.ietf.org/html/rfc4122) with the exception that zero UUID is not supported (`00000000-0000-0000-0000-000000000000`).",
          "type": "string"
        },
        "externalCorrelationId": {
          "description": "Optional. An optional identifier in the external system that partners can use to correlate a Channel Services purchase transaction for the entitlement.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListChannelPartnerLinksResponse": {
      "description": "Response message for CloudChannelService.ListChannelPartnerLinks.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ListChannelPartnerLinksResponse",
      "properties": {
        "channelPartnerLinks": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
          },
          "description": "The Channel partner links for a reseller.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListChannelPartnerLinksRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Product": {
      "description": "A Product is the entity a customer uses when placing an order. For example, Google Workspace, Google Voice, etc.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1Product",
      "properties": {
        "marketingInfo": {
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo",
          "description": "Marketing information for the product."
        },
        "name": {
          "description": "Resource Name of the Product. Format: products/{product_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ProductAuthorization": {
      "description": "The product and region pairs that a reseller may be authorized to sell.",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1ProductAuthorization",
      "properties": {
        "authorizedProductFamily": {
          "description": "The family of Google products that the reseller may be authorized to sell.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "Google Cloud",
            "Chrome. Deprecated: Use AuthorizedProductFamily.CHROME instead.",
            "Google Workspace",
            "Google Maps",
            "Chrome",
            "Google Workspace for Education"
          ],
          "enumDeprecated": [
            false,
            false,
            true,
            false,
            false,
            false,
            false
          ],
          "enum": [
            "AUTHORIZED_PRODUCT_FAMILY_UNSPECIFIED",
            "GOOGLE_CLOUD_PLATFORM",
            "CHROME_ENTERPRISE",
            "GOOGLE_WORKSPACE",
            "GOOGLE_MAPS_PLATFORM",
            "CHROME",
            "GOOGLE_WORKSPACE_FOR_EDUCATION"
          ]
        },
        "region": {
          "description": "The region where this reseller is authorized to sell this product family.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "Australia & New Zealand",
            "Central & Eastern Europe",
            "Germany, Austria, & Switzerland",
            "France",
            "Global",
            "India",
            "Japan",
            "LATAM - Brazil",
            "LATAM - Spanish speaking",
            "Northern Europe",
            "North America",
            "Other Asia Pacific",
            "Southern Europe and Emerging Markets",
            "UK & Ireland"
          ],
          "enum": [
            "REGION_UNSPECIFIED",
            "ANZ",
            "CEE",
            "DACH",
            "FRANCE",
            "GLOBAL",
            "INDIA",
            "JAPAN",
            "LATAM_BRAZIL",
            "LATAM_SPANISH_SPEAKING",
            "NE",
            "NORTH_AMERICA",
            "OTHER_ASIA_PACIFIC",
            "SEEMEA",
            "UK_AND_I"
          ]
        },
        "state": {
          "description": "The state of this product authorization.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "The default status for an authorization. Stays set while the partner works on the authorization tasks.",
            "Shows that the partner has completed their requisite tasks and can sell the product family in the corresponding region.",
            "Set when a partner submits the authorization for Google's review.",
            "Used to indicate the authorization is no longer active.",
            "Used when a partner no longer meets the authorization requirements. Stays set while the partner works on meeting the requirements.",
            "Indicates that the application was rejected.",
            "Used when the partner is no longer authorized to do business, regardless of reason."
          ],
          "enum": [
            "STATE_UNSPECIFIED",
            "INTERESTED",
            "ACTIVE",
            "SUBMITTED",
            "INACTIVE",
            "SUSPENDED",
            "REJECTED",
            "OFFBOARDING"
          ]
        },
        "sellType": {
          "description": "The type of reseller this ProductAuthorization corresponds to.",
          "type": "string",
          "enumDescriptions": [
            "Default value. Does not display if there are no errors.",
            "Reseller sells directly through Google.",
            "Reseller sells through a distributor."
          ],
          "enum": [
            "SELL_TYPE_UNSPECIFIED",
            "ONE_TIER",
            "TWO_TIER"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1EduData": {
      "description": "Required Edu Attributes",
      "type": "object",
      "id": "GoogleCloudChannelV1alpha1EduData",
      "properties": {
        "instituteType": {
          "description": "Designated institute type of customer.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Elementary/Secondary Schools & Districts",
            "Higher Education Universities & Colleges"
          ],
          "enum": [
            "INSTITUTE_TYPE_UNSPECIFIED",
            "K12",
            "UNIVERSITY"
          ]
        },
        "instituteSize": {
          "description": "Size of the institute.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "1 - 100",
            "101 - 500",
            "501 - 1,000",
            "1,001 - 2,000",
            "2,001 - 5,000",
            "5,001 - 10,000",
            "10,001 +"
          ],
          "enum": [
            "INSTITUTE_SIZE_UNSPECIFIED",
            "SIZE_1_100",
            "SIZE_101_500",
            "SIZE_501_1000",
            "SIZE_1001_2000",
            "SIZE_2001_5000",
            "SIZE_5001_10000",
            "SIZE_10001_OR_MORE"
          ]
        },
        "website": {
          "description": "Web address for the edu customer's institution.",
          "type": "string"
        }
      }
    }
  },
  "batchPath": "batch",
  "ownerName": "Google",
  "ownerDomain": "google.com",
  "kind": "discovery#restDescription",
  "mtlsRootUrl": "https://cloudchannel.mtls.googleapis.com/",
  "parameters": {
    "callback": {
      "type": "string",
      "description": "JSONP",
      "location": "query"
    },
    "quotaUser": {
      "type": "string",
      "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.",
      "location": "query"
    },
    "upload_protocol": {
      "location": "query",
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\")."
    },
    "access_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth access token."
    },
    "oauth_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth 2.0 token for the current user."
    },
    "fields": {
      "location": "query",
      "type": "string",
      "description": "Selector specifying which fields to include in a partial response."
    },
    "$.xgafv": {
      "type": "string",
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ],
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "location": "query"
    },
    "alt": {
      "type": "string",
      "description": "Data format for response.",
      "enum": [
        "json",
        "media",
        "proto"
      ],
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "default": "json",
      "location": "query"
    },
    "key": {
      "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.",
      "location": "query"
    },
    "prettyPrint": {
      "type": "boolean",
      "description": "Returns response with indentations and line breaks.",
      "default": "true",
      "location": "query"
    },
    "uploadType": {
      "location": "query",
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\")."
    }
  },
  "version_module": true,
  "icons": {
    "x16": "http://www.google.com/images/icons/product/search-16.gif",
    "x32": "http://www.google.com/images/icons/product/search-32.gif"
  },
  "id": "cloudchannel:v1alpha1",
  "resources": {
    "integrators": {
      "methods": {
        "registerSubscriber": {
          "parameterOrder": [
            "integrator"
          ],
          "path": "v1alpha1/{+integrator}:registerSubscriber",
          "parameters": {
            "integrator": {
              "required": true,
              "pattern": "^integrators/[^/]+$",
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path"
            }
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest"
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse"
          },
          "flatPath": "v1alpha1/integrators/{integratorsId}:registerSubscriber",
          "id": "cloudchannel.integrators.registerSubscriber",
          "httpMethod": "POST",
          "description": "Registers a service account with subscriber privileges on the Pub/Sub topic for this Channel Services account or integrator. After you create a subscriber, you get the events through SubscriberEvent Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The topic name with the registered service email address.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "unregisterSubscriber": {
          "description": "Unregisters a service account with subscriber privileges on the Pub/Sub topic created for this Channel Services account or integrator. If there are no service accounts left with subscriber privileges, this deletes the topic. You can call ListSubscribers to check for these accounts. Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The topic resource doesn't exist. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The topic name that unregistered the service email address. Returns a success response if the service email address wasn't registered with the topic.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "id": "cloudchannel.integrators.unregisterSubscriber",
          "httpMethod": "POST",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse"
          },
          "flatPath": "v1alpha1/integrators/{integratorsId}:unregisterSubscriber",
          "parameterOrder": [
            "integrator"
          ],
          "path": "v1alpha1/{+integrator}:unregisterSubscriber",
          "parameters": {
            "integrator": {
              "pattern": "^integrators/[^/]+$",
              "required": true,
              "location": "path",
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string"
            }
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest"
          }
        },
        "listSubscribers": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Lists service accounts with subscriber privileges on the Pub/Sub topic created for this Channel Services account or integrator. Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The topic resource doesn't exist. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: A list of service email addresses.",
          "httpMethod": "GET",
          "id": "cloudchannel.integrators.listSubscribers",
          "flatPath": "v1alpha1/integrators/{integratorsId}:listSubscribers",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListSubscribersResponse"
          },
          "path": "v1alpha1/{+integrator}:listSubscribers",
          "parameters": {
            "pageSize": {
              "description": "Optional. The maximum number of service accounts to return. The service may return fewer than this value. If unspecified, returns at most 100 service accounts. The maximum value is 1000; the server will coerce values above 1000.",
              "type": "integer",
              "location": "query",
              "format": "int32"
            },
            "integrator": {
              "pattern": "^integrators/[^/]+$",
              "required": true,
              "location": "path",
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string"
            },
            "pageToken": {
              "description": "Optional. A page token, received from a previous `ListSubscribers` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListSubscribers` must match the call that provided the page token.",
              "type": "string",
              "location": "query"
            },
            "account": {
              "location": "query",
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string"
            }
          },
          "parameterOrder": [
            "integrator"
          ]
        }
      }
    },
    "operations": {
      "methods": {
        "get": {
          "parameterOrder": [
            "name"
          ],
          "path": "v1alpha1/{+name}",
          "parameters": {
            "name": {
              "location": "path",
              "description": "The name of the operation resource.",
              "type": "string",
              "pattern": "^operations/[^/]+$",
              "required": true
            }
          },
          "response": {
            "$ref": "GoogleLongrunningOperation"
          },
          "flatPath": "v1alpha1/operations/{operationsId}",
          "id": "cloudchannel.operations.get",
          "httpMethod": "GET",
          "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "list": {
          "id": "cloudchannel.operations.list",
          "httpMethod": "GET",
          "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [
            "name"
          ],
          "path": "v1alpha1/{+name}",
          "parameters": {
            "returnPartialSuccess": {
              "location": "query",
              "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.",
              "type": "boolean"
            },
            "pageToken": {
              "location": "query",
              "description": "The standard list page token.",
              "type": "string"
            },
            "pageSize": {
              "description": "The standard list page size.",
              "type": "integer",
              "location": "query",
              "format": "int32"
            },
            "filter": {
              "location": "query",
              "description": "The standard list filter.",
              "type": "string"
            },
            "name": {
              "location": "path",
              "description": "The name of the operation's parent resource.",
              "type": "string",
              "pattern": "^operations$",
              "required": true
            }
          },
          "response": {
            "$ref": "GoogleLongrunningListOperationsResponse"
          },
          "flatPath": "v1alpha1/operations"
        },
        "cancel": {
          "response": {
            "$ref": "GoogleProtobufEmpty"
          },
          "flatPath": "v1alpha1/operations/{operationsId}:cancel",
          "parameterOrder": [
            "name"
          ],
          "path": "v1alpha1/{+name}:cancel",
          "parameters": {
            "name": {
              "description": "The name of the operation resource to be cancelled.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^operations/.*$"
            }
          },
          "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "id": "cloudchannel.operations.cancel",
          "httpMethod": "POST"
        },
        "delete": {
          "parameterOrder": [
            "name"
          ],
          "path": "v1alpha1/{+name}",
          "parameters": {
            "name": {
              "location": "path",
              "description": "The name of the operation resource to be deleted.",
              "type": "string",
              "pattern": "^operations/.*$",
              "required": true
            }
          },
          "response": {
            "$ref": "GoogleProtobufEmpty"
          },
          "flatPath": "v1alpha1/operations/{operationsId}",
          "id": "cloudchannel.operations.delete",
          "httpMethod": "DELETE",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`."
        }
      }
    },
    "accounts": {
      "methods": {
        "listProvisionableCloudIdentityTypes": {
          "flatPath": "v1alpha1/accounts/{accountsId}:listProvisionableCloudIdentityTypes",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse"
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest"
          },
          "path": "v1alpha1/{+parent}:listProvisionableCloudIdentityTypes",
          "parameters": {
            "parent": {
              "description": "Required. The resource name of the reseller's account. Parent uses the format: accounts/{account_id}",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^accounts/[^/]+$"
            }
          },
          "parameterOrder": [
            "parent"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Returns the Google Workspace customer types you can create for the given domain, and shows if this requires a transfer. Possible error codes: * PERMISSION_DENIED: The reseller account making the request cannot edit this customer. * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
          "httpMethod": "POST",
          "id": "cloudchannel.accounts.listProvisionableCloudIdentityTypes"
        },
        "register": {
          "flatPath": "v1alpha1/accounts/{accountsId}:register",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse"
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest"
          },
          "path": "v1alpha1/{+account}:register",
          "parameters": {
            "account": {
              "location": "path",
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "pattern": "^accounts/[^/]+$",
              "required": true
            }
          },
          "parameterOrder": [
            "account"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Registers a service account with subscriber privileges on the Pub/Sub topic for this Channel Services account or integrator. After you create a subscriber, you get the events through SubscriberEvent Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The topic name with the registered service email address.",
          "httpMethod": "POST",
          "id": "cloudchannel.accounts.register"
        },
        "listTransferableOffers": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "List TransferableOffers of a customer based on Cloud Identity ID or Customer Name in the request. Use this method when a reseller gets the entitlement information of an unowned customer. The reseller should provide the customer's Cloud Identity ID or Customer Name. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller and has no auth token. * The customer provided incorrect reseller information when generating auth token. * The reseller account making the request is different from the reseller account in the query. * The reseller is not authorized to transact on this Product. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: List of TransferableOffer for the given customer and SKU.",
          "httpMethod": "POST",
          "id": "cloudchannel.accounts.listTransferableOffers",
          "flatPath": "v1alpha1/accounts/{accountsId}:listTransferableOffers",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableOffersResponse"
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableOffersRequest"
          },
          "path": "v1alpha1/{+parent}:listTransferableOffers",
          "parameters": {
            "parent": {
              "description": "Required. The resource name of the reseller's account.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^accounts/[^/]+$"
            }
          },
          "parameterOrder": [
            "parent"
          ]
        },
        "listSubscribers": {
          "httpMethod": "GET",
          "id": "cloudchannel.accounts.listSubscribers",
          "description": "Lists service accounts with subscriber privileges on the Pub/Sub topic created for this Channel Services account or integrator. Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The topic resource doesn't exist. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: A list of service email addresses.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "path": "v1alpha1/{+account}:listSubscribers",
          "parameters": {
            "pageSize": {
              "description": "Optional. The maximum number of service accounts to return. The service may return fewer than this value. If unspecified, returns at most 100 service accounts. The maximum value is 1000; the server will coerce values above 1000.",
              "type": "integer",
              "location": "query",
              "format": "int32"
            },
            "pageToken": {
              "location": "query",
              "description": "Optional. A page token, received from a previous `ListSubscribers` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListSubscribers` must match the call that provided the page token.",
              "type": "string"
            },
            "integrator": {
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "query"
            },
            "account": {
              "pattern": "^accounts/[^/]+$",
              "required": true,
              "location": "path",
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string"
            }
          },
          "parameterOrder": [
            "account"
          ],
          "flatPath": "v1alpha1/accounts/{accountsId}:listSubscribers",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListSubscribersResponse"
          }
        },
        "unregister": {
          "parameterOrder": [
            "account"
          ],
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest"
          },
          "path": "v1alpha1/{+account}:unregister",
          "parameters": {
            "account": {
              "required": true,
              "pattern": "^accounts/[^/]+$",
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:unregister",
          "id": "cloudchannel.accounts.unregister",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Unregisters a service account with subscriber privileges on the Pub/Sub topic created for this Channel Services account or integrator. If there are no service accounts left with subscriber privileges, this deletes the topic. You can call ListSubscribers to check for these accounts. Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different, or the impersonated user is not a super admin. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The topic resource doesn't exist. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The topic name that unregistered the service email address. Returns a success response if the service email address wasn't registered with the topic."
        },
        "listTransferableSkus": {
          "flatPath": "v1alpha1/accounts/{accountsId}:listTransferableSkus",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableSkusResponse"
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableSkusRequest"
          },
          "path": "v1alpha1/{+parent}:listTransferableSkus",
          "parameters": {
            "parent": {
              "required": true,
              "pattern": "^accounts/[^/]+$",
              "description": "Required. The reseller account's resource name. Parent uses the format: accounts/{account_id}",
              "type": "string",
              "location": "path"
            }
          },
          "parameterOrder": [
            "parent"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "List TransferableSkus of a customer based on the Cloud Identity ID or Customer Name in the request. Use this method to list the entitlements information of an unowned customer. You should provide the customer's Cloud Identity ID or Customer Name. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller and has no auth token. * The supplied auth token is invalid. * The reseller account making the request is different from the reseller account in the query. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: A list of the customer's TransferableSku.",
          "httpMethod": "POST",
          "id": "cloudchannel.accounts.listTransferableSkus"
        },
        "checkCloudIdentityAccountsExist": {
          "id": "cloudchannel.accounts.checkCloudIdentityAccountsExist",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Confirms the existence of Cloud Identity accounts based on the domain and if the Cloud Identity accounts are owned by the reseller. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * INVALID_VALUE: Invalid domain value in the request. Return value: A list of CloudIdentityCustomerAccount resources for the domain (may be empty) Note: in the v1alpha1 version of the API, a NOT_FOUND error returns if no CloudIdentityCustomerAccount resources match the domain.",
          "parameterOrder": [
            "parent"
          ],
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistRequest"
          },
          "path": "v1alpha1/{+parent}:checkCloudIdentityAccountsExist",
          "parameters": {
            "parent": {
              "pattern": "^accounts/[^/]+$",
              "required": true,
              "location": "path",
              "description": "Required. The reseller account's resource name. Parent uses the format: accounts/{account_id}",
              "type": "string"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:checkCloudIdentityAccountsExist"
        }
      },
      "resources": {
        "reports": {
          "methods": {
            "run": {
              "parameterOrder": [
                "name"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1RunReportJobRequest"
              },
              "path": "v1alpha1/{+name}:run",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/reports/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The report's resource name. Specifies the account and report used to generate report data. The report_id identifier is a UID (for example, `613bf59q`). Name uses the format: accounts/{account_id}/reports/{report_id}",
                  "type": "string"
                }
              },
              "deprecated": true,
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/reports/{reportsId}:run",
              "id": "cloudchannel.accounts.reports.run",
              "httpMethod": "POST",
              "scopes": [
                "https://www.googleapis.com/auth/apps.reports.usage.readonly"
              ],
              "description": "Begins generation of data for a given report. The report identifier is a UID (for example, `613bf59q`). Possible error codes: * PERMISSION_DENIED: The user doesn't have access to this report. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The report identifier was not found. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata contains an instance of OperationMetadata. To get the results of report generation, call CloudChannelReportsService.FetchReportResults with the RunReportJobResponse.report_job. Deprecated: Please use [Export Channel Services data to BigQuery](https://cloud.google.com/channel/docs/rebilling/export-data-to-bigquery) instead."
            },
            "list": {
              "description": "Lists the reports that RunReportJob can run. These reports include an ID, a description, and the list of columns that will be in the result. Deprecated: Please use [Export Channel Services data to BigQuery](https://cloud.google.com/channel/docs/rebilling/export-data-to-bigquery) instead.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.reports.usage.readonly"
              ],
              "id": "cloudchannel.accounts.reports.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListReportsResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/reports",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1alpha1/{+parent}/reports",
              "parameters": {
                "pageSize": {
                  "location": "query",
                  "format": "int32",
                  "description": "Optional. Requested page size of the report. The server might return fewer results than requested. If unspecified, returns 20 reports. The maximum value is 100.",
                  "type": "integer"
                },
                "parent": {
                  "location": "path",
                  "description": "Required. The resource name of the partner account to list available reports for. Parent uses the format: accounts/{account_id}",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "required": true
                },
                "languageCode": {
                  "location": "query",
                  "description": "Optional. The BCP-47 language code, such as \"en-US\". If specified, the response is localized to the corresponding language code if the original data sources support it. Default is \"en-US\".",
                  "type": "string"
                },
                "pageToken": {
                  "description": "Optional. A token that specifies a page of results beyond the first page. Obtained through ListReportsResponse.next_page_token of the previous CloudChannelReportsService.ListReports call.",
                  "type": "string",
                  "location": "query"
                }
              },
              "deprecated": true
            }
          },
          "deprecated": true
        },
        "reportJobs": {
          "methods": {
            "fetchReportResults": {
              "description": "Retrieves data generated by CloudChannelReportsService.RunReportJob. Deprecated: Please use [Export Channel Services data to BigQuery](https://cloud.google.com/channel/docs/rebilling/export-data-to-bigquery) instead.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.reports.usage.readonly"
              ],
              "id": "cloudchannel.accounts.reportJobs.fetchReportResults",
              "httpMethod": "POST",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1FetchReportResultsResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/reportJobs/{reportJobsId}:fetchReportResults",
              "parameterOrder": [
                "reportJob"
              ],
              "path": "v1alpha1/{+reportJob}:fetchReportResults",
              "parameters": {
                "reportJob": {
                  "required": true,
                  "pattern": "^accounts/[^/]+/reportJobs/[^/]+$",
                  "description": "Required. The report job created by CloudChannelReportsService.RunReportJob. Report_job uses the format: accounts/{account_id}/reportJobs/{report_job_id}",
                  "type": "string",
                  "location": "path"
                }
              },
              "deprecated": true,
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1FetchReportResultsRequest"
              }
            }
          },
          "deprecated": true
        },
        "customers": {
          "methods": {
            "transferEntitlements": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Transfers customer entitlements to new reseller. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller. * The reseller is not authorized to transact on this Product. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer or offer resource was not found. * ALREADY_EXISTS: The SKU was already transferred for the customer. * CONDITION_NOT_MET or FAILED_PRECONDITION: * The SKU requires domain verification to transfer, but the domain is not verified. * An Add-On SKU (example, Vault or Drive) is missing the pre-requisite SKU (example, G Suite Basic). * (Developer accounts only) Reseller and resold domain must meet the following naming requirements: * Domain names must start with goog-test. * Domain names must include the reseller domain. * Specify all transferring entitlements. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
              "id": "cloudchannel.accounts.customers.transferEntitlements",
              "httpMethod": "POST",
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:transferEntitlements",
              "parameterOrder": [
                "parent"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1TransferEntitlementsRequest"
              },
              "path": "v1alpha1/{+parent}:transferEntitlements",
              "parameters": {
                "parent": {
                  "required": true,
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Required. The resource name of the reseller's customer account that will receive transferred entitlements. Parent uses the format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string",
                  "location": "path"
                }
              }
            },
            "queryEligibleBillingAccounts": {
              "path": "v1alpha1/{+customer}:queryEligibleBillingAccounts",
              "parameters": {
                "skus": {
                  "location": "query",
                  "description": "Required. List of SKUs to list eligible billing accounts for. At least one SKU is required. Format: products/{product_id}/skus/{sku_id}.",
                  "type": "string",
                  "repeated": true
                },
                "customer": {
                  "description": "Required. The resource name of the customer to list eligible billing accounts for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+/customers/[^/]+$"
                }
              },
              "parameterOrder": [
                "customer"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:queryEligibleBillingAccounts",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse"
              },
              "httpMethod": "GET",
              "id": "cloudchannel.accounts.customers.queryEligibleBillingAccounts",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Lists the billing accounts that are eligible to purchase particular SKUs for a given customer. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: Based on the provided list of SKUs, returns a list of SKU groups that must be purchased using the same billing account and the billing accounts eligible to purchase each SKU group."
            },
            "transferEntitlementsToGoogle": {
              "parameterOrder": [
                "parent"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest"
              },
              "path": "v1alpha1/{+parent}:transferEntitlementsToGoogle",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of the reseller's customer account where the entitlements transfer from. Parent uses the format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string"
                }
              },
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:transferEntitlementsToGoogle",
              "id": "cloudchannel.accounts.customers.transferEntitlementsToGoogle",
              "httpMethod": "POST",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Transfers customer entitlements from their current reseller to Google. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer or offer resource was not found. * ALREADY_EXISTS: The SKU was already transferred for the customer. * CONDITION_NOT_MET or FAILED_PRECONDITION: * The SKU requires domain verification to transfer, but the domain is not verified. * An Add-On SKU (example, Vault or Drive) is missing the pre-requisite SKU (example, G Suite Basic). * (Developer accounts only) Reseller and resold domain must meet the following naming requirements: * Domain names must start with goog-test. * Domain names must include the reseller domain. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The response will contain google.protobuf.Empty on success. The Operation metadata will contain an instance of OperationMetadata."
            },
            "create": {
              "parameterOrder": [
                "parent"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "path": "v1alpha1/{+parent}/customers",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of reseller account in which to create the customer. Parent uses the format: accounts/{account_id}",
                  "type": "string"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers",
              "id": "cloudchannel.accounts.customers.create",
              "httpMethod": "POST",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Creates a new Customer resource under the reseller or distributor account. Possible error codes: * PERMISSION_DENIED: * The reseller account making the request is different from the reseller account in the API request. * You are not authorized to create a customer. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: * Required request parameters are missing or invalid. * Domain field value doesn't match the primary email domain. Return value: The newly created Customer resource."
            },
            "provisionCloudIdentity": {
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.customers.provisionCloudIdentity",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Creates a Cloud Identity for the given customer using the customer's information, or the information provided here. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller. * You are not authorized to provision cloud identity id. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer was not found. * ALREADY_EXISTS: The customer's primary email already exists. Retry after changing the customer's primary contact email. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata contains an instance of OperationMetadata.",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ProvisionCloudIdentityRequest"
              },
              "path": "v1alpha1/{+customer}:provisionCloudIdentity",
              "parameters": {
                "customer": {
                  "location": "path",
                  "description": "Required. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "required": true
                }
              },
              "parameterOrder": [
                "customer"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:provisionCloudIdentity",
              "response": {
                "$ref": "GoogleLongrunningOperation"
              }
            },
            "listPurchasableOffers": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Lists the following: * Offers that you can purchase for a customer. * Offers that you can change for an entitlement. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller * The reseller is not authorized to transact on this Product. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
              "httpMethod": "GET",
              "id": "cloudchannel.accounts.customers.listPurchasableOffers",
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:listPurchasableOffers",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse"
              },
              "path": "v1alpha1/{+customer}:listPurchasableOffers",
              "parameters": {
                "pageSize": {
                  "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 Offers. The maximum value is 1000; the server will coerce values above 1000.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "createEntitlementPurchase.sku": {
                  "description": "Required. SKU that the result should be restricted to. Format: products/{product_id}/skus/{sku_id}.",
                  "type": "string",
                  "location": "query"
                },
                "changeOfferPurchase.newSku": {
                  "description": "Optional. Resource name of the new target SKU. Provide this SKU when upgrading or downgrading an entitlement. Format: products/{product_id}/skus/{sku_id}",
                  "type": "string",
                  "location": "query"
                },
                "customer": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of the customer to list Offers for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string"
                },
                "languageCode": {
                  "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
                  "type": "string",
                  "location": "query"
                },
                "changeOfferPurchase.entitlement": {
                  "location": "query",
                  "description": "Required. Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                  "type": "string"
                },
                "createEntitlementPurchase.billingAccount": {
                  "location": "query",
                  "description": "Optional. Billing account that the result should be restricted to. Format: accounts/{account_id}/billingAccounts/{billing_account_id}.",
                  "type": "string"
                },
                "changeOfferPurchase.billingAccount": {
                  "location": "query",
                  "description": "Optional. Resource name of the new target Billing Account. Provide this Billing Account when setting up billing for a trial subscription. Format: accounts/{account_id}/billingAccounts/{billing_account_id}. This field is only relevant for multi-currency accounts. It should be left empty for single currency accounts.",
                  "type": "string"
                },
                "pageToken": {
                  "location": "query",
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string"
                },
                "createEntitlementPurchase.dealCode": {
                  "location": "query",
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "type": "string"
                },
                "changeOfferPurchase.dealCode": {
                  "location": "query",
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "type": "string"
                }
              },
              "parameterOrder": [
                "customer"
              ]
            },
            "list": {
              "httpMethod": "GET",
              "id": "cloudchannel.accounts.customers.list",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "List Customers. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: List of Customers, or an empty list if there are no customers.",
              "path": "v1alpha1/{+parent}/customers",
              "parameters": {
                "parent": {
                  "description": "Required. The resource name of the reseller account to list customers from. Parent uses the format: accounts/{account_id}.",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+$"
                },
                "pageSize": {
                  "description": "Optional. The maximum number of customers to return. The service may return fewer than this value. If unspecified, returns at most 10 customers. The maximum value is 50.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "filter": {
                  "description": "Optional. Filters applied to the [CloudChannelService.ListCustomers] results. See https://cloud.google.com/channel/docs/concepts/google-cloud/filter-customers for more information.",
                  "type": "string",
                  "location": "query"
                },
                "pageToken": {
                  "description": "Optional. A token identifying a page of results other than the first page. Obtained through ListCustomersResponse.next_page_token of the previous CloudChannelService.ListCustomers call.",
                  "type": "string",
                  "location": "query"
                }
              },
              "parameterOrder": [
                "parent"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/customers",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListCustomersResponse"
              }
            },
            "delete": {
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}",
              "response": {
                "$ref": "GoogleProtobufEmpty"
              },
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "required": true,
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Required. The resource name of the customer to delete.",
                  "type": "string",
                  "location": "path"
                }
              },
              "parameterOrder": [
                "name"
              ],
              "description": "Deletes the given Customer permanently. Possible error codes: * PERMISSION_DENIED: The account making the request does not own this customer. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * FAILED_PRECONDITION: The customer has existing entitlements. * NOT_FOUND: No Customer resource found for the name in the request.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "DELETE",
              "id": "cloudchannel.accounts.customers.delete"
            },
            "patch": {
              "id": "cloudchannel.accounts.customers.patch",
              "httpMethod": "PATCH",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Updates an existing Customer resource for the reseller or distributor. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: No Customer resource found for the name in the request. Return value: The updated Customer resource.",
              "parameterOrder": [
                "name"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "path": "v1alpha1/{+name}",
              "parameters": {
                "updateMask": {
                  "location": "query",
                  "format": "google-fieldmask",
                  "description": "The update mask that applies to the resource. Optional.",
                  "type": "string"
                },
                "name": {
                  "required": true,
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string",
                  "location": "path"
                },
                "name1": {
                  "description": "Deprecated: Set Customer.name instead Name uses the format: accounts/{account_id}/customers/{customer_id}",
                  "deprecated": true,
                  "type": "string",
                  "location": "query"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}"
            },
            "import": {
              "flatPath": "v1alpha1/accounts/{accountsId}/customers:import",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "path": "v1alpha1/{+parent}/customers:import",
              "parameters": {
                "parent": {
                  "location": "path",
                  "description": "Required. The resource name of the reseller's account. Parent takes the format: accounts/{account_id} or accounts/{account_id}/channelPartnerLinks/{channel_partner_id}",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$",
                  "required": true
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ImportCustomerRequest"
              },
              "parameterOrder": [
                "parent"
              ],
              "description": "Imports a Customer from the Cloud Identity associated with the provided Cloud Identity ID or domain before a TransferEntitlements call. If a linked Customer already exists and overwrite_if_exists is true, it will update that Customer's data. Possible error codes: * PERMISSION_DENIED: * The reseller account making the request is different from the reseller account in the API request. * You are not authorized to import the customer. See https://support.google.com/channelservices/answer/9759265 * NOT_FOUND: Cloud Identity doesn't exist or was deleted. * INVALID_ARGUMENT: Required parameters are missing, or the auth_token is expired or invalid. * ALREADY_EXISTS: A customer already exists and has conflicting critical fields. Requires an overwrite. Return value: The Customer.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.customers.import"
            },
            "listPurchasableSkus": {
              "parameterOrder": [
                "customer"
              ],
              "path": "v1alpha1/{+customer}:listPurchasableSkus",
              "parameters": {
                "pageToken": {
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string",
                  "location": "query"
                },
                "changeOfferPurchase.entitlement": {
                  "location": "query",
                  "description": "Required. Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                  "type": "string"
                },
                "pageSize": {
                  "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 SKUs. The maximum value is 1000; the server will coerce values above 1000.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "changeOfferPurchase.changeType": {
                  "location": "query",
                  "description": "Required. Change Type for the entitlement.",
                  "type": "string",
                  "enumDescriptions": [
                    "Not used.",
                    "SKU is an upgrade on the current entitlement.",
                    "SKU is a downgrade on the current entitlement."
                  ],
                  "enum": [
                    "CHANGE_TYPE_UNSPECIFIED",
                    "UPGRADE",
                    "DOWNGRADE"
                  ]
                },
                "customer": {
                  "location": "path",
                  "description": "Required. The resource name of the customer to list SKUs for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "required": true
                },
                "createEntitlementPurchase.product": {
                  "location": "query",
                  "description": "Required. List SKUs belonging to this Product. Format: products/{product_id}. Supports products/- to retrieve SKUs for all products.",
                  "type": "string"
                },
                "languageCode": {
                  "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
                  "type": "string",
                  "location": "query"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:listPurchasableSkus",
              "id": "cloudchannel.accounts.customers.listPurchasableSkus",
              "httpMethod": "GET",
              "description": "Lists the following: * SKUs that you can purchase for a customer * SKUs that you can upgrade or downgrade for an entitlement. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            },
            "get": {
              "parameterOrder": [
                "name"
              ],
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of the customer to retrieve. Name uses the format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}",
              "id": "cloudchannel.accounts.customers.get",
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Returns the requested Customer resource. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer resource doesn't exist. Usually the result of an invalid name parameter. Return value: The Customer resource."
            }
          },
          "resources": {
            "customerRepricingConfigs": {
              "methods": {
                "create": {
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs",
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "path": "v1alpha1/{+parent}/customerRepricingConfigs",
                  "parameters": {
                    "parent": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the customer that will receive this repricing config. Parent uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string"
                    }
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Creates a CustomerRepricingConfig. Call this method to set modifications for a specific customer's bill. You can only create configs if the RepricingConfig.effective_invoice_month is a future month. If needed, you can create a config for the current month, with some restrictions. When creating a config for a future month, make sure there are no existing configs for that RepricingConfig.effective_invoice_month. The following restrictions are for creating configs in the current month. * This functionality is reserved for recovering from an erroneous config, and should not be used for regular business cases. * The new config will not modify exports used with other configs. Changes to the config may be immediate, but may take up to 24 hours. * There is a limit of ten configs for any RepricingConfig.EntitlementGranularity.entitlement, for any RepricingConfig.effective_invoice_month. * The contained CustomerRepricingConfig.repricing_config value must be different from the value used in the current config for a RepricingConfig.EntitlementGranularity.entitlement. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * INVALID_ARGUMENT: Missing or invalid required parameters in the request. Also displays if the updated config is for the current month or past months. * NOT_FOUND: The CustomerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the updated CustomerRepricingConfig resource, otherwise returns an error.",
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.create",
                  "httpMethod": "POST"
                },
                "get": {
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.get",
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Gets information about how a Reseller modifies their bill before sending it to a Customer. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * NOT_FOUND: The CustomerRepricingConfig was not found. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the CustomerRepricingConfig resource, otherwise returns an error.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The resource name of the CustomerRepricingConfig. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/customerRepricingConfigs/[^/]+$",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}"
                },
                "patch": {
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/customerRepricingConfigs/[^/]+$",
                      "description": "Output only. Resource name of the CustomerRepricingConfig. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}",
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.patch",
                  "httpMethod": "PATCH",
                  "description": "Updates a CustomerRepricingConfig. Call this method to set modifications for a specific customer's bill. This method overwrites the existing CustomerRepricingConfig. You can only update configs if the RepricingConfig.effective_invoice_month is a future month. To make changes to configs for the current month, use CreateCustomerRepricingConfig, taking note of its restrictions. You cannot update the RepricingConfig.effective_invoice_month. When updating a config in the future: * This config must already exist. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * INVALID_ARGUMENT: Missing or invalid required parameters in the request. Also displays if the updated config is for the current month or past months. * NOT_FOUND: The CustomerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the updated CustomerRepricingConfig resource, otherwise returns an error.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "delete": {
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.delete",
                  "httpMethod": "DELETE",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Deletes the given CustomerRepricingConfig permanently. You can only delete configs if their RepricingConfig.effective_invoice_month is set to a date after the current month. Possible error codes: * PERMISSION_DENIED: The account making the request does not own this customer. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * FAILED_PRECONDITION: The CustomerRepricingConfig is active or in the past. * NOT_FOUND: No CustomerRepricingConfig found for the name in the request.",
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The resource name of the customer repricing config rule to delete. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/customerRepricingConfigs/[^/]+$",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}"
                },
                "list": {
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1alpha1/{+parent}/customerRepricingConfigs",
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results beyond the first page. Obtained through ListCustomerRepricingConfigsResponse.next_page_token of the previous CloudChannelService.ListCustomerRepricingConfigs call.",
                      "type": "string",
                      "location": "query"
                    },
                    "filter": {
                      "description": "Optional. A filter for [CloudChannelService.ListCustomerRepricingConfigs] results (customer only). You can use this filter when you support a BatchGet-like query. To use the filter, you must set `parent=accounts/{account_id}/customers/-`. Example: customer = accounts/account_id/customers/c1 OR customer = accounts/account_id/customers/c2.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "description": "Optional. The maximum number of repricing configs to return. The service may return fewer than this value. If unspecified, returns a maximum of 50 rules. The maximum value is 100; values above 100 will be coerced to 100.",
                      "type": "integer",
                      "location": "query",
                      "format": "int32"
                    },
                    "parent": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+$",
                      "description": "Required. The resource name of the customer. Parent uses the format: accounts/{account_id}/customers/{customer_id}. Supports accounts/{account_id}/customers/- to retrieve configs for all customers.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "description": "Lists information about how a Reseller modifies their bill before sending it to a Customer. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * NOT_FOUND: The CustomerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the CustomerRepricingConfig resources. The data for each resource is displayed in the ascending order of: * Customer ID * RepricingConfig.EntitlementGranularity.entitlement * RepricingConfig.effective_invoice_month * CustomerRepricingConfig.update_time If unsuccessful, returns an error.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.list",
                  "httpMethod": "GET"
                }
              }
            },
            "entitlements": {
              "methods": {
                "get": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Entitlement"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the entitlement to retrieve. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string"
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Returns the requested Entitlement resource. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer entitlement was not found. Return value: The requested Entitlement resource.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.customers.entitlements.get"
                },
                "suspend": {
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.suspend",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Suspends a previously fulfilled entitlement. An entitlement suspension is a long-running operation. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * NOT_ACTIVE: Entitlement is not active. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1SuspendEntitlementRequest"
                  },
                  "path": "v1alpha1/{+name}:suspend",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The resource name of the entitlement to suspend. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:suspend",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  }
                },
                "list": {
                  "id": "cloudchannel.accounts.customers.entitlements.list",
                  "httpMethod": "GET",
                  "description": "Lists Entitlements belonging to a customer. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: A list of the customer's Entitlements.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1alpha1/{+parent}/entitlements",
                  "parameters": {
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token for a page of results other than the first page. Obtained using ListEntitlementsResponse.next_page_token of the previous CloudChannelService.ListEntitlements call.",
                      "type": "string"
                    },
                    "pageSize": {
                      "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, return at most 50 entitlements. The maximum value is 100; the server will coerce values above 100.",
                      "type": "integer",
                      "location": "query",
                      "format": "int32"
                    },
                    "parent": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the reseller's customer account to list entitlements for. Parent uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListEntitlementsResponse"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements"
                },
                "create": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CreateEntitlementRequest"
                  },
                  "path": "v1alpha1/{+parent}/entitlements",
                  "parameters": {
                    "parent": {
                      "description": "Required. The resource name of the reseller's customer account in which to create the entitlement. Parent uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements",
                  "id": "cloudchannel.accounts.customers.entitlements.create",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Creates an entitlement for a customer. Possible error codes: * PERMISSION_DENIED: * The customer doesn't belong to the reseller. * The reseller is not authorized to transact on this Product. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: * Required request parameters are missing or invalid. * There is already a customer entitlement for a SKU from the same product family. * INVALID_VALUE: Make sure the OfferId is valid. If it is, contact Google Channel support for further troubleshooting. * NOT_FOUND: The customer or offer resource was not found. * ALREADY_EXISTS: * The SKU was already purchased for the customer. * The customer's primary email already exists. Retry after changing the customer's primary contact email. * CONDITION_NOT_MET or FAILED_PRECONDITION: * The domain required for purchasing a SKU has not been verified. * A pre-requisite SKU required to purchase an Add-On SKU is missing. For example, Google Workspace Business Starter is required to purchase Vault or Drive. * (Developer accounts only) Reseller and resold domain must meet the following naming requirements: * Domain names must start with goog-test. * Domain names must include the reseller domain. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata."
                },
                "changeSku": {
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}:changeSku",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "deprecated": true,
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeSkuRequest"
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeSku",
                  "id": "cloudchannel.accounts.customers.entitlements.changeSku",
                  "httpMethod": "POST",
                  "description": "Updates the SKU for an existing customer entitlement. This method creates a new entitlement for the modified SKU and cancels the original SKU's entitlement. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: * Required request parameters are missing or invalid. * The new offer's SKU doesn't belong to the same product family as the existing entitlement's SKU * Can't upgrade or downgrade an annual commitment. * NOT_FOUND: Offer or Entitlement resource not found. * ALREADY_EXISTS: The new offer SKU already exists for the customer. Call the ChangePlan api if the new offer has the same product and SKU as the existing one. * INVALID_PLAN: If purchasing multiple SKUs of the same product family results in a upgrade, the plan based on the existing SKU is commitment-based and the commitment interval hasn't expired. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata. Deprecated: Use `ChangeOffer` instead.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "lookupOffer": {
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.customers.entitlements.lookupOffer",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Returns the requested Offer resource. Possible error codes: * PERMISSION_DENIED: The entitlement doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement or offer was not found. Return value: The Offer resource.",
                  "path": "v1alpha1/{+entitlement}:lookupOffer",
                  "parameters": {
                    "entitlement": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "description": "Required. The resource name of the entitlement to retrieve the Offer. Entitlement uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "parameterOrder": [
                    "entitlement"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:lookupOffer",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Offer"
                  }
                },
                "changeQuantity": {
                  "path": "v1alpha1/{+name}:changeQuantity",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "deprecated": true,
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeQuantityRequest"
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeQuantity",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.changeQuantity",
                  "description": "Updates the quantity for existing seat-based entitlements. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * SEAT_REDUCTION_NOT_ALLOWED: Can't decrease num_units for a commitment based plan in the middle of the commitment period. * SEATS_EXCEED_LIMIT: The number of seats being changed to is greater than the allowed number of max seats. This only applies to flex plans. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata. Deprecated: Use `ChangeParameters` instead.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "changeRenewalSettings": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Updates the renewal settings for an existing customer entitlement. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * NOT_COMMITMENT_PLAN: Renewal Settings are only applicable for a commitment plan. Can't enable or disable renewals for non-commitment plans. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "id": "cloudchannel.accounts.customers.entitlements.changeRenewalSettings",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeRenewalSettings",
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest"
                  },
                  "path": "v1alpha1/{+name}:changeRenewalSettings",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true
                    }
                  }
                },
                "changePlan": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Updates the plan for an existing customer entitlement. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Offer or Entitlement resource not found. * INVALID_PLAN: Can't update a commitment based plan to a flex plan in the middle of the commitment period. * SKU_CHANGE_NOT_ALLOWED: OfferId pertains to a different SKU. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata. Deprecated: Use `ChangeOffer` instead.",
                  "id": "cloudchannel.accounts.customers.entitlements.changePlan",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changePlan",
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangePlanRequest"
                  },
                  "path": "v1alpha1/{+name}:changePlan",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "deprecated": true
                },
                "activate": {
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.activate",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Activates a previously suspended entitlement. Entitlements suspended for pending ToS acceptance can't be activated using this method. An entitlement activation is a long-running operation and it updates the state of the customer entitlement. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * SUSPENSION_NOT_RESELLER_INITIATED: Can only activate reseller-initiated suspensions and entitlements that have accepted the TOS. * NOT_SUSPENDED: Can only activate suspended entitlements not in an ACTIVE state. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ActivateEntitlementRequest"
                  },
                  "path": "v1alpha1/{+name}:activate",
                  "parameters": {
                    "name": {
                      "description": "Required. The resource name of the entitlement to activate. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:activate",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  }
                },
                "assignChannelPartner": {
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest"
                  },
                  "path": "v1alpha1/{+name}:assignChannelPartner",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The resource name of the entitlement to assign. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Entitlement"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:assignChannelPartner",
                  "id": "cloudchannel.accounts.customers.entitlements.assignChannelPartner",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Assigns a channel partner to an Entitlement resource. The assigned partner becomes the reseller for the entitlement and will gain delegated admin access to the customer's entitlement. You must be a distributor to call this method. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement or ChannelPartner resource not found. Usually because of an invalid channel_partner_id or entitlement name. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The Entitlement resource with an updated channel partner."
                },
                "changeOffer": {
                  "id": "cloudchannel.accounts.customers.entitlements.changeOffer",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Updates the Offer for an existing customer entitlement. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Offer or Entitlement resource not found. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeOfferRequest"
                  },
                  "path": "v1alpha1/{+name}:changeOffer",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "description": "Required. The resource name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeOffer"
                },
                "startPaidService": {
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}:startPaidService",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The name of the entitlement to start a paid service for. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1StartPaidServiceRequest"
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:startPaidService",
                  "id": "cloudchannel.accounts.customers.entitlements.startPaidService",
                  "httpMethod": "POST",
                  "description": "Starts paid service for a trial entitlement. Starts paid service for a trial entitlement immediately. This method is only applicable if a plan is set up for a trial entitlement but has some trial days remaining. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * FAILED_PRECONDITION/NOT_IN_TRIAL: This method only works for entitlement on trial plans. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "cancel": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:cancel",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:cancel",
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the entitlement to cancel. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CancelEntitlementRequest"
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "description": "Cancels a previously fulfilled entitlement. An entitlement cancellation is a long-running operation. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * FAILED_PRECONDITION: There are Google Cloud projects linked to the Google Cloud entitlement's Cloud Billing subaccount. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: Entitlement resource not found. * DELETION_TYPE_NOT_ALLOWED: Cancel is only allowed for Google Workspace add-ons, or entitlements for Google Cloud's development platform. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The response will contain google.protobuf.Empty on success. The Operation metadata will contain an instance of OperationMetadata.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.cancel"
                },
                "listEntitlementChanges": {
                  "description": "List entitlement history. Possible error codes: * PERMISSION_DENIED: The reseller account making the request and the provided reseller account are different. * INVALID_ARGUMENT: Missing or invalid required fields in the request. * NOT_FOUND: The parent resource doesn't exist. Usually the result of an invalid name parameter. * INTERNAL: Any non-user error related to a technical issue in the backend. In this case, contact CloudChannel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. In this case, contact Cloud Channel support. Return value: List of EntitlementChanges.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.customers.entitlements.listEntitlementChanges",
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:listEntitlementChanges",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse"
                  },
                  "path": "v1alpha1/{+parent}:listEntitlementChanges",
                  "parameters": {
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. The maximum number of entitlement changes to return. The service may return fewer than this value. If unspecified, returns at most 10 entitlement changes. The maximum value is 50; the server will coerce values above 50.",
                      "type": "integer"
                    },
                    "parent": {
                      "description": "Required. The resource name of the entitlement for which to list entitlement changes. The `-` wildcard may be used to match entitlements across a customer. Formats: * accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id} * accounts/{account_id}/customers/{customer_id}/entitlements/-",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    },
                    "pageToken": {
                      "description": "Optional. A page token, received from a previous CloudChannelService.ListEntitlementChanges call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to CloudChannelService.ListEntitlementChanges must match the call that provided the page token.",
                      "type": "string",
                      "location": "query"
                    },
                    "filter": {
                      "description": "Optional. Filters applied to the list results.",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ]
                },
                "changeParameters": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Change parameters of the entitlement. An entitlement update is a long-running operation and it updates the entitlement as a result of fulfillment. Possible error codes: * PERMISSION_DENIED: The customer doesn't belong to the reseller. * INVALID_ARGUMENT: Required request parameters are missing or invalid. For example, the number of seats being changed is greater than the allowed number of max seats, or decreasing seats for a commitment based plan. * NOT_FOUND: Entitlement resource not found. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The ID of a long-running operation. To get the results of the operation, call the GetOperation method of CloudChannelOperationsService. The Operation metadata will contain an instance of OperationMetadata.",
                  "id": "cloudchannel.accounts.customers.entitlements.changeParameters",
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeParameters",
                  "parameterOrder": [
                    "name"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeParametersRequest"
                  },
                  "path": "v1alpha1/{+name}:changeParameters",
                  "parameters": {
                    "name": {
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    }
                  }
                }
              }
            }
          }
        },
        "offers": {
          "methods": {
            "list": {
              "parameterOrder": [
                "parent"
              ],
              "path": "v1alpha1/{+parent}/offers",
              "parameters": {
                "pageToken": {
                  "location": "query",
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string"
                },
                "dealCode": {
                  "location": "query",
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "type": "string"
                },
                "pageSize": {
                  "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, returns at most 500 Offers. The maximum value is 1000; the server will coerce values above 1000.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of the reseller account from which to list Offers. Parent uses the format: accounts/{account_id}.",
                  "type": "string"
                },
                "filter": {
                  "description": "Optional. The expression to filter results by name (name of the Offer), sku.name (name of the SKU), or sku.product.name (name of the Product). Example 1: sku.product.name=products/p1 AND sku.name!=products/p1/skus/s1 Example 2: name=accounts/a1/offers/o1",
                  "type": "string",
                  "location": "query"
                },
                "languageCode": {
                  "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
                  "type": "string",
                  "location": "query"
                },
                "showFutureOffers": {
                  "description": "Optional. A boolean flag that determines if a response returns future offers 30 days from now. If the show_future_offers is true, the response will only contain offers that are scheduled to be available 30 days from now.",
                  "type": "boolean",
                  "location": "query"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListOffersResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/offers",
              "id": "cloudchannel.accounts.offers.list",
              "httpMethod": "GET",
              "description": "Lists the Offers the reseller can sell. Possible error codes: * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            }
          }
        },
        "channelPartnerLinks": {
          "methods": {
            "list": {
              "description": "List ChannelPartnerLinks belonging to a distributor. You must be a distributor to call this method. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: The list of the distributor account's ChannelPartnerLink resources.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "id": "cloudchannel.accounts.channelPartnerLinks.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListChannelPartnerLinksResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1alpha1/{+parent}/channelPartnerLinks",
              "parameters": {
                "pageToken": {
                  "description": "Optional. A token for a page of results other than the first page. Obtained using ListChannelPartnerLinksResponse.next_page_token of the previous CloudChannelService.ListChannelPartnerLinks call.",
                  "type": "string",
                  "location": "query"
                },
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. The resource name of the reseller account for listing channel partner links. Parent uses the format: accounts/{account_id}",
                  "type": "string"
                },
                "view": {
                  "location": "query",
                  "description": "Optional. The level of granularity the ChannelPartnerLink will display.",
                  "type": "string",
                  "enumDescriptions": [
                    "The default / unset value. The API will default to the BASIC view.",
                    "Includes all fields except the ChannelPartnerLink.channel_partner_cloud_identity_info.",
                    "Includes all fields."
                  ],
                  "enum": [
                    "UNSPECIFIED",
                    "BASIC",
                    "FULL"
                  ]
                },
                "pageSize": {
                  "location": "query",
                  "format": "int32",
                  "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, server will pick a default size (25). The maximum value is 200; the server will coerce values above 200.",
                  "type": "integer"
                }
              }
            },
            "patch": {
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "required": true,
                  "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                  "description": "Required. The resource name of the channel partner link to cancel. Name uses the format: accounts/{account_id}/channelPartnerLinks/{id} where {id} is the Cloud Identity ID of the partner.",
                  "type": "string",
                  "location": "path"
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1UpdateChannelPartnerLinkRequest"
              },
              "parameterOrder": [
                "name"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "httpMethod": "PATCH",
              "id": "cloudchannel.accounts.channelPartnerLinks.patch",
              "description": "Updates a channel partner link. Distributors call this method to change a link's status. For example, to suspend a partner link. You must be a distributor to call this method. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: * Required request parameters are missing or invalid. * Link state cannot change from invited to active or suspended. * Cannot send reseller_cloud_identity_id, invite_url, or name in update mask. * NOT_FOUND: ChannelPartnerLink resource not found. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The updated ChannelPartnerLink resource.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            },
            "create": {
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.channelPartnerLinks.create",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Initiates a channel partner link between a distributor and a reseller, or between resellers in an n-tier reseller channel. Invited partners need to follow the invite_link_uri provided in the response to accept. After accepting the invitation, a link is set up between the two parties. You must be a distributor to call this method. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * ALREADY_EXISTS: The ChannelPartnerLink sent in the request already exists. * NOT_FOUND: No Cloud Identity customer exists for provided domain. * INTERNAL: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. * UNKNOWN: Any non-user error related to a technical issue in the backend. Contact Cloud Channel support. Return value: The new ChannelPartnerLink resource.",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "path": "v1alpha1/{+parent}/channelPartnerLinks",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "required": true,
                  "location": "path",
                  "description": "Required. Create a channel partner link for the provided reseller account's resource name. Parent uses the format: accounts/{account_id}",
                  "type": "string"
                },
                "domain": {
                  "description": "Optional. The invited partner's domain. Either domain or channel_partner_link.reseller_cloud_identity_id can be used to create a link. Deprecated: Use ChannelPartnerLink.reseller_cloud_identity_id instead",
                  "deprecated": true,
                  "type": "string",
                  "location": "query"
                }
              },
              "parameterOrder": [
                "parent"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              }
            },
            "get": {
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "description": "Required. The resource name of the channel partner link to retrieve. Name uses the format: accounts/{account_id}/channelPartnerLinks/{id} where {id} is the Cloud Identity ID of the partner.",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                },
                "view": {
                  "location": "query",
                  "description": "Optional. The level of granularity the ChannelPartnerLink will display.",
                  "type": "string",
                  "enumDescriptions": [
                    "The default / unset value. The API will default to the BASIC view.",
                    "Includes all fields except the ChannelPartnerLink.channel_partner_cloud_identity_info.",
                    "Includes all fields."
                  ],
                  "enum": [
                    "UNSPECIFIED",
                    "BASIC",
                    "FULL"
                  ]
                }
              },
              "parameterOrder": [
                "name"
              ],
              "description": "Returns the requested ChannelPartnerLink resource. You must be a distributor to call this method. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: ChannelPartnerLink resource not found because of an invalid channel partner link name. Return value: The ChannelPartnerLink resource.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "GET",
              "id": "cloudchannel.accounts.channelPartnerLinks.get"
            }
          },
          "resources": {
            "customers": {
              "methods": {
                "patch": {
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.patch",
                  "httpMethod": "PATCH",
                  "description": "Updates an existing Customer resource for the reseller or distributor. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: No Customer resource found for the name in the request. Return value: The updated Customer resource.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$"
                    },
                    "name1": {
                      "location": "query",
                      "description": "Deprecated: Set Customer.name instead Name uses the format: accounts/{account_id}/customers/{customer_id}",
                      "deprecated": true,
                      "type": "string"
                    },
                    "updateMask": {
                      "description": "The update mask that applies to the resource. Optional.",
                      "type": "string",
                      "location": "query",
                      "format": "google-fieldmask"
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}"
                },
                "import": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers:import",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ImportCustomerRequest"
                  },
                  "path": "v1alpha1/{+parent}/customers:import",
                  "parameters": {
                    "parent": {
                      "description": "Required. The resource name of the reseller's account. Parent takes the format: accounts/{account_id} or accounts/{account_id}/channelPartnerLinks/{channel_partner_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Imports a Customer from the Cloud Identity associated with the provided Cloud Identity ID or domain before a TransferEntitlements call. If a linked Customer already exists and overwrite_if_exists is true, it will update that Customer's data. Possible error codes: * PERMISSION_DENIED: * The reseller account making the request is different from the reseller account in the API request. * You are not authorized to import the customer. See https://support.google.com/channelservices/answer/9759265 * NOT_FOUND: Cloud Identity doesn't exist or was deleted. * INVALID_ARGUMENT: Required parameters are missing, or the auth_token is expired or invalid. * ALREADY_EXISTS: A customer already exists and has conflicting critical fields. Requires an overwrite. Return value: The Customer.",
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.import"
                },
                "create": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Creates a new Customer resource under the reseller or distributor account. Possible error codes: * PERMISSION_DENIED: * The reseller account making the request is different from the reseller account in the API request. * You are not authorized to create a customer. See https://support.google.com/channelservices/answer/9759265 * INVALID_ARGUMENT: * Required request parameters are missing or invalid. * Domain field value doesn't match the primary email domain. Return value: The newly created Customer resource.",
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.create",
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "path": "v1alpha1/{+parent}/customers",
                  "parameters": {
                    "parent": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of reseller account in which to create the customer. Parent uses the format: accounts/{account_id}",
                      "type": "string"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ]
                },
                "get": {
                  "description": "Returns the requested Customer resource. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: The customer resource doesn't exist. Usually the result of an invalid name parameter. Return value: The Customer resource.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.get",
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$",
                      "description": "Required. The resource name of the customer to retrieve. Name uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ]
                },
                "delete": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Required. The resource name of the customer to delete.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$",
                      "required": true
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Deletes the given Customer permanently. Possible error codes: * PERMISSION_DENIED: The account making the request does not own this customer. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * FAILED_PRECONDITION: The customer has existing entitlements. * NOT_FOUND: No Customer resource found for the name in the request.",
                  "httpMethod": "DELETE",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.delete"
                },
                "list": {
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.list",
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "List Customers. Possible error codes: * PERMISSION_DENIED: The reseller account making the request is different from the reseller account in the API request. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: List of Customers, or an empty list if there are no customers.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "path": "v1alpha1/{+parent}/customers",
                  "parameters": {
                    "pageToken": {
                      "location": "query",
                      "description": "Optional. A token identifying a page of results other than the first page. Obtained through ListCustomersResponse.next_page_token of the previous CloudChannelService.ListCustomers call.",
                      "type": "string"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Filters applied to the [CloudChannelService.ListCustomers] results. See https://cloud.google.com/channel/docs/concepts/google-cloud/filter-customers for more information.",
                      "type": "string"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. The maximum number of customers to return. The service may return fewer than this value. If unspecified, returns at most 10 customers. The maximum value is 50.",
                      "type": "integer"
                    },
                    "parent": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                      "description": "Required. The resource name of the reseller account to list customers from. Parent uses the format: accounts/{account_id}.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListCustomersResponse"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers"
                }
              }
            },
            "channelPartnerRepricingConfigs": {
              "methods": {
                "patch": {
                  "description": "Updates a ChannelPartnerRepricingConfig. Call this method to set modifications for a specific ChannelPartner's bill. This method overwrites the existing CustomerRepricingConfig. You can only update configs if the RepricingConfig.effective_invoice_month is a future month. To make changes to configs for the current month, use CreateChannelPartnerRepricingConfig, taking note of its restrictions. You cannot update the RepricingConfig.effective_invoice_month. When updating a config in the future: * This config must already exist. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * INVALID_ARGUMENT: Missing or invalid required parameters in the request. Also displays if the updated config is for the current month or past months. * NOT_FOUND: The ChannelPartnerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the updated ChannelPartnerRepricingConfig resource, otherwise returns an error.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "PATCH",
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.patch",
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "description": "Output only. Resource name of the ChannelPartnerRepricingConfig. Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "parameterOrder": [
                    "name"
                  ]
                },
                "create": {
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.create",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Creates a ChannelPartnerRepricingConfig. Call this method to set modifications for a specific ChannelPartner's bill. You can only create configs if the RepricingConfig.effective_invoice_month is a future month. If needed, you can create a config for the current month, with some restrictions. When creating a config for a future month, make sure there are no existing configs for that RepricingConfig.effective_invoice_month. The following restrictions are for creating configs in the current month. * This functionality is reserved for recovering from an erroneous config, and should not be used for regular business cases. * The new config will not modify exports used with other configs. Changes to the config may be immediate, but may take up to 24 hours. * There is a limit of ten configs for any ChannelPartner or RepricingConfig.EntitlementGranularity.entitlement, for any RepricingConfig.effective_invoice_month. * The contained ChannelPartnerRepricingConfig.repricing_config value must be different from the value used in the current config for a ChannelPartner. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * INVALID_ARGUMENT: Missing or invalid required parameters in the request. Also displays if the updated config is for the current month or past months. * NOT_FOUND: The ChannelPartnerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the updated ChannelPartnerRepricingConfig resource, otherwise returns an error.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "path": "v1alpha1/{+parent}/channelPartnerRepricingConfigs",
                  "parameters": {
                    "parent": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the ChannelPartner that will receive the repricing config. Parent uses the format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs"
                },
                "get": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$",
                      "description": "Required. The resource name of the ChannelPartnerRepricingConfig Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
                      "type": "string",
                      "location": "path"
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Gets information about how a Distributor modifies their bill before sending it to a ChannelPartner. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * NOT_FOUND: The ChannelPartnerRepricingConfig was not found. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the ChannelPartnerRepricingConfig resource, otherwise returns an error.",
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.get"
                },
                "delete": {
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "description": "Required. The resource name of the channel partner repricing config rule to delete.",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$"
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "httpMethod": "DELETE",
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.delete",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "description": "Deletes the given ChannelPartnerRepricingConfig permanently. You can only delete configs if their RepricingConfig.effective_invoice_month is set to a date after the current month. Possible error codes: * PERMISSION_DENIED: The account making the request does not own this customer. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * FAILED_PRECONDITION: The ChannelPartnerRepricingConfig is active or in the past. * NOT_FOUND: No ChannelPartnerRepricingConfig found for the name in the request."
                },
                "list": {
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.list",
                  "description": "Lists information about how a Reseller modifies their bill before sending it to a ChannelPartner. Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different. * NOT_FOUND: The ChannelPartnerRepricingConfig specified does not exist or is not associated with the given account. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the ChannelPartnerRepricingConfig resources. The data for each resource is displayed in the ascending order of: * Channel Partner ID * RepricingConfig.effective_invoice_month * ChannelPartnerRepricingConfig.update_time If unsuccessful, returns an error.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "path": "v1alpha1/{+parent}/channelPartnerRepricingConfigs",
                  "parameters": {
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results beyond the first page. Obtained through ListChannelPartnerRepricingConfigsResponse.next_page_token of the previous CloudChannelService.ListChannelPartnerRepricingConfigs call.",
                      "type": "string",
                      "location": "query"
                    },
                    "filter": {
                      "description": "Optional. A filter for [CloudChannelService.ListChannelPartnerRepricingConfigs] results (channel_partner_link only). You can use this filter when you support a BatchGet-like query. To use the filter, you must set `parent=accounts/{account_id}/channelPartnerLinks/-`. Example: `channel_partner_link = accounts/account_id/channelPartnerLinks/c1` OR `channel_partner_link = accounts/account_id/channelPartnerLinks/c2`.",
                      "type": "string",
                      "location": "query"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. The maximum number of repricing configs to return. The service may return fewer than this value. If unspecified, returns a maximum of 50 rules. The maximum value is 100; values above 100 will be coerced to 100.",
                      "type": "integer"
                    },
                    "parent": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                      "required": true,
                      "location": "path",
                      "description": "Required. The resource name of the account's ChannelPartnerLink. Parent uses the format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}. Supports accounts/{account_id}/channelPartnerLinks/- to retrieve configs for all channel partners.",
                      "type": "string"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse"
                  }
                }
              }
            }
          }
        },
        "skuGroups": {
          "methods": {
            "list": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "description": "Lists the Rebilling supported SKU groups the account is authorized to sell. Reference: https://cloud.google.com/skus/sku-groups Possible Error Codes: * PERMISSION_DENIED: If the account making the request and the account being queried are different, or the account doesn't exist. * INTERNAL: Any non-user error related to technical issues in the backend. In this case, contact Cloud Channel support. Return Value: If successful, the SkuGroup resources. The data for each resource is displayed in the alphabetical order of SKU group display name. The data for each resource is displayed in the ascending order of SkuGroup.display_name If unsuccessful, returns an error.",
              "id": "cloudchannel.accounts.skuGroups.list",
              "httpMethod": "GET",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListSkuGroupsResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/skuGroups",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1alpha1/{+parent}/skuGroups",
              "parameters": {
                "pageToken": {
                  "description": "Optional. A token identifying a page of results beyond the first page. Obtained through ListSkuGroupsResponse.next_page_token of the previous CloudChannelService.ListSkuGroups call.",
                  "type": "string",
                  "location": "query"
                },
                "pageSize": {
                  "description": "Optional. The maximum number of SKU groups to return. The service may return fewer than this value. If unspecified, returns a maximum of 1000 SKU groups. The maximum value is 1000; values above 1000 will be coerced to 1000.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "parent": {
                  "required": true,
                  "pattern": "^accounts/[^/]+$",
                  "description": "Required. The resource name of the account from which to list SKU groups. Parent uses the format: accounts/{account}.",
                  "type": "string",
                  "location": "path"
                }
              }
            }
          },
          "resources": {
            "billableSkus": {
              "methods": {
                "list": {
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.skuGroups.billableSkus.list",
                  "description": "Lists the Billable SKUs in a given SKU group. Possible error codes: PERMISSION_DENIED: If the account making the request and the account being queried for are different, or the account doesn't exist. INVALID_ARGUMENT: Missing or invalid required parameters in the request. INTERNAL: Any non-user error related to technical issue in the backend. In this case, contact cloud channel support. Return Value: If successful, the BillableSku resources. The data for each resource is displayed in the ascending order of: * BillableSku.service_display_name * BillableSku.sku_display_name If unsuccessful, returns an error.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "path": "v1alpha1/{+parent}/billableSkus",
                  "parameters": {
                    "parent": {
                      "description": "Required. Resource name of the SKU group. Format: accounts/{account}/skuGroups/{sku_group}.",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/skuGroups/[^/]+$"
                    },
                    "pageSize": {
                      "location": "query",
                      "format": "int32",
                      "description": "Optional. The maximum number of SKUs to return. The service may return fewer than this value. If unspecified, returns a maximum of 100000 SKUs. The maximum value is 100000; values above 100000 will be coerced to 100000.",
                      "type": "integer"
                    },
                    "pageToken": {
                      "description": "Optional. A token identifying a page of results beyond the first page. Obtained through ListSkuGroupBillableSkusResponse.next_page_token of the previous CloudChannelService.ListSkuGroupBillableSkus call.",
                      "type": "string",
                      "location": "query"
                    }
                  },
                  "parameterOrder": [
                    "parent"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/skuGroups/{skuGroupsId}/billableSkus",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse"
                  }
                }
              }
            }
          }
        }
      }
    },
    "products": {
      "methods": {
        "list": {
          "httpMethod": "GET",
          "id": "cloudchannel.products.list",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Lists the Products the reseller is authorized to sell. Possible error codes: * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
          "path": "v1alpha1/products",
          "parameters": {
            "languageCode": {
              "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
              "type": "string",
              "location": "query"
            },
            "pageSize": {
              "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 Products. The maximum value is 1000; the server will coerce values above 1000.",
              "type": "integer",
              "location": "query",
              "format": "int32"
            },
            "account": {
              "location": "query",
              "description": "Required. The resource name of the reseller account. Format: accounts/{account_id}.",
              "type": "string"
            },
            "pageToken": {
              "description": "Optional. A token for a page of results other than the first page.",
              "type": "string",
              "location": "query"
            }
          },
          "parameterOrder": [],
          "flatPath": "v1alpha1/products",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListProductsResponse"
          }
        }
      },
      "resources": {
        "skus": {
          "methods": {
            "list": {
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListSkusResponse"
              },
              "flatPath": "v1alpha1/products/{productsId}/skus",
              "parameterOrder": [
                "parent"
              ],
              "path": "v1alpha1/{+parent}/skus",
              "parameters": {
                "account": {
                  "description": "Required. Resource name of the reseller. Format: accounts/{account_id}.",
                  "type": "string",
                  "location": "query"
                },
                "pageToken": {
                  "location": "query",
                  "description": "Optional. A token for a page of results other than the first page. Optional.",
                  "type": "string"
                },
                "parent": {
                  "required": true,
                  "pattern": "^products/[^/]+$",
                  "description": "Required. The resource name of the Product to list SKUs for. Parent uses the format: products/{product_id}. Supports products/- to retrieve SKUs for all products.",
                  "type": "string",
                  "location": "path"
                },
                "pageSize": {
                  "description": "Optional. Requested page size. Server might return fewer results than requested. If unspecified, returns at most 100 SKUs. The maximum value is 1000; the server will coerce values above 1000.",
                  "type": "integer",
                  "location": "query",
                  "format": "int32"
                },
                "languageCode": {
                  "description": "Optional. The BCP-47 language code. For example, \"en-US\". The response will localize in the corresponding language code, if specified. The default value is \"en-US\".",
                  "type": "string",
                  "location": "query"
                }
              },
              "description": "Lists the SKUs for a product the reseller is authorized to sell. Possible error codes: * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "id": "cloudchannel.products.skus.list",
              "httpMethod": "GET"
            }
          }
        }
      }
    },
    "opportunities": {
      "methods": {
        "query": {
          "id": "cloudchannel.opportunities.query",
          "httpMethod": "GET",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Query Opportunitys associated with a specific Partner. Possible error codes: * PERMISSION_DENIED: The user making the request isn't allowed to list opportunities associated with the given partner. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: Opportunitys the user has access to, or an empty list if there are no opportunities.",
          "parameterOrder": [],
          "path": "v1alpha1/opportunities:query",
          "parameters": {
            "pageSize": {
              "description": "Optional. The maximum number of opportunities to return. The service might return fewer than this value. If unspecified, at most 50 opportunities are returned. The maximum value is 100; values above 100 are coerced to 100.",
              "type": "integer",
              "location": "query",
              "format": "int32"
            },
            "pageToken": {
              "description": "Optional. A page token, received from a previous `QueryOpportunities` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `QueryOpportunities` must match the call that provided the page token.",
              "type": "string",
              "location": "query"
            },
            "orderBy": {
              "location": "query",
              "description": "Optional. Sort order of the Opportunity. Currently supports sorting on the following fields: * `state` * `stage` * `partner_info.rebate_expiration_date` * `sales_cycle.close_date` * `source` * `opportunity_info.display_name` * `customer_display_name` * `opportunity_info.product_category` * `update_time` For information on the sort format, see https://google.aip.dev/132#ordering.",
              "type": "string"
            },
            "partner": {
              "description": "Required. Provide the Partner ID for which the Opportunities are being queried. Format: partner = partners/{id}",
              "type": "string",
              "location": "query"
            },
            "filter": {
              "description": "Optional. Filters on the Opportunity. Currently supports filtering on the following fields: * `state` * `stage` * `partner_info.rebate_expiration_date` * `sales_cycle.close_date` * `source` * `customer_display_name` * `partner_info.incentive_eligibility` * `qualification_info.campaign_code` * `update_time` For information on the filter format, see https://google.aip.dev/160.",
              "type": "string",
              "location": "query"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse"
          },
          "flatPath": "v1alpha1/opportunities:query"
        },
        "patch": {
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "flatPath": "v1alpha1/opportunities/{opportunitiesId}",
          "parameterOrder": [
            "name"
          ],
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "path": "v1alpha1/{+name}",
          "parameters": {
            "partner": {
              "description": "Required. Provide the Partner Id for which the Opportunity is being updated. Format: partner = partners/{id}",
              "type": "string",
              "location": "query"
            },
            "updateMask": {
              "description": "Required. The list of fields to update.",
              "type": "string",
              "location": "query",
              "format": "google-fieldmask"
            },
            "name": {
              "pattern": "^opportunities/[^/]+$",
              "required": true,
              "location": "path",
              "description": "Identifier. Resource name of an Opportunity in the form: opportunities/{opportunity_id}. Available in Limited view.",
              "type": "string"
            }
          },
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Updates an existing Opportunity resource. * `DRAFT`/`REJECTED`: All fields for a `DRAFT` or `REJECTED` Opportunity can be edited. * `SUBMITTED`: You can't make further updates to a `SUBMITTED` Opportunity. * `ACCEPTED`: You can update some, but not all, of the fields for an `ACCEPTED` opportunity. Possible error codes: * PERMISSION_DENIED: The user making the request isn't allowed to update the opportunity. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: No Opportunity resource found for the name in the request. Return value: The updated Opportunity resource.",
          "id": "cloudchannel.opportunities.patch",
          "httpMethod": "PATCH"
        },
        "create": {
          "path": "v1alpha1/opportunities",
          "parameters": {},
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "parameterOrder": [],
          "flatPath": "v1alpha1/opportunities",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "httpMethod": "POST",
          "id": "cloudchannel.opportunities.create",
          "description": "Creates a new Opportunity resource for a deal submission process. This can have the state `DRAFT` or `SUBMITTED`. Creating a `SUBMITTED` opportunity initiates an offline review process, in which Google determines whether it's `ACCEPTED` or `REJECTED`. Possible error codes: * PERMISSION_DENIED: The user making the request isn't allowed to create an opportunity. * INVALID_ARGUMENT: Required request parameters are missing or invalid. Return value: The newly created Opportunity resource.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "get": {
          "path": "v1alpha1/{+name}",
          "parameters": {
            "name": {
              "description": "Required. The name of the opportunity to retrieve. Format: opportunities/{opportunity}",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^opportunities/[^/]+$"
            },
            "partner": {
              "location": "query",
              "description": "Required. Provide the Partner Id for which the Opportunity is being retrieved. Format: partner = partners/{id}",
              "type": "string"
            }
          },
          "parameterOrder": [
            "name"
          ],
          "flatPath": "v1alpha1/opportunities/{opportunitiesId}",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "httpMethod": "GET",
          "id": "cloudchannel.opportunities.get",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "description": "Returns the requested Opportunity resource. Possible error codes: * PERMISSION_DENIED: The user making the request isn't allowed to view the opportunity. * INVALID_ARGUMENT: Required request parameters are missing or invalid. * NOT_FOUND: No Opportunity resource found for the name in the request. Return value: The Opportunity resource."
        }
      }
    }
  },
  "fullyEncodeReservedExpansion": true,
  "rootUrl": "https://cloudchannel.googleapis.com/",
  "version": "v1alpha1",
  "canonicalName": "Cloudchannel",
  "auth": {
    "oauth2": {
      "scopes": {
        "https://www.googleapis.com/auth/apps.order": {
          "description": "Manage users on your domain"
        },
        "https://www.googleapis.com/auth/apps.reports.usage.readonly": {
          "description": "View usage reports for your Google Workspace domain"
        }
      }
    }
  },
  "discoveryVersion": "v1",
  "revision": "20260620",
  "basePath": ""
}
