{
  "basePath": "",
  "fullyEncodeReservedExpansion": true,
  "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"
        }
      }
    }
  },
  "parameters": {
    "$.xgafv": {
      "enumDescriptions": [
        "v1 error format",
        "v2 error format"
      ],
      "location": "query",
      "type": "string",
      "description": "V1 error format.",
      "enum": [
        "1",
        "2"
      ]
    },
    "access_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth access token."
    },
    "prettyPrint": {
      "location": "query",
      "type": "boolean",
      "description": "Returns response with indentations and line breaks.",
      "default": "true"
    },
    "alt": {
      "enumDescriptions": [
        "Responses with Content-Type of application/json",
        "Media download with context-dependent Content-Type",
        "Responses with Content-Type of application/x-protobuf"
      ],
      "location": "query",
      "type": "string",
      "description": "Data format for response.",
      "default": "json",
      "enum": [
        "json",
        "media",
        "proto"
      ]
    },
    "oauth_token": {
      "location": "query",
      "type": "string",
      "description": "OAuth 2.0 token for the current user."
    },
    "uploadType": {
      "location": "query",
      "type": "string",
      "description": "Legacy upload protocol for media (e.g. \"media\", \"multipart\")."
    },
    "fields": {
      "type": "string",
      "description": "Selector specifying which fields to include in a partial response.",
      "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"
    },
    "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": {
      "type": "string",
      "description": "Upload protocol for media (e.g. \"raw\", \"multipart\").",
      "location": "query"
    }
  },
  "discoveryVersion": "v1",
  "title": "Cloud Channel API",
  "servicePath": "",
  "ownerName": "Google",
  "baseUrl": "https://cloudchannel.googleapis.com/",
  "kind": "discovery#restDescription",
  "schemas": {
    "GoogleCloudChannelV1alpha1Parameter": {
      "properties": {
        "value": {
          "description": "Value of the parameter.",
          "$ref": "GoogleCloudChannelV1alpha1Value"
        },
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "editable": {
          "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",
          "readOnly": true
        }
      },
      "id": "GoogleCloudChannelV1alpha1Parameter",
      "description": "Definition for extended entitlement parameters.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Report": {
      "deprecated": true,
      "properties": {
        "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"
        },
        "description": {
          "description": "A description of other aspects of the report, such as the products it supports.",
          "type": "string"
        },
        "displayName": {
          "description": "A human-readable name for this report.",
          "type": "string"
        },
        "columns": {
          "description": "The list of columns included in the report. This defines the schema of the report results.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Column"
          }
        }
      },
      "id": "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"
    },
    "GoogleCloudChannelV1alpha1ReportValue": {
      "deprecated": true,
      "properties": {
        "moneyValue": {
          "description": "A value of type `google.type.Money` (currency code, whole units, decimal units).",
          "$ref": "GoogleTypeMoney"
        },
        "dateTimeValue": {
          "description": "A value of type `google.type.DateTime` (year, month, day, hour, minute, second, and UTC offset or timezone.)",
          "$ref": "GoogleTypeDateTime"
        },
        "decimalValue": {
          "description": "A value of type `google.type.Decimal`, representing non-integer numeric values.",
          "$ref": "GoogleTypeDecimal"
        },
        "dateValue": {
          "description": "A value of type `google.type.Date` (year, month, day).",
          "$ref": "GoogleTypeDate"
        },
        "stringValue": {
          "description": "A value of type `string`.",
          "type": "string"
        },
        "intValue": {
          "description": "A value of type `int`.",
          "type": "string",
          "format": "int64"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ReportValue",
      "description": "A single report value.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CloudIdentityInfo": {
      "id": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
      "description": "Cloud Identity information for the Cloud Channel Customer.",
      "type": "object",
      "properties": {
        "alternateEmail": {
          "description": "The alternate email.",
          "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"
          ]
        },
        "languageCode": {
          "description": "Language code.",
          "type": "string"
        },
        "adminConsoleUri": {
          "readOnly": true,
          "description": "Output only. URI of Customer's Admin console dashboard.",
          "type": "string"
        },
        "phoneNumber": {
          "description": "Phone number associated with the Cloud Identity.",
          "type": "string"
        },
        "primaryDomain": {
          "description": "Output only. The primary domain name.",
          "type": "string",
          "readOnly": true
        },
        "eduData": {
          "description": "Edu information about the customer.",
          "$ref": "GoogleCloudChannelV1alpha1EduData"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1Period": {
      "properties": {
        "duration": {
          "format": "int32",
          "description": "Total duration of Period Type defined.",
          "type": "integer"
        },
        "periodType": {
          "enumDescriptions": [
            "Not used.",
            "Day.",
            "Month.",
            "Year."
          ],
          "enum": [
            "PERIOD_TYPE_UNSPECIFIED",
            "DAY",
            "MONTH",
            "YEAR"
          ],
          "description": "Period Type.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1Period",
      "description": "Represents period in days/months/years.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ContactInfo": {
      "id": "GoogleCloudChannelV1alpha1ContactInfo",
      "description": "Contact information for a customer account.",
      "type": "object",
      "properties": {
        "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"
        },
        "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"
        },
        "lastName": {
          "description": "The customer account contact's last name. Optional for Team customers.",
          "type": "string"
        },
        "title": {
          "description": "Optional. The customer account contact's job title.",
          "type": "string"
        },
        "phone": {
          "description": "The customer account's contact phone number.",
          "type": "string"
        },
        "firstName": {
          "description": "The customer account contact's first name. Optional for Team customers.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsResponse": {
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsResponse",
      "description": "Response message for CloudChannelService.TransferEntitlements. This is put in the response field of google.longrunning.Operation.",
      "type": "object",
      "properties": {
        "entitlements": {
          "description": "The transferred entitlements.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          }
        }
      }
    },
    "GoogleCloudChannelV1RenewalSettings": {
      "id": "GoogleCloudChannelV1RenewalSettings",
      "description": "Renewal settings for renewable Offers.",
      "type": "object",
      "properties": {
        "paymentPlan": {
          "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": "Describes how a reseller will be billed.",
          "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": "GoogleCloudChannelV1Period"
        }
      }
    },
    "GoogleCloudChannelV1alpha1DateRange": {
      "deprecated": true,
      "properties": {
        "usageStartDateTime": {
          "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.",
          "$ref": "GoogleTypeDateTime"
        },
        "usageEndDateTime": {
          "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.",
          "$ref": "GoogleTypeDateTime"
        },
        "invoiceStartDate": {
          "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.",
          "$ref": "GoogleTypeDate"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1DateRange",
      "description": "A representation of usage or invoice date ranges.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSubscribersResponse": {
      "id": "GoogleCloudChannelV1alpha1ListSubscribersResponse",
      "description": "Response Message for ListSubscribers.",
      "type": "object",
      "properties": {
        "topic": {
          "description": "Name of the topic registered with the reseller.",
          "type": "string"
        },
        "serviceAccounts": {
          "items": {
            "type": "string"
          },
          "description": "List of service accounts which have subscriber access to the topic.",
          "type": "array"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1EntitlementEvent": {
      "id": "GoogleCloudChannelV1alpha1EntitlementEvent",
      "description": "Represents Pub/Sub message content describing entitlement update.",
      "type": "object",
      "properties": {
        "eventType": {
          "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": "Type of event which happened for the entitlement.",
          "type": "string"
        },
        "entitlement": {
          "description": "Resource name of an entitlement of the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1DiscountComponent": {
      "id": "GoogleCloudChannelV1alpha1DiscountComponent",
      "description": "Represents a single component of the total discount applicable on a Price.",
      "type": "object",
      "properties": {
        "discountType": {
          "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"
          ],
          "description": "Type of the discount.",
          "type": "string"
        },
        "discountPercentage": {
          "description": "Discount percentage, represented as decimal. For example, a 20% discount will be represented as 0.2.",
          "type": "number",
          "format": "double"
        },
        "discountAbsolute": {
          "description": "Fixed value discount.",
          "$ref": "GoogleTypeMoney"
        }
      }
    },
    "GoogleCloudChannelV1ReportResultsMetadata": {
      "id": "GoogleCloudChannelV1ReportResultsMetadata",
      "description": "The features describing the data. Returned by CloudChannelReportsService.RunReportJob and CloudChannelReportsService.FetchReportResults.",
      "type": "object",
      "properties": {
        "report": {
          "description": "Details of the completed report.",
          "$ref": "GoogleCloudChannelV1Report"
        },
        "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": "GoogleCloudChannelV1DateRange"
        },
        "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": "GoogleCloudChannelV1DateRange"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ListTransferableSkusRequest": {
      "id": "GoogleCloudChannelV1alpha1ListTransferableSkusRequest",
      "description": "Request message for CloudChannelService.ListTransferableSkus",
      "type": "object",
      "properties": {
        "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"
        },
        "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"
        },
        "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"
        },
        "cloudIdentityId": {
          "description": "Customer's Cloud Identity ID",
          "type": "string"
        },
        "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"
        },
        "pageSize": {
          "format": "int32",
          "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"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleTypeDecimal",
      "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"
    },
    "GoogleCloudChannelV1Parameter": {
      "id": "GoogleCloudChannelV1Parameter",
      "description": "Definition for extended entitlement parameters.",
      "type": "object",
      "properties": {
        "value": {
          "description": "Value of the parameter.",
          "$ref": "GoogleCloudChannelV1Value"
        },
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "editable": {
          "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",
          "readOnly": true
        }
      }
    },
    "GoogleCloudChannelV1TransferEntitlementsResponse": {
      "id": "GoogleCloudChannelV1TransferEntitlementsResponse",
      "description": "Response message for CloudChannelService.TransferEntitlements. This is put in the response field of google.longrunning.Operation.",
      "type": "object",
      "properties": {
        "entitlements": {
          "items": {
            "$ref": "GoogleCloudChannelV1Entitlement"
          },
          "description": "The transferred entitlements.",
          "type": "array"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerLink": {
      "properties": {
        "inviteLinkUri": {
          "description": "Output only. URI of the web page where partner accepts the link invitation.",
          "type": "string",
          "readOnly": true
        },
        "createTime": {
          "description": "Output only. Timestamp of when the channel partner link is created.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "resellerCloudIdentityId": {
          "description": "Required. Cloud Identity ID of the linked reseller.",
          "type": "string"
        },
        "linkState": {
          "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"
          ],
          "description": "Required. State of the channel partner link.",
          "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"
        },
        "name": {
          "readOnly": true,
          "description": "Output only. Resource name for the channel partner link, in the format accounts/{account_id}/channelPartnerLinks/{id}.",
          "type": "string"
        },
        "partnerAdvantageInfo": {
          "description": "Output only. Partner Advantage information for this Channel Partner (IR).",
          "readOnly": true,
          "$ref": "GoogleCloudChannelV1alpha1PartnerAdvantageInfo"
        },
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Timestamp of when the channel partner link is updated.",
          "type": "string"
        },
        "channelPartnerCloudIdentityInfo": {
          "readOnly": true,
          "description": "Output only. Cloud Identity info of the channel partner (IR).",
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerLink",
      "description": "Entity representing a link between distributors and their indirect resellers in an n-tier resale channel.",
      "type": "object"
    },
    "GoogleTypeDateTime": {
      "id": "GoogleTypeDateTime",
      "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",
      "properties": {
        "nanos": {
          "format": "int32",
          "description": "Optional. Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999, defaults to 0.",
          "type": "integer"
        },
        "hours": {
          "format": "int32",
          "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"
        },
        "month": {
          "description": "Optional. Month of year. Must be from 1 to 12, or 0 if specifying a datetime without a month.",
          "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"
        },
        "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"
        },
        "timeZone": {
          "description": "Time zone.",
          "$ref": "GoogleTypeTimeZone"
        },
        "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"
        },
        "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"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ProductAuthorization": {
      "id": "GoogleCloudChannelV1alpha1ProductAuthorization",
      "description": "The product and region pairs that a reseller may be authorized to sell.",
      "type": "object",
      "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": {
          "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"
          ],
          "description": "The region where this reseller is authorized to sell this product family.",
          "type": "string"
        },
        "state": {
          "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"
          ],
          "description": "The state of this product authorization.",
          "type": "string"
        },
        "sellType": {
          "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"
          ],
          "description": "The type of reseller this ProductAuthorization corresponds to.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CommitmentSettings": {
      "id": "GoogleCloudChannelV1alpha1CommitmentSettings",
      "description": "Commitment settings for commitment-based offers.",
      "type": "object",
      "properties": {
        "endTime": {
          "format": "google-datetime",
          "description": "Output only. Commitment end timestamp.",
          "type": "string",
          "readOnly": true
        },
        "renewalSettings": {
          "description": "Optional. Renewal settings applicable for a commitment-based Offer.",
          "$ref": "GoogleCloudChannelV1alpha1RenewalSettings"
        },
        "startTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Commitment start timestamp.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Offer": {
      "id": "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",
      "properties": {
        "endTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. End of the Offer validity time.",
          "type": "string"
        },
        "plan": {
          "description": "Describes the payment plan for the Offer.",
          "$ref": "GoogleCloudChannelV1alpha1Plan"
        },
        "startTime": {
          "format": "google-datetime",
          "description": "Start of the Offer validity time.",
          "type": "string"
        },
        "dealCode": {
          "description": "The deal code of the offer to get a special promotion or discount.",
          "type": "string"
        },
        "sku": {
          "description": "SKU the offer is associated with.",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        },
        "parameterDefinitions": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ParameterDefinition"
          },
          "description": "Parameters required to use current Offer to purchase.",
          "type": "array"
        },
        "name": {
          "description": "Resource Name of the Offer. Format: accounts/{account_id}/offers/{offer_id}",
          "type": "string"
        },
        "constraints": {
          "description": "Constraints on transacting the Offer.",
          "$ref": "GoogleCloudChannelV1alpha1Constraints"
        },
        "marketingInfo": {
          "description": "Marketing information for the Offer.",
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo"
        },
        "priceByResources": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PriceByResource"
          },
          "description": "Price for each monetizable resource type.",
          "type": "array"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1TrialSettings",
      "description": "Settings for trial offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RegisterSubscriberRequest": {
      "id": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest",
      "description": "Request Message for RegisterSubscriber.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Row": {
      "id": "GoogleCloudChannelV1alpha1Row",
      "description": "A row of report values.",
      "type": "object",
      "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
    },
    "GoogleTypePhoneNumber": {
      "id": "GoogleTypePhoneNumber",
      "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",
      "properties": {
        "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": {
          "description": "A short code. Reference(s): - https://wikipedia.org/wiki/Short_code",
          "$ref": "GoogleTypePhoneNumberShortCode"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OperationMetadata": {
      "id": "GoogleCloudChannelV1alpha1OperationMetadata",
      "description": "Provides contextual information about a google.longrunning.Operation.",
      "type": "object",
      "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"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1Customer": {
      "properties": {
        "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"
        },
        "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": {
          "readOnly": true,
          "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "correlationId": {
          "description": "Optional. External CRM ID for the customer. Populated only if a CRM ID exists for this customer.",
          "type": "string"
        },
        "primaryContactInfo": {
          "description": "Primary contact info.",
          "$ref": "GoogleCloudChannelV1alpha1ContactInfo"
        },
        "createTime": {
          "description": "Output only. Time when the customer was created.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "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.",
          "type": "string",
          "readOnly": true,
          "deprecated": true
        },
        "updateTime": {
          "format": "google-datetime",
          "description": "Output only. Time when the customer was updated.",
          "type": "string",
          "readOnly": true
        },
        "customerAttestationState": {
          "description": "Optional. Indicate if a customer is attesting about the correctness of provided information. Only required if creating a GCP Entitlement.",
          "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"
          ]
        },
        "domain": {
          "description": "Required. The customer's primary domain. Must match the primary contact email's domain.",
          "type": "string"
        },
        "channelPartnerId": {
          "description": "Cloud Identity ID of the customer's channel partner. Populated only if a channel partner exists for this customer.",
          "type": "string"
        },
        "orgDisplayName": {
          "description": "Required. Name of the organization that the customer entity represents.",
          "type": "string"
        },
        "cloudIdentityId": {
          "readOnly": true,
          "description": "Output only. The customer's Cloud Identity ID if the customer has a Cloud Identity resource.",
          "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"
        },
        "cloudIdentityInfo": {
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
          "description": "Output only. Cloud Identity information for the customer. Populated only if a Cloud Identity account exists for this customer.",
          "readOnly": true
        }
      },
      "id": "GoogleCloudChannelV1alpha1Customer",
      "description": "Entity representing a customer of a reseller or distributor.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType": {
      "properties": {
        "isEligible": {
          "description": "If you can create a customer with that type.",
          "type": "boolean"
        },
        "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"
          ]
        },
        "ineligibilityReason": {
          "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"
          ],
          "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."
          ],
          "description": "Optional. Only shown if is_eligible = false.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType",
      "description": "A Cloud identity type, if you can provision it, and why. Used in the ListProvisionableCloudIdentityTypes response.",
      "type": "object"
    },
    "GoogleTypeTimeZone": {
      "id": "GoogleTypeTimeZone",
      "description": "Represents a time zone from the [IANA Time Zone Database](https://www.iana.org/time-zones).",
      "type": "object",
      "properties": {
        "id": {
          "description": "IANA Time Zone Database time zone. For example \"America/New_York\".",
          "type": "string"
        },
        "version": {
          "description": "Optional. IANA Time Zone Database version number. For example \"2019a\".",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerEvent": {
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerEvent",
      "description": "Represents Pub/Sub messages about updates to a Channel Partner. You can retrieve updated values through the ChannelPartnerLinks API.",
      "type": "object",
      "properties": {
        "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"
          ]
        },
        "channelPartner": {
          "description": "Resource name for the Channel Partner Link. Channel_partner uses the format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SkuPurchaseGroup": {
      "id": "GoogleCloudChannelV1alpha1SkuPurchaseGroup",
      "description": "Represents a set of SKUs that must be purchased using the same billing account.",
      "type": "object",
      "properties": {
        "skus": {
          "description": "Resource names of the SKUs included in this group. Format: products/{product_id}/skus/{sku_id}.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "billingAccountPurchaseInfos": {
          "description": "List of billing accounts that are eligible to purhcase these SKUs.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1SubscriberEvent": {
      "id": "GoogleCloudChannelV1alpha1SubscriberEvent",
      "description": "Represents information which resellers will get as part of notification from Pub/Sub.",
      "type": "object",
      "properties": {
        "customerEvent": {
          "description": "Customer event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1alpha1CustomerEvent"
        },
        "entitlementEvent": {
          "description": "Entitlement event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1alpha1EntitlementEvent"
        },
        "channelPartnerEvent": {
          "description": "Channel Partner event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerEvent"
        },
        "opportunityEvent": {
          "description": "Opportunity event sent as part of Pub/Sub event to partners/integrators.",
          "$ref": "GoogleCloudChannelV1alpha1OpportunityEvent"
        }
      }
    },
    "GoogleCloudChannelV1alpha1PartnerInfo": {
      "properties": {
        "contractExpiryDate": {
          "$ref": "GoogleTypeDate",
          "description": "Deprecated: This field is no longer used.",
          "deprecated": true
        },
        "subBillingAccountId": {
          "description": "Optional. Cloud Billing subaccount ID. Can be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "extensionsCount": {
          "format": "int32",
          "readOnly": true,
          "description": "Output only. Number of extensions for rebate.",
          "type": "integer"
        },
        "incentiveEligibility": {
          "readOnly": true,
          "description": "Output only. Whether Partner is eligible for incentives for this Opportunity.",
          "type": "boolean"
        },
        "distributor": {
          "description": "Distributor in case of 2-tier deals. Format: partners/{id}. Can be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "submitTime": {
          "description": "Output only. Timestamp when the Opportunity was last submitted.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "approveTime": {
          "format": "google-datetime",
          "description": "Output only. Timestamp when the Opportunity was approved.",
          "type": "string",
          "readOnly": true
        },
        "rebateExpirationDate": {
          "$ref": "GoogleTypeDate",
          "readOnly": true,
          "description": "Output only. Rebate expiration date."
        },
        "incentiveType": {
          "enum": [
            "INCENTIVE_TYPE_UNSPECIFIED",
            "DEAL_REGISTRATION",
            "DEAL_REFERRAL"
          ],
          "readOnly": true,
          "enumDescriptions": [
            "Not used.",
            "Deal Registration incentive.",
            "Deal Referral incentive."
          ],
          "description": "Output only. Incentive type if the Opportunity is eligible for incentive: Deal Registration or Deal Referral.",
          "type": "string"
        },
        "gcpProjectNumbers": {
          "description": "Optional. Google Cloud project numbers. Can be edited after the Opportunity is Accepted. Can only be numeric values.",
          "type": "array",
          "items": {
            "type": "string"
          }
        },
        "partnerViewType": {
          "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."
          ],
          "description": "Output only. Indicates what view the partner has access to.",
          "type": "string",
          "enum": [
            "PARTNER_VIEW_TYPE_UNSPECIFIED",
            "FULL",
            "LIMITED"
          ],
          "readOnly": true
        }
      },
      "id": "GoogleCloudChannelV1alpha1PartnerInfo",
      "description": "Partner Information provided after the Opportunity is Accepted.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest": {
      "properties": {
        "renewalSettings": {
          "description": "Required. New renewal settings.",
          "$ref": "GoogleCloudChannelV1alpha1RenewalSettings"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest",
      "description": "Request message for CloudChannelService.ChangeRenewalSettings.",
      "type": "object"
    },
    "GoogleCloudChannelV1OperationMetadata": {
      "id": "GoogleCloudChannelV1OperationMetadata",
      "description": "Provides contextual information about a google.longrunning.Operation.",
      "type": "object",
      "properties": {
        "operationType": {
          "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"
          ],
          "description": "The RPC that initiated this Long Running Operation.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount": {
      "properties": {
        "customerCloudIdentityId": {
          "description": "If existing = true, the Cloud Identity ID of the customer.",
          "type": "string"
        },
        "existing": {
          "description": "Returns true if a Cloud Identity account exists for a specific domain.",
          "type": "boolean"
        },
        "channelPartnerCloudIdentityId": {
          "description": "If existing = true, and is 2-tier customer, the channel partner of the customer.",
          "type": "string"
        },
        "customerType": {
          "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": "If existing = true, the type of the customer.",
          "type": "string"
        },
        "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"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount",
      "description": "Entity representing a Cloud Identity account that may be associated with a Channel Services API partner.",
      "type": "object"
    },
    "GoogleLongrunningListOperationsResponse": {
      "id": "GoogleLongrunningListOperationsResponse",
      "description": "The response message for Operations.ListOperations.",
      "type": "object",
      "properties": {
        "operations": {
          "items": {
            "$ref": "GoogleLongrunningOperation"
          },
          "description": "A list of operations that matches the specified filter in the request.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "The standard List next-page token.",
          "type": "string"
        },
        "unreachable": {
          "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",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1RunReportJobRequest": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1RunReportJobRequest",
      "description": "Request message for CloudChannelReportsService.RunReportJob.",
      "type": "object",
      "properties": {
        "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"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RepricingCondition": {
      "properties": {
        "skuGroupCondition": {
          "description": "SKU Group condition for override.",
          "$ref": "GoogleCloudChannelV1alpha1SkuGroupCondition"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RepricingCondition",
      "description": "Represents the various repricing conditions you can use for a conditional override.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Value": {
      "id": "GoogleCloudChannelV1alpha1Value",
      "description": "Data type and value of a parameter.",
      "type": "object",
      "properties": {
        "protoValue": {
          "description": "Represents an 'Any' proto value.",
          "type": "object",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "int64Value": {
          "description": "Represents an int64 value.",
          "type": "string",
          "format": "int64"
        },
        "stringValue": {
          "description": "Represents a string value.",
          "type": "string"
        },
        "doubleValue": {
          "description": "Represents a double value.",
          "type": "number",
          "format": "double"
        },
        "boolValue": {
          "description": "Represents a boolean value.",
          "type": "boolean"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListTransferableSkusResponse": {
      "properties": {
        "transferableSkus": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1TransferableSku"
          },
          "description": "Information about existing SKUs for a customer that needs a transfer.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListTransferableSkusRequest.page_token to obtain that page.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListTransferableSkusResponse",
      "description": "Response message for CloudChannelService.ListTransferableSkus.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferableOffer": {
      "id": "GoogleCloudChannelV1alpha1TransferableOffer",
      "description": "TransferableOffer represents an Offer that can be used in Transfer. Read-only.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse": {
      "id": "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse",
      "description": "Response message for CloudChannelService.QueryOpportunities",
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.",
          "type": "string"
        },
        "totalSize": {
          "description": "Total Number of Opportunties for the given filter.",
          "type": "integer",
          "format": "int32"
        },
        "opportunities": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "description": "The opportunities for the specified partner.",
          "type": "array"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerConstraints": {
      "id": "GoogleCloudChannelV1alpha1CustomerConstraints",
      "description": "Represents constraints required to purchase the Offer for a customer.",
      "type": "object",
      "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"
        },
        "promotionalOrderTypes": {
          "description": "Allowed Promotional Order Type. Present for Promotional offers.",
          "type": "array",
          "items": {
            "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"
            ],
            "type": "string"
          }
        },
        "allowedRegions": {
          "description": "Allowed geographical regions of the customer.",
          "type": "array",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1CreateEntitlementRequest": {
      "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"
        },
        "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.",
          "type": "boolean",
          "deprecated": true
        },
        "entitlement": {
          "description": "Required. The entitlement to create.",
          "$ref": "GoogleCloudChannelV1alpha1Entitlement"
        },
        "cloudIdentityInfo": {
          "$ref": "GoogleCloudChannelV1alpha1CloudIdentityInfo",
          "deprecated": true,
          "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."
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1CreateEntitlementRequest",
      "description": "Request message for CloudChannelService.CreateEntitlement",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1PurchasableOffer": {
      "id": "GoogleCloudChannelV1alpha1PurchasableOffer",
      "description": "Offer that you can purchase for a customer. This is used in the ListPurchasableOffer API response.",
      "type": "object",
      "properties": {
        "offer": {
          "description": "Offer.",
          "$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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Column": {
      "id": "GoogleCloudChannelV1alpha1Column",
      "description": "The definition of a report column. Specifies the data properties in the corresponding position of the report rows.",
      "type": "object",
      "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"
        },
        "dataType": {
          "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"
          ],
          "description": "The type of the values for this column.",
          "type": "string"
        },
        "displayName": {
          "description": "The column's display name.",
          "type": "string"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1CustomerInfo": {
      "properties": {
        "customerDetails": {
          "description": "Required. Firm details needed for creating a new customer or for mapping to an existing customer. Available in Limited view.",
          "$ref": "GoogleCloudChannelV1alpha1CustomerDetails"
        },
        "contact": {
          "description": "Optional. Primary Customer contact that will be added to the Opportunity Contact Roles.",
          "$ref": "GoogleCloudChannelV1alpha1Contact"
        },
        "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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1CustomerInfo",
      "description": "Customer Information provided during Opportunity Creation",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1WinLossInfo": {
      "id": "GoogleCloudChannelV1alpha1WinLossInfo",
      "description": "Win Loss Details.",
      "type": "object",
      "properties": {
        "lostReason": {
          "readOnly": true,
          "description": "Output only. Lost reason.",
          "type": "string"
        },
        "winLossAdditionalContext": {
          "readOnly": true,
          "description": "Output only. Win/loss additional context.",
          "type": "string"
        },
        "wonReason": {
          "description": "Output only. Won reason.",
          "type": "string",
          "readOnly": true
        },
        "winMainReason": {
          "description": "Output only. Win main reason.",
          "type": "string",
          "readOnly": true
        },
        "lostRejectedReasonDetails": {
          "readOnly": true,
          "description": "Output only. Lost rejected reason details.",
          "type": "string"
        },
        "winLossProducts": {
          "readOnly": true,
          "items": {
            "type": "string"
          },
          "description": "Output only. Win/loss products.",
          "type": "array"
        },
        "lostMainReason": {
          "description": "Output only. Lost main reason.",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1PercentageAdjustment",
      "description": "An adjustment that applies a flat markup or markdown to an entire bill.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Constraints": {
      "id": "GoogleCloudChannelV1alpha1Constraints",
      "description": "Represents the constraints for buying the Offer.",
      "type": "object",
      "properties": {
        "customerConstraints": {
          "description": "Represents constraints required to purchase the Offer for a customer.",
          "$ref": "GoogleCloudChannelV1alpha1CustomerConstraints"
        }
      }
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsRequest": {
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsRequest",
      "description": "Request message for CloudChannelService.TransferEntitlements.",
      "type": "object",
      "properties": {
        "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"
        },
        "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.",
          "type": "boolean",
          "deprecated": true
        },
        "entitlements": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          },
          "description": "Required. The new entitlements to create or transfer.",
          "type": "array"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1EntitlementEvent": {
      "id": "GoogleCloudChannelV1EntitlementEvent",
      "description": "Represents Pub/Sub message content describing entitlement update.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ChangePlanRequest": {
      "properties": {
        "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"
        },
        "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"
        },
        "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"
        },
        "purchaseOrderId": {
          "description": "Purchase order ID provided by the reseller. Optional",
          "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ChangePlanRequest",
      "description": "Request message for CloudChannelService.ChangePlan.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Plan": {
      "properties": {
        "trialPeriod": {
          "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.",
          "$ref": "GoogleCloudChannelV1alpha1Period"
        },
        "billingAccount": {
          "description": "Reseller Billing account to charge after an offer transaction. Only present for Google Cloud offers.",
          "type": "string"
        },
        "paymentCycle": {
          "description": "Describes how frequently the reseller will be billed, such as once per month.",
          "$ref": "GoogleCloudChannelV1alpha1Period"
        },
        "paymentPlan": {
          "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": "Describes how a reseller will be billed.",
          "type": "string"
        },
        "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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1Plan",
      "description": "The payment plan for the Offer. Describes how to make a payment.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RenewalSettings": {
      "properties": {
        "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"
        },
        "disableCommitment": {
          "deprecated": true,
          "description": "If true, disables commitment-based offer on renewal and switches to flexible or pay as you go. Deprecated: Use `payment_plan` instead.",
          "type": "boolean"
        },
        "paymentPlan": {
          "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": "Describes how a reseller will be billed.",
          "type": "string"
        },
        "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"
        },
        "paymentOption": {
          "deprecated": true,
          "enum": [
            "PAYMENT_OPTION_UNSPECIFIED",
            "ANNUAL",
            "MONTHLY"
          ],
          "description": "Set if enable_renewal=true. Deprecated: Use `payment_cycle` instead.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Paid in yearly installments.",
            "Paid in monthly installments."
          ]
        },
        "enableRenewal": {
          "description": "If false, the plan will be completed at the end date.",
          "type": "boolean"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RenewalSettings",
      "description": "Renewal settings for renewable Offers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse": {
      "id": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse",
      "description": "Response Message for UnregisterSubscriber.",
      "type": "object",
      "properties": {
        "topic": {
          "description": "Name of the topic the service account subscriber access was removed from.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1BillingAccount": {
      "id": "GoogleCloudChannelV1alpha1BillingAccount",
      "description": "Represents a billing account.",
      "type": "object",
      "properties": {
        "name": {
          "readOnly": true,
          "description": "Output only. Resource name of the billing account. Format: accounts/{account_id}/billingAccounts/{billing_account_id}.",
          "type": "string"
        },
        "regionCode": {
          "description": "Output only. The CLDR region code.",
          "type": "string",
          "readOnly": true
        },
        "displayName": {
          "description": "Display name of the billing account.",
          "type": "string"
        },
        "createTime": {
          "readOnly": true,
          "description": "Output only. The time when this billing account was created.",
          "type": "string",
          "format": "google-datetime"
        },
        "currencyCode": {
          "readOnly": true,
          "description": "Output only. The 3-letter currency code defined in ISO 4217.",
          "type": "string"
        }
      }
    },
    "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": {
          "format": "int32",
          "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"
        }
      },
      "id": "GoogleTypeDate",
      "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"
    },
    "GoogleCloudChannelV1alpha1FetchReportResultsRequest": {
      "deprecated": true,
      "properties": {
        "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"
          }
        },
        "pageSize": {
          "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",
          "format": "int32"
        }
      },
      "id": "GoogleCloudChannelV1alpha1FetchReportResultsRequest",
      "description": "Request message for CloudChannelReportsService.FetchReportResults.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Opportunity": {
      "id": "GoogleCloudChannelV1alpha1Opportunity",
      "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",
      "properties": {
        "createTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. Timestamp when the Opportunity was created.",
          "type": "string"
        },
        "customerDisplayName": {
          "readOnly": true,
          "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"
        },
        "isvSolutionConnectInfo": {
          "description": "Optional. Optional information that can be provided for ISV deals during Create Opportunity. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo"
        },
        "winLossInfo": {
          "$ref": "GoogleCloudChannelV1alpha1WinLossInfo",
          "readOnly": true,
          "description": "Output only. Information related to the Sales cycle. Present only after the Opportunity is closed. Unset otherwise. Can't be edited."
        },
        "partnerInfo": {
          "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.",
          "$ref": "GoogleCloudChannelV1alpha1PartnerInfo"
        },
        "source": {
          "enumDescriptions": [
            "Not used.",
            "Created by Google sales rep.",
            "Created by Google Business.",
            "Created by Google programmatically.",
            "If the Opportunity was created by Partner."
          ],
          "description": "Output only. Represents if the Opportunity was created by Google or by Partner. Available in Limited view.",
          "type": "string",
          "enum": [
            "SOURCE_UNKNOWN",
            "GOOGLE",
            "GOOGLE_BDR",
            "GOOGLE_PROGRAMMATIC",
            "PARTNER"
          ],
          "readOnly": true
        },
        "stateDescription": {
          "description": "Output only. Contains the reason if the Opportunity was not accepted. Available in Limited view.",
          "type": "string",
          "readOnly": true
        },
        "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"
        },
        "opportunityTeamMembers": {
          "readOnly": true,
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1OpportunityTeamMember"
          },
          "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"
        },
        "owner": {
          "readOnly": true,
          "description": "Output only. Name of the Google FSR who owns the Opportunity. Available in Limited view.",
          "type": "string"
        },
        "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"
        },
        "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",
          "readOnly": true,
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1RebateExtension"
          }
        },
        "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"
        },
        "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"
          ]
        },
        "creatorEmail": {
          "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",
          "readOnly": true
        },
        "opportunityInfo": {
          "description": "Required. Information about the Opportunity provided during deal submission. Required for Creating an Opportunity. Available in Limited view.",
          "$ref": "GoogleCloudChannelV1alpha1OpportunityInfo"
        },
        "updateTime": {
          "format": "google-datetime",
          "description": "Output only. Timestamp when the Opportunity was last updated.",
          "type": "string",
          "readOnly": true
        },
        "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"
          ]
        },
        "qualificationInfo": {
          "description": "Required. Information that will be used to qualify the Opportunity for approval and incentive eligibility. Required for Creating an Opportunity.",
          "$ref": "GoogleCloudChannelV1alpha1QualificationInfo"
        },
        "ownerEmail": {
          "readOnly": true,
          "description": "Output only. Email of the Google FSR who owns the Opportunity. Available in Limited view.",
          "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"
          ]
        },
        "name": {
          "description": "Identifier. Resource name of an Opportunity in the form: opportunities/{opportunity_id}. Available in Limited view.",
          "type": "string"
        },
        "customerContacts": {
          "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",
          "readOnly": true,
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CustomerContact"
          }
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest": {
      "id": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest",
      "description": "Request message for CloudChannelService.ListProvisionableCloudIdentityTypes",
      "type": "object",
      "properties": {
        "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"
        },
        "domain": {
          "description": "Required. The customer's domain.",
          "type": "string"
        }
      }
    },
    "GoogleRpcStatus": {
      "properties": {
        "details": {
          "items": {
            "type": "object",
            "additionalProperties": {
              "type": "any",
              "description": "Properties of the object. Contains field @type with type URL."
            }
          },
          "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.",
          "type": "array"
        },
        "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"
        }
      },
      "id": "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"
    },
    "GoogleCloudChannelV1alpha1ListReportsResponse": {
      "id": "GoogleCloudChannelV1alpha1ListReportsResponse",
      "description": "Response message for CloudChannelReportsService.ListReports.",
      "type": "object",
      "properties": {
        "reports": {
          "description": "The reports available to the partner.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Report"
          }
        },
        "nextPageToken": {
          "description": "Pass this token to FetchReportResultsRequest.page_token to retrieve the next page of results.",
          "type": "string"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ParameterDefinition": {
      "id": "GoogleCloudChannelV1alpha1ParameterDefinition",
      "description": "Parameter's definition. Specifies what parameter is required to use the current Offer to purchase.",
      "type": "object",
      "properties": {
        "maxValue": {
          "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.",
          "$ref": "GoogleCloudChannelV1alpha1Value"
        },
        "name": {
          "description": "Name of the parameter.",
          "type": "string"
        },
        "minValue": {
          "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.",
          "$ref": "GoogleCloudChannelV1alpha1Value"
        },
        "optional": {
          "description": "If set to true, parameter is optional to purchase this Offer.",
          "type": "boolean"
        },
        "parameterType": {
          "enumDescriptions": [
            "Not used.",
            "Int64 type.",
            "String type.",
            "Double type.",
            "Boolean type."
          ],
          "enum": [
            "PARAMETER_TYPE_UNSPECIFIED",
            "INT64",
            "STRING",
            "DOUBLE",
            "BOOLEAN"
          ],
          "description": "Data type of the parameter. Minimal value, Maximum value and allowed values will use specified data type here.",
          "type": "string"
        },
        "allowedValues": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Value"
          },
          "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse": {
      "id": "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse",
      "description": "Response message for CloudChannelService.ListEntitlementChanges",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest": {
      "id": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest",
      "description": "Request Message for UnregisterSubscriber.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RepricingConfig": {
      "properties": {
        "effectiveInvoiceMonth": {
          "description": "Required. The YearMonth when these adjustments activate. The Day field needs to be \"0\" since we only accept YearMonth repricing boundaries.",
          "$ref": "GoogleTypeDate"
        },
        "rebillingBasis": {
          "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": "Required. The RebillingBasis to use for this bill. Specifies the relative cost based on repricing costs you will apply.",
          "type": "string"
        },
        "conditionalOverrides": {
          "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",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ConditionalOverride"
          }
        },
        "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"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RepricingConfig",
      "description": "Configuration for repricing a Google bill over a period of time.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Media": {
      "properties": {
        "content": {
          "description": "URL of the media.",
          "type": "string"
        },
        "title": {
          "description": "Title 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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1Media",
      "description": "Represents media information.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferEligibility": {
      "properties": {
        "description": {
          "description": "Localized description if reseller is not eligible to transfer the SKU.",
          "type": "string"
        },
        "isEligible": {
          "description": "Whether reseller is eligible to transfer the SKU.",
          "type": "boolean"
        },
        "ineligibilityReason": {
          "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"
          ],
          "description": "Specified the reason for ineligibility.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1TransferEligibility",
      "description": "Specifies transfer eligibility of a SKU.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse": {
      "properties": {
        "customerRepricingConfigs": {
          "description": "The repricing configs for this channel partner.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListCustomerRepricingConfigsRequest.page_token to obtain that page.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse",
      "description": "Response message for CloudChannelService.ListCustomerRepricingConfigs.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1FetchReportResultsResponse": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1FetchReportResultsResponse",
      "description": "Response message for CloudChannelReportsService.FetchReportResults. Contains a tabular representation of the report results.",
      "type": "object",
      "properties": {
        "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"
          }
        },
        "nextPageToken": {
          "description": "Pass this token to FetchReportResultsRequest.page_token to retrieve the next page of results.",
          "type": "string"
        },
        "reportMetadata": {
          "description": "The metadata for the report results (display name, columns, row count, and date ranges).",
          "$ref": "GoogleCloudChannelV1alpha1ReportResultsMetadata"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerContact": {
      "id": "GoogleCloudChannelV1alpha1CustomerContact",
      "description": "Customer Contact.",
      "type": "object",
      "properties": {
        "givenName": {
          "readOnly": true,
          "description": "Output only. Contact First Name.",
          "type": "string"
        },
        "familyName": {
          "description": "Output only. Contact Last Name.",
          "type": "string",
          "readOnly": true
        },
        "role": {
          "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."
          ],
          "description": "Output only. Contact Role.",
          "type": "string",
          "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
        },
        "title": {
          "readOnly": true,
          "description": "Output only. Contact Title.",
          "type": "string"
        },
        "primary": {
          "description": "Output only. Is Primary contact for this Opportunity?",
          "type": "boolean",
          "readOnly": true
        }
      }
    },
    "GoogleTypeMoney": {
      "properties": {
        "units": {
          "description": "The whole units of the amount. For example if `currencyCode` is `\"USD\"`, then 1 unit is one US dollar.",
          "type": "string",
          "format": "int64"
        },
        "currencyCode": {
          "description": "The three-letter currency code defined in ISO 4217.",
          "type": "string"
        },
        "nanos": {
          "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",
          "format": "int32"
        }
      },
      "id": "GoogleTypeMoney",
      "description": "Represents an amount of money with its currency type.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CustomerEvent": {
      "id": "GoogleCloudChannelV1alpha1CustomerEvent",
      "description": "Represents Pub/Sub message content describing customer update.",
      "type": "object",
      "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"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1PricePhase": {
      "id": "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",
      "properties": {
        "priceTiers": {
          "description": "Price by the resource tiers.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PriceTier"
          }
        },
        "firstPeriod": {
          "description": "Defines first period for the phase.",
          "type": "integer",
          "format": "int32"
        },
        "price": {
          "description": "Price of the phase. Present if there are no price tiers.",
          "$ref": "GoogleCloudChannelV1alpha1Price"
        },
        "periodType": {
          "description": "Defines the phase period type.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Day.",
            "Month.",
            "Year."
          ],
          "enum": [
            "PERIOD_TYPE_UNSPECIFIED",
            "DAY",
            "MONTH",
            "YEAR"
          ]
        },
        "lastPeriod": {
          "format": "int32",
          "description": "Defines first period for the phase.",
          "type": "integer"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Product": {
      "id": "GoogleCloudChannelV1alpha1Product",
      "description": "A Product is the entity a customer uses when placing an order. For example, Google Workspace, Google Voice, etc.",
      "type": "object",
      "properties": {
        "name": {
          "description": "Resource Name of the Product. Format: products/{product_id}",
          "type": "string"
        },
        "marketingInfo": {
          "description": "Marketing information for the product.",
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RunReportJobResponse": {
      "properties": {
        "reportJob": {
          "description": "Pass `report_job.name` to FetchReportResultsRequest.report_job to retrieve the report's results.",
          "$ref": "GoogleCloudChannelV1alpha1ReportJob"
        },
        "reportMetadata": {
          "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.",
          "$ref": "GoogleCloudChannelV1alpha1ReportResultsMetadata"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RunReportJobResponse",
      "description": "Response message for CloudChannelReportsService.RunReportJob.",
      "type": "object",
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1RepricingConfigChannelPartnerGranularity": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1RepricingConfigChannelPartnerGranularity",
      "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",
      "properties": {}
    },
    "GoogleCloudChannelV1Column": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1Column",
      "description": "The definition of a report column. Specifies the data properties in the corresponding position of the report rows.",
      "type": "object",
      "properties": {
        "displayName": {
          "description": "The column's display name.",
          "type": "string"
        },
        "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"
        },
        "dataType": {
          "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"
          ],
          "description": "The type of the values for this column.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SkuGroup": {
      "id": "GoogleCloudChannelV1alpha1SkuGroup",
      "description": "Represents the SKU group information.",
      "type": "object",
      "properties": {
        "name": {
          "description": "Resource name of SKU group. Format: accounts/{account}/skuGroups/{sku_group}. Example: \"accounts/C01234/skuGroups/3d50fd57-3157-4577-a5a9-a219b8490041\".",
          "type": "string"
        },
        "displayName": {
          "description": "Unique human readable identifier for the SKU group.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CancelEntitlementRequest": {
      "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1CancelEntitlementRequest",
      "description": "Request message for CloudChannelService.CancelEntitlement.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest": {
      "properties": {
        "entitlements": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Entitlement"
          },
          "description": "Required. The entitlements to transfer to Google.",
          "type": "array"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest",
      "description": "Request message for CloudChannelService.TransferEntitlementsToGoogle.",
      "type": "object"
    },
    "GoogleCloudChannelV1RunReportJobResponse": {
      "properties": {
        "reportJob": {
          "description": "Pass `report_job.name` to FetchReportResultsRequest.report_job to retrieve the report's results.",
          "$ref": "GoogleCloudChannelV1ReportJob"
        },
        "reportMetadata": {
          "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.",
          "$ref": "GoogleCloudChannelV1ReportResultsMetadata"
        }
      },
      "id": "GoogleCloudChannelV1RunReportJobResponse",
      "description": "Response message for CloudChannelReportsService.RunReportJob.",
      "type": "object",
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ListProductsResponse": {
      "properties": {
        "products": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Product"
          },
          "description": "List of Products requested.",
          "type": "array"
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListProductsResponse",
      "description": "Response message for ListProducts.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo": {
      "properties": {
        "supportLevel": {
          "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"
          ],
          "description": "Support Level. Can't be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "contractVehicle": {
          "enumDescriptions": [
            "Not used.",
            "Google Cloud Marketplace.",
            "Partner contract.",
            "Not known at this time."
          ],
          "enum": [
            "CONTRACT_VEHICLE_UNSPECIFIED",
            "CLOUD_MARKETPLACE",
            "PARTNER_CONTRACT",
            "UNKNOWN"
          ],
          "description": "Contract Vehicle. Can't be edited after the Opportunity is Accepted.",
          "type": "string"
        },
        "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"
        },
        "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"
        },
        "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"
        },
        "isvSolutionConnectDeal": {
          "description": "Is the deal an ISV solution connect deal? Can't be edited after the Opportunity is Accepted. Default: false.",
          "type": "boolean"
        },
        "deliveryModel": {
          "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"
          ],
          "description": "Delivery Model. Can't be edited after the Opportunity is Accepted.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1IsvSolutionConnectInfo",
      "description": "Information about a ISV Solution Connect Deal.",
      "type": "object"
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListTransferableOffersResponse",
      "description": "Response message for CloudChannelService.ListTransferableOffers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse": {
      "id": "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse",
      "description": "Response message for ListSkuGroupBillableSkus.",
      "type": "object",
      "properties": {
        "billableSkus": {
          "description": "The list of billable SKUs in the requested SKU group.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1BillableSku"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListSkuGroupBillableSkusRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1ReportJob": {
      "properties": {
        "name": {
          "description": "Required. The resource name of a report job. Name uses the format: `accounts/{account_id}/reportJobs/{report_job_id}`",
          "type": "string"
        },
        "reportStatus": {
          "description": "The current status of report generation.",
          "$ref": "GoogleCloudChannelV1ReportStatus"
        }
      },
      "id": "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",
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ReportStatus": {
      "deprecated": true,
      "id": "GoogleCloudChannelV1alpha1ReportStatus",
      "description": "Status of a report generation process.",
      "type": "object",
      "properties": {
        "startTime": {
          "description": "The report generation's start time.",
          "type": "string",
          "format": "google-datetime"
        },
        "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"
          ]
        },
        "endTime": {
          "format": "google-datetime",
          "description": "The report generation's completion time.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1EduData": {
      "id": "GoogleCloudChannelV1alpha1EduData",
      "description": "Required Edu Attributes",
      "type": "object",
      "properties": {
        "website": {
          "description": "Web address for the edu customer's institution.",
          "type": "string"
        },
        "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"
          ]
        },
        "instituteType": {
          "enumDescriptions": [
            "Not used.",
            "Elementary/Secondary Schools & Districts",
            "Higher Education Universities & Colleges"
          ],
          "enum": [
            "INSTITUTE_TYPE_UNSPECIFIED",
            "K12",
            "UNIVERSITY"
          ],
          "description": "Designated institute type of customer.",
          "type": "string"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1SkuGroupCondition",
      "description": "A condition that applies the override if a line item SKU is found in the SKU group.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo": {
      "id": "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo",
      "description": "Product line information for the Opportunity.",
      "type": "object",
      "properties": {
        "productCategory": {
          "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"
          ],
          "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"
          ],
          "description": "Optional. Product Category for which info is being provided. Required for Non-ISV Opportunities.",
          "type": "string"
        },
        "quantity": {
          "format": "int32",
          "description": "Optional. Number of seats or licenses. Default: 1. Can't be edited after the Opportunity is Accepted.",
          "type": "integer"
        },
        "productFamily": {
          "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 for which info is being provided. Required for ISV Opportunities.",
          "type": "string"
        },
        "dealSize": {
          "description": "Required. Target budget/estimated cost. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleTypeMoney"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListCustomersResponse": {
      "id": "GoogleCloudChannelV1alpha1ListCustomersResponse",
      "description": "Response message for CloudChannelService.ListCustomers.",
      "type": "object",
      "properties": {
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListCustomersRequest.page_token to obtain that page.",
          "type": "string"
        },
        "customers": {
          "description": "The customers belonging to a reseller or distributor.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Customer"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ConditionalOverride": {
      "id": "GoogleCloudChannelV1alpha1ConditionalOverride",
      "description": "Specifies the override to conditionally apply.",
      "type": "object",
      "properties": {
        "repricingCondition": {
          "description": "Required. Specifies the condition which, if met, will apply the override.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingCondition"
        },
        "adjustment": {
          "description": "Required. Information about the applied override's adjustment.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingAdjustment"
        },
        "rebillingBasis": {
          "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": "Required. The RebillingBasis to use for the applied override. Shows the relative cost based on your repricing costs.",
          "type": "string"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1UpdateChannelPartnerLinkRequest",
      "description": "Request message for CloudChannelService.UpdateChannelPartnerLink",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1OpportunityInfo": {
      "id": "GoogleCloudChannelV1alpha1OpportunityInfo",
      "description": "Contains details about the Opportunity.",
      "type": "object",
      "properties": {
        "partnerEntity": {
          "description": "Required. Partner who sources the deal. In case of 2-tier Partners, this is the Distributor id. Format: partners/{id}",
          "type": "string"
        },
        "displayName": {
          "description": "Optional. Display name for the Opportunity. Available in Limited view. Maximum character length: 120.",
          "type": "string"
        },
        "productCategory": {
          "items": {
            "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"
            ],
            "type": "string"
          },
          "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"
        },
        "productFamily": {
          "items": {
            "enumDescriptions": [
              "Not used.",
              "Google Cloud Platform.",
              "Google Workspace.",
              "Maps.",
              "Chrome",
              "PSO"
            ],
            "enum": [
              "PRODUCT_FAMILY_UNSPECIFIED",
              "GOOGLE_CLOUD_PLATFORM",
              "GOOGLE_WORKSPACE",
              "MAPS",
              "CHROME",
              "PSO"
            ],
            "type": "string"
          },
          "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"
        },
        "gcpWatermark": {
          "format": "double",
          "description": "Output only. GCP Watermark.",
          "type": "number",
          "readOnly": true
        },
        "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"
        },
        "indirectPartnerEntity": {
          "description": "Optional. If a 2-tier deal provide the Indirect Reseller involved. Format: partners/{id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityEvent": {
      "id": "GoogleCloudChannelV1alpha1OpportunityEvent",
      "description": "Represents Pub/Sub message content describing opportunity updates.",
      "type": "object",
      "properties": {
        "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"
        },
        "opportunity": {
          "description": "Resource name of the opportunity. Format: opportunities/{opportunity}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest": {
      "properties": {
        "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"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest",
      "description": "Request message for CloudChannelService.AssignChannelPartner.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1PartnerAdvantageInfo": {
      "id": "GoogleCloudChannelV1alpha1PartnerAdvantageInfo",
      "description": "Partner Advantage information for a Channel Partner.",
      "type": "object",
      "properties": {
        "productAuthorization": {
          "description": "A list of this Channel Partner's product authorizations.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ProductAuthorization"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1ActivateEntitlementRequest": {
      "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ActivateEntitlementRequest",
      "description": "Request message for CloudChannelService.ActivateEntitlement.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangeQuantityRequest": {
      "id": "GoogleCloudChannelV1alpha1ChangeQuantityRequest",
      "description": "Request message for CloudChannelService.ChangeQuantityRequest.",
      "type": "object",
      "properties": {
        "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"
        },
        "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"
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order ID provided by the reseller. Optional.",
          "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"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1EntitlementChange": {
      "properties": {
        "provisionedService": {
          "description": "Service provisioned for an Entitlement.",
          "$ref": "GoogleCloudChannelV1alpha1ProvisionedService"
        },
        "otherChangeReason": {
          "description": "e.g. purchase_number change reason, entered by CRS.",
          "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"
          ]
        },
        "entitlement": {
          "description": "Required. Resource name of an entitlement in the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        },
        "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"
          ]
        },
        "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"
          ]
        },
        "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"
          ]
        },
        "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"
          ]
        },
        "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"
        },
        "offer": {
          "description": "Required. Resource name of the Offer at the time of change. Takes the form: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        },
        "createTime": {
          "description": "The submitted time of the change.",
          "type": "string",
          "format": "google-datetime"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1EntitlementChange",
      "description": "Change event entry for Entitlement order history",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1MarketingInfo": {
      "id": "GoogleCloudChannelV1alpha1MarketingInfo",
      "description": "Represents the marketing information for a Product, SKU or Offer.",
      "type": "object",
      "properties": {
        "description": {
          "description": "Human readable description. Description can contain HTML.",
          "type": "string"
        },
        "defaultLogo": {
          "description": "Default logo.",
          "$ref": "GoogleCloudChannelV1alpha1Media"
        },
        "displayName": {
          "description": "Human readable name.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse": {
      "id": "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse",
      "description": "Response message for QueryEligibleBillingAccounts.",
      "type": "object",
      "properties": {
        "skuPurchaseGroups": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1SkuPurchaseGroup"
          },
          "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"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListChannelPartnerLinksResponse",
      "description": "Response message for CloudChannelService.ListChannelPartnerLinks.",
      "type": "object"
    },
    "GoogleCloudChannelV1TrialSettings": {
      "id": "GoogleCloudChannelV1TrialSettings",
      "description": "Settings for trial offers.",
      "type": "object",
      "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": {
          "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",
          "format": "google-datetime"
        }
      }
    },
    "GoogleCloudChannelV1alpha1PurchaseEligibility": {
      "id": "GoogleCloudChannelV1alpha1PurchaseEligibility",
      "description": "Specifies purchase eligibility of a SKU.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1TransferableSku": {
      "properties": {
        "skuId": {
          "description": "The SKU pertaining to the provisioning resource as specified in the Offer. Deprecated: Use `sku.name` instead.",
          "type": "string",
          "deprecated": true
        },
        "purchaseEligibility": {
          "$ref": "GoogleCloudChannelV1alpha1PurchaseEligibility",
          "description": "Describes the purchase eligibility of a SKU. Deprecated: Use `transfer_eligibility` instead.",
          "deprecated": true
        },
        "sku": {
          "description": "The SKU pertaining to the provisioning resource as specified in the Offer.",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        },
        "transferEligibility": {
          "description": "Describes the transfer eligibility of a SKU.",
          "$ref": "GoogleCloudChannelV1alpha1TransferEligibility"
        },
        "productId": {
          "deprecated": true,
          "description": "The product pertaining to the provisioning resource as specified in the Offer. Deprecated: Use `sku.product.name` instead.",
          "type": "string"
        },
        "numUnits": {
          "deprecated": true,
          "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.",
          "type": "integer",
          "format": "int32"
        },
        "maxUnits": {
          "description": "Maximum number of units for a non-commitment-based offer, such as Flexible or Trial. Deprecated: Use `ListTransferableOffers` API instead.",
          "type": "integer",
          "deprecated": true,
          "format": "int32"
        },
        "skuDisplayName": {
          "deprecated": true,
          "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.",
          "type": "string"
        },
        "legacySku": {
          "description": "Optional. The customer to transfer has an entitlement with the populated legacy SKU.",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        },
        "isCommitment": {
          "description": "Whether a transferable SKU is commitment-based or not. Deprecated: Use `ListTransferableOffers` API instead.",
          "type": "boolean",
          "deprecated": true
        },
        "commitmentEndTimestamp": {
          "deprecated": true,
          "description": "Commitment end timestamp. Deprecated: Use `ListTransferableOffers` API instead.",
          "type": "string",
          "format": "google-datetime"
        },
        "assignedUnits": {
          "format": "int32",
          "deprecated": true,
          "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.",
          "type": "integer"
        }
      },
      "id": "GoogleCloudChannelV1alpha1TransferableSku",
      "description": "TransferableSku represents information a reseller needs to view existing provisioned services for a customer that they do not own. Read-only.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSkuGroupsResponse": {
      "properties": {
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListSkuGroupsRequest.page_token to obtain that page.",
          "type": "string"
        },
        "skuGroups": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1SkuGroup"
          },
          "description": "The list of SKU groups requested.",
          "type": "array"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListSkuGroupsResponse",
      "description": "Response message for ListSkuGroups.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ProvisionedService": {
      "id": "GoogleCloudChannelV1alpha1ProvisionedService",
      "description": "Service provisioned for an entitlement.",
      "type": "object",
      "properties": {
        "skuId": {
          "readOnly": true,
          "description": "Output only. The SKU pertaining to the provisioning resource as specified in the Offer.",
          "type": "string"
        },
        "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": {
          "readOnly": true,
          "description": "Output only. The product pertaining to the provisioning resource as specified in the Offer.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1RepricingConfigEntitlementGranularity": {
      "id": "GoogleCloudChannelV1alpha1RepricingConfigEntitlementGranularity",
      "description": "Applies the repricing configuration at the entitlement level.",
      "type": "object",
      "properties": {
        "entitlement": {
          "description": "Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1SalesCycle": {
      "id": "GoogleCloudChannelV1alpha1SalesCycle",
      "description": "Information on the sales cycle.",
      "type": "object",
      "properties": {
        "closeDatePushCount": {
          "format": "int32",
          "readOnly": true,
          "description": "Output only. Number of times close date is pushed/changed.",
          "type": "integer"
        },
        "prmSiteDetails": {
          "readOnly": true,
          "description": "Output only. PRM site details.",
          "type": "string"
        },
        "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"
        },
        "partnerReadyToClose": {
          "enumDescriptions": [
            "Not used.",
            "Stage 4 - Migration or Implementation. Represents Closed/Won stage.",
            "Closed lost."
          ],
          "enum": [
            "PARTNER_CLOSE_STAGE_UNSPECIFIED",
            "MIGRATION_IMPL",
            "CLOSED_LOST"
          ],
          "description": "Partner ready to close info. Can be edited after the Opportunity is Accepted.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityLine": {
      "id": "GoogleCloudChannelV1alpha1OpportunityLine",
      "description": "Opportunity Line item.",
      "type": "object",
      "properties": {
        "quantity": {
          "format": "int32",
          "description": "Output only. Quantity.",
          "type": "integer",
          "readOnly": true
        },
        "totalPrice": {
          "description": "Output only. Total price of the line.",
          "readOnly": true,
          "$ref": "GoogleTypeMoney"
        },
        "listPrice": {
          "description": "Output only. List price.",
          "readOnly": true,
          "$ref": "GoogleTypeMoney"
        },
        "description": {
          "description": "Output only. Line item description.",
          "type": "string",
          "readOnly": true
        },
        "displayName": {
          "description": "Output only. Product display name.",
          "type": "string",
          "readOnly": true
        },
        "salesPrice": {
          "$ref": "GoogleTypeMoney",
          "readOnly": true,
          "description": "Output only. Sales price."
        },
        "metric": {
          "description": "Output only. Unit of measure.",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "GoogleCloudChannelV1DateRange": {
      "deprecated": true,
      "properties": {
        "usageStartDateTime": {
          "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.",
          "$ref": "GoogleTypeDateTime"
        },
        "usageEndDateTime": {
          "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.",
          "$ref": "GoogleTypeDateTime"
        },
        "invoiceStartDate": {
          "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.",
          "$ref": "GoogleTypeDate"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1DateRange",
      "description": "A representation of usage or invoice date ranges.",
      "type": "object"
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistRequest",
      "description": "Request message for CloudChannelService.CheckCloudIdentityAccountsExist.",
      "type": "object"
    },
    "GoogleCloudChannelV1Value": {
      "id": "GoogleCloudChannelV1Value",
      "description": "Data type and value of a parameter.",
      "type": "object",
      "properties": {
        "protoValue": {
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          },
          "description": "Represents an 'Any' proto value.",
          "type": "object"
        },
        "int64Value": {
          "format": "int64",
          "description": "Represents an int64 value.",
          "type": "string"
        },
        "stringValue": {
          "description": "Represents a string value.",
          "type": "string"
        },
        "doubleValue": {
          "description": "Represents a double value.",
          "type": "number",
          "format": "double"
        },
        "boolValue": {
          "description": "Represents a boolean value.",
          "type": "boolean"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ImportCustomerRequest": {
      "id": "GoogleCloudChannelV1alpha1ImportCustomerRequest",
      "description": "Request message for CloudChannelService.ImportCustomer",
      "type": "object",
      "properties": {
        "primaryAdminEmail": {
          "description": "Required. Customer's primary admin email.",
          "type": "string"
        },
        "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"
        },
        "domain": {
          "description": "Required. Customer domain.",
          "type": "string"
        },
        "customer": {
          "description": "Optional. Specifies the customer that will receive imported Cloud Identity information. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "cloudIdentityId": {
          "description": "Required. Customer's Cloud Identity ID",
          "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"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListEntitlementsResponse": {
      "id": "GoogleCloudChannelV1alpha1ListEntitlementsResponse",
      "description": "Response message for CloudChannelService.ListEntitlements.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Sku": {
      "properties": {
        "marketingInfo": {
          "description": "Marketing information for the SKU.",
          "$ref": "GoogleCloudChannelV1alpha1MarketingInfo"
        },
        "product": {
          "description": "Product the SKU is associated with.",
          "$ref": "GoogleCloudChannelV1alpha1Product"
        },
        "name": {
          "description": "Resource Name of the SKU. Format: products/{product_id}/skus/{sku_id}",
          "type": "string"
        }
      },
      "id": "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"
    },
    "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse": {
      "properties": {
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        },
        "purchasableOffers": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PurchasableOffer"
          },
          "description": "The list of Offers requested.",
          "type": "array"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse",
      "description": "Response message for ListPurchasableOffers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChangeSkuRequest": {
      "id": "GoogleCloudChannelV1alpha1ChangeSkuRequest",
      "description": "Request message for CloudChannelService.ChangeSku.",
      "type": "object",
      "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"
        },
        "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"
        },
        "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"
        },
        "purchaseOrderId": {
          "description": "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"
        },
        "offer": {
          "description": "Required. New Offer applicable to a new SKU. The offer takes the form: accounts/{account_id}/offers/{offer_id}.",
          "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"
        }
      }
    },
    "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ProvisionCloudIdentityRequest",
      "description": "Request message for CloudChannelService.ProvisionCloudIdentity",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListOffersResponse": {
      "id": "GoogleCloudChannelV1alpha1ListOffersResponse",
      "description": "Response message for ListOffers.",
      "type": "object",
      "properties": {
        "offers": {
          "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",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Offer"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1Report": {
      "deprecated": true,
      "properties": {
        "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"
        },
        "description": {
          "description": "A description of other aspects of the report, such as the products it supports.",
          "type": "string"
        },
        "displayName": {
          "description": "A human-readable name for this report.",
          "type": "string"
        },
        "columns": {
          "description": "The list of columns included in the report. This defines the schema of the report results.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1Column"
          }
        }
      },
      "id": "GoogleCloudChannelV1Report",
      "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"
    },
    "GoogleCloudChannelV1alpha1AdminUser": {
      "properties": {
        "familyName": {
          "description": "Family name of the admin user.",
          "type": "string"
        },
        "email": {
          "description": "Primary email of the admin user.",
          "type": "string"
        },
        "givenName": {
          "description": "Given name of the admin user.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1AdminUser",
      "description": "Information needed to create an Admin User for Google Workspace.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse": {
      "id": "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse",
      "description": "Response message for CloudChannelService.ListChannelPartnerRepricingConfigs.",
      "type": "object",
      "properties": {
        "channelPartnerRepricingConfigs": {
          "description": "The repricing configs for this channel partner.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
          }
        },
        "nextPageToken": {
          "description": "A token to retrieve the next page of results. Pass to ListChannelPartnerRepricingConfigsRequest.page_token to obtain that page.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse": {
      "id": "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse",
      "description": "Response message for ListPurchasableSkus.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1PurchasableSku": {
      "id": "GoogleCloudChannelV1alpha1PurchasableSku",
      "description": "SKU that you can purchase. This is used in ListPurchasableSku API response.",
      "type": "object",
      "properties": {
        "sku": {
          "description": "SKU",
          "$ref": "GoogleCloudChannelV1alpha1Sku"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ReportResultsMetadata": {
      "id": "GoogleCloudChannelV1alpha1ReportResultsMetadata",
      "description": "The features describing the data. Returned by CloudChannelReportsService.RunReportJob and CloudChannelReportsService.FetchReportResults.",
      "type": "object",
      "properties": {
        "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"
        },
        "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"
        },
        "report": {
          "description": "Details of the completed report.",
          "$ref": "GoogleCloudChannelV1alpha1Report"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ChangeOfferRequest": {
      "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"
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order id provided by the reseller.",
          "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"
        },
        "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"
        },
        "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"
        },
        "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": "Required. New Offer. Format: accounts/{account_id}/offers/{offer_id}.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ChangeOfferRequest",
      "description": "Request message for CloudChannelService.ChangeOffer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1StartPaidServiceRequest": {
      "id": "GoogleCloudChannelV1alpha1StartPaidServiceRequest",
      "description": "Request message for CloudChannelService.StartPaidService.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1BillableSku": {
      "id": "GoogleCloudChannelV1alpha1BillableSku",
      "description": "Represents the Billable SKU information.",
      "type": "object",
      "properties": {
        "service": {
          "description": "Resource name of Service which contains Repricing SKU. Format: services/{service}. Example: \"services/B7D9-FDCB-15D8\".",
          "type": "string"
        },
        "serviceDisplayName": {
          "description": "Unique human readable name for the Service.",
          "type": "string"
        },
        "sku": {
          "description": "Resource name of Billable SKU. Format: billableSkus/{sku}. Example: billableSkus/6E1B-6634-470F\".",
          "type": "string"
        },
        "skuDisplayName": {
          "description": "Unique human readable name for the SKU.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerDetails": {
      "properties": {
        "domain": {
          "description": "Required. Customer's primary website domain. Available in Limited view.",
          "type": "string"
        },
        "organizationName": {
          "description": "Required. Name of the Customer Organization. Available in Limited view.",
          "type": "string"
        },
        "employeeCount": {
          "description": "Required. Workforce size.",
          "type": "integer",
          "format": "int32"
        },
        "address": {
          "description": "Required. Customer address.",
          "$ref": "GoogleTypePostalAddress"
        },
        "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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1CustomerDetails",
      "description": "Customer details used to create a new customer or map to existing customers.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1PriceByResource": {
      "id": "GoogleCloudChannelV1alpha1PriceByResource",
      "description": "Represents price by resource type.",
      "type": "object",
      "properties": {
        "price": {
          "description": "Price of the Offer. Present if there are no price phases.",
          "$ref": "GoogleCloudChannelV1alpha1Price"
        },
        "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"
          ]
        },
        "pricePhases": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1PricePhase"
          },
          "description": "Specifies the price by time range.",
          "type": "array"
        }
      }
    },
    "GoogleCloudChannelV1alpha1ReportJob": {
      "properties": {
        "reportStatus": {
          "description": "The current status of report generation.",
          "$ref": "GoogleCloudChannelV1alpha1ReportStatus"
        },
        "name": {
          "description": "Required. The resource name of a report job. Name uses the format: `accounts/{account_id}/reportJobs/{report_job_id}`",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ReportJob",
      "description": "The result of a RunReportJob operation. Contains the name to use in FetchReportResultsRequest.report_job and the status of the operation.",
      "type": "object",
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ListTransferableOffersRequest": {
      "properties": {
        "customerName": {
          "description": "A reseller should create a customer and use the resource name of that customer here.",
          "type": "string"
        },
        "cloudIdentityId": {
          "description": "Customer's Cloud Identity ID",
          "type": "string"
        },
        "sku": {
          "description": "Required. The SKU to look up Offers for.",
          "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"
        },
        "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"
        },
        "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"
        },
        "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"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListTransferableOffersRequest",
      "description": "Request message for CloudChannelService.ListTransferableOffers",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig": {
      "properties": {
        "name": {
          "description": "Output only. Resource name of the ChannelPartnerRepricingConfig. Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
          "type": "string",
          "readOnly": true
        },
        "updateTime": {
          "readOnly": true,
          "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",
          "format": "google-datetime"
        },
        "repricingConfig": {
          "description": "Required. The configuration for bill modifications made by a reseller before sending it to ChannelPartner.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfig"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig",
      "description": "Configuration for how a distributor will rebill a channel partner (also known as a distributor-authorized reseller).",
      "type": "object"
    },
    "GoogleCloudChannelV1CommitmentSettings": {
      "properties": {
        "endTime": {
          "description": "Output only. Commitment end timestamp.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        },
        "renewalSettings": {
          "description": "Optional. Renewal settings applicable for a commitment-based Offer.",
          "$ref": "GoogleCloudChannelV1RenewalSettings"
        },
        "startTime": {
          "format": "google-datetime",
          "description": "Output only. Commitment start timestamp.",
          "type": "string",
          "readOnly": true
        }
      },
      "id": "GoogleCloudChannelV1CommitmentSettings",
      "description": "Commitment settings for commitment-based offers.",
      "type": "object"
    },
    "GoogleTypePostalAddress": {
      "id": "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",
      "properties": {
        "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"
        },
        "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"
        },
        "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"
        },
        "organization": {
          "description": "Optional. The name of the organization at the address.",
          "type": "string"
        },
        "addressLines": {
          "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",
          "items": {
            "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"
        },
        "sublocality": {
          "description": "Optional. Sublocality of the address. For example, this can be a neighborhood, borough, or district.",
          "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"
        },
        "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"
        },
        "revision": {
          "format": "int32",
          "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"
        },
        "recipients": {
          "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",
          "items": {
            "type": "string"
          }
        }
      }
    },
    "GoogleCloudChannelV1alpha1PriceTier": {
      "properties": {
        "lastResource": {
          "format": "int32",
          "description": "Last resource for which the tier price applies.",
          "type": "integer"
        },
        "firstResource": {
          "format": "int32",
          "description": "First resource for which the tier price applies.",
          "type": "integer"
        },
        "price": {
          "description": "Price of the tier.",
          "$ref": "GoogleCloudChannelV1alpha1Price"
        }
      },
      "id": "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"
    },
    "GoogleProtobufEmpty": {
      "id": "GoogleProtobufEmpty",
      "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",
      "properties": {}
    },
    "GoogleCloudChannelV1alpha1RepricingAdjustment": {
      "properties": {
        "percentageAdjustment": {
          "description": "Flat markup or markdown on an entire bill.",
          "$ref": "GoogleCloudChannelV1alpha1PercentageAdjustment"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RepricingAdjustment",
      "description": "A type that represents the various adjustments you can apply to a bill.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RegisterSubscriberResponse": {
      "properties": {
        "topic": {
          "description": "Name of the topic the subscriber will listen to.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse",
      "description": "Response Message for RegisterSubscriber.",
      "type": "object"
    },
    "GoogleCloudChannelV1ReportStatus": {
      "id": "GoogleCloudChannelV1ReportStatus",
      "description": "Status of a report generation process.",
      "type": "object",
      "properties": {
        "state": {
          "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"
          ],
          "description": "The current state of the report generation process.",
          "type": "string"
        },
        "endTime": {
          "format": "google-datetime",
          "description": "The report generation's completion time.",
          "type": "string"
        },
        "startTime": {
          "description": "The report generation's start time.",
          "type": "string",
          "format": "google-datetime"
        }
      },
      "deprecated": true
    },
    "GoogleCloudChannelV1alpha1ChangeParametersRequest": {
      "id": "GoogleCloudChannelV1alpha1ChangeParametersRequest",
      "description": "Request message for CloudChannelService.ChangeParameters.",
      "type": "object",
      "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"
          }
        },
        "purchaseOrderId": {
          "description": "Optional. Purchase order ID provided by the reseller.",
          "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"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1Entitlement": {
      "properties": {
        "commitmentSettings": {
          "description": "Commitment settings for a commitment-based Offer. Required for commitment based offers.",
          "$ref": "GoogleCloudChannelV1CommitmentSettings"
        },
        "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"
            ]
          }
        },
        "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"
        },
        "associationInfo": {
          "description": "Association information to other entitlements.",
          "$ref": "GoogleCloudChannelV1AssociationInfo"
        },
        "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"
        },
        "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
        },
        "parameters": {
          "items": {
            "$ref": "GoogleCloudChannelV1Parameter"
          },
          "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": {
          "$ref": "GoogleCloudChannelV1TrialSettings",
          "readOnly": true,
          "description": "Output only. Settings for trial offers."
        },
        "provisionedService": {
          "readOnly": true,
          "description": "Output only. Service provisioning details for the entitlement.",
          "$ref": "GoogleCloudChannelV1ProvisionedService"
        },
        "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": {
          "enumDescriptions": [
            "Not used.",
            "The entitlement is currently active.",
            "The entitlement is currently suspended."
          ],
          "description": "Output only. Current provisioning state of the entitlement.",
          "type": "string",
          "enum": [
            "PROVISIONING_STATE_UNSPECIFIED",
            "ACTIVE",
            "SUSPENDED"
          ],
          "readOnly": true
        },
        "updateTime": {
          "format": "google-datetime",
          "description": "Output only. The time at which the entitlement is updated.",
          "type": "string",
          "readOnly": true
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement.",
          "type": "string"
        },
        "createTime": {
          "description": "Output only. The time at which the entitlement is created.",
          "type": "string",
          "readOnly": true,
          "format": "google-datetime"
        }
      },
      "id": "GoogleCloudChannelV1Entitlement",
      "description": "An entitlement is a representation of a customer's ability to use a service.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1QualificationInfo": {
      "properties": {
        "estimatedCloseDate": {
          "description": "Required. Target deal close date in UTC. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleTypeDate"
        },
        "dealNumber": {
          "readOnly": true,
          "description": "Output only. System generated unique deal identifier.",
          "type": "string"
        },
        "contractLengthMonths": {
          "description": "Required. Contract terms in months. Can't be edited for ISV Opportunity after they are Accepted.",
          "type": "integer",
          "format": "int32"
        },
        "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"
        },
        "dealSize": {
          "description": "Required. Target budget/estimated cost. Can't be edited after the Opportunity is Accepted.",
          "$ref": "GoogleTypeMoney"
        },
        "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"
          ]
        },
        "timeline": {
          "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"
          ],
          "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"
        },
        "decisionPhase": {
          "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"
          ],
          "description": "Required. Decision Phase.",
          "type": "string"
        },
        "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"
        },
        "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"
          ]
        },
        "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"
          ]
        },
        "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"
        },
        "productLineInfo": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1QualificationInfoProductLineInfo"
          },
          "description": "Optional. Product line information for the Opportunity.",
          "type": "array"
        },
        "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"
        },
        "msspDeal": {
          "description": "Optional. Flag to highlight if the partner will also act as MSSP (Managed Security Service Provided).",
          "type": "boolean"
        },
        "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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1QualificationInfo",
      "description": "Qualification information for the Opportunity.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListSkusResponse": {
      "properties": {
        "nextPageToken": {
          "description": "A token to retrieve the next page of results.",
          "type": "string"
        },
        "skus": {
          "description": "The list of SKUs requested.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1Sku"
          }
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListSkusResponse",
      "description": "Response message for ListSkus.",
      "type": "object"
    },
    "GoogleLongrunningOperation": {
      "id": "GoogleLongrunningOperation",
      "description": "This resource represents a long-running operation that is the result of a network API call.",
      "type": "object",
      "properties": {
        "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."
          }
        },
        "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": {
          "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",
          "additionalProperties": {
            "type": "any",
            "description": "Properties of the object. Contains field @type with type URL."
          }
        },
        "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"
        },
        "error": {
          "description": "The error result of the operation in case of failure or cancellation.",
          "$ref": "GoogleRpcStatus"
        }
      }
    },
    "GoogleTypePhoneNumberShortCode": {
      "id": "GoogleTypePhoneNumberShortCode",
      "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",
      "properties": {
        "number": {
          "description": "Required. The short code digits, without a leading plus ('+') or country calling code. For example \"611\".",
          "type": "string"
        },
        "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"
        }
      }
    },
    "GoogleCloudChannelV1ProvisionedService": {
      "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"
        }
      },
      "id": "GoogleCloudChannelV1ProvisionedService",
      "description": "Service provisioned for an entitlement.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1SuspendEntitlementRequest": {
      "id": "GoogleCloudChannelV1alpha1SuspendEntitlementRequest",
      "description": "Request message for CloudChannelService.SuspendEntitlement.",
      "type": "object",
      "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"
        }
      }
    },
    "GoogleCloudChannelV1alpha1Entitlement": {
      "id": "GoogleCloudChannelV1alpha1Entitlement",
      "description": "An entitlement is a representation of a customer's ability to use a service.",
      "type": "object",
      "properties": {
        "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.",
          "type": "string",
          "deprecated": true
        },
        "provisioningState": {
          "enumDeprecated": [
            false,
            false,
            true,
            true,
            true,
            false
          ],
          "enum": [
            "PROVISIONING_STATE_UNSPECIFIED",
            "ACTIVE",
            "CANCELED",
            "COMPLETE",
            "PENDING",
            "SUSPENDED"
          ],
          "readOnly": true,
          "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."
          ],
          "description": "Output only. Current provisioning state of the entitlement.",
          "type": "string"
        },
        "maxUnits": {
          "format": "int32",
          "deprecated": true,
          "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.",
          "type": "integer"
        },
        "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"
        },
        "assignedUnits": {
          "format": "int32",
          "deprecated": true,
          "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.",
          "type": "integer"
        },
        "provisionedService": {
          "$ref": "GoogleCloudChannelV1alpha1ProvisionedService",
          "description": "Output only. Service provisioning details for the entitlement.",
          "readOnly": true
        },
        "createTime": {
          "readOnly": true,
          "description": "Output only. The time at which the entitlement is created.",
          "type": "string",
          "format": "google-datetime"
        },
        "billingAccount": {
          "description": "Optional. The billing account resource name that is used to pay for this entitlement.",
          "type": "string"
        },
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "description": "Output only. The time at which the entitlement is updated.",
          "type": "string"
        },
        "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"
            ]
          }
        },
        "numUnits": {
          "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.",
          "type": "integer",
          "deprecated": true,
          "format": "int32"
        },
        "commitmentSettings": {
          "description": "Commitment settings for a commitment-based Offer. Required for commitment based offers.",
          "$ref": "GoogleCloudChannelV1alpha1CommitmentSettings"
        },
        "trialSettings": {
          "readOnly": true,
          "description": "Output only. Settings for trial offers.",
          "$ref": "GoogleCloudChannelV1alpha1TrialSettings"
        },
        "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": "GoogleCloudChannelV1alpha1Parameter"
          }
        },
        "name": {
          "readOnly": true,
          "description": "Output only. Resource name of an entitlement in the form: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_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"
        },
        "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"
        },
        "associationInfo": {
          "description": "Association information to other entitlements.",
          "$ref": "GoogleCloudChannelV1alpha1AssociationInfo"
        }
      }
    },
    "GoogleCloudChannelV1AssociationInfo": {
      "id": "GoogleCloudChannelV1AssociationInfo",
      "description": "Association links that an entitlement has to other entitlements.",
      "type": "object",
      "properties": {
        "baseEntitlement": {
          "description": "The name of the base entitlement, for which this entitlement is an add-on.",
          "type": "string"
        }
      }
    },
    "GoogleCloudChannelV1alpha1OpportunityTeamMember": {
      "id": "GoogleCloudChannelV1alpha1OpportunityTeamMember",
      "description": "Opportunity Team Member.",
      "type": "object",
      "properties": {
        "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"
        },
        "accessLevel": {
          "description": "Output only. Access Level. Available in Limited view.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "View only.",
            "Modify."
          ],
          "readOnly": true,
          "enum": [
            "ACCESS_LEVEL_UNSPECIFIED",
            "VIEW_ONLY",
            "MODIFY"
          ]
        }
      }
    },
    "GoogleCloudChannelV1alpha1CustomerRepricingConfig": {
      "id": "GoogleCloudChannelV1alpha1CustomerRepricingConfig",
      "description": "Configuration for how a reseller will reprice a Customer.",
      "type": "object",
      "properties": {
        "repricingConfig": {
          "description": "Required. The configuration for bill modifications made by a reseller before sending it to customers.",
          "$ref": "GoogleCloudChannelV1alpha1RepricingConfig"
        },
        "updateTime": {
          "format": "google-datetime",
          "readOnly": true,
          "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"
        },
        "name": {
          "description": "Output only. Resource name of the CustomerRepricingConfig. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
          "type": "string",
          "readOnly": true
        }
      }
    },
    "GoogleCloudChannelV1alpha1Price": {
      "properties": {
        "discount": {
          "format": "double",
          "description": "Discount percentage, represented as decimal. For example, a 20% discount will be represent as 0.2.",
          "type": "number"
        },
        "externalPriceUri": {
          "description": "Link to external price list, such as link to Google Voice rate card.",
          "type": "string"
        },
        "basePrice": {
          "description": "Base price.",
          "$ref": "GoogleTypeMoney"
        },
        "pricePeriod": {
          "description": "The time period with respect to which base and effective prices are defined. Example: 1 month, 6 months, 1 year, etc.",
          "$ref": "GoogleCloudChannelV1alpha1Period"
        },
        "effectivePrice": {
          "description": "Effective Price after applying the discounts.",
          "$ref": "GoogleTypeMoney"
        },
        "discountComponents": {
          "description": "Breakdown of the discount into its components. This will be empty if there is no discount present.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1DiscountComponent"
          }
        }
      },
      "id": "GoogleCloudChannelV1alpha1Price",
      "description": "Represents the price of the Offer.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo": {
      "properties": {
        "billingAccount": {
          "description": "The billing account resource.",
          "$ref": "GoogleCloudChannelV1alpha1BillingAccount"
        }
      },
      "id": "GoogleCloudChannelV1alpha1BillingAccountPurchaseInfo",
      "description": "Represents a billing account that can be used to make a purchase.",
      "type": "object"
    },
    "GoogleCloudChannelV1CustomerEvent": {
      "properties": {
        "customer": {
          "description": "Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
          "type": "string"
        },
        "eventType": {
          "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"
          ],
          "description": "Type of event which happened for the customer.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1CustomerEvent",
      "description": "Represents Pub/Sub message content describing customer update.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1AssociationInfo": {
      "properties": {
        "baseEntitlement": {
          "description": "The name of the base entitlement, for which this entitlement is an add-on.",
          "type": "string"
        }
      },
      "id": "GoogleCloudChannelV1alpha1AssociationInfo",
      "description": "Association links that an entitlement has to other entitlements.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1Contact": {
      "properties": {
        "givenName": {
          "description": "Required. Contact's first name.",
          "type": "string"
        },
        "email": {
          "description": "Required. Email.",
          "type": "string"
        },
        "familyName": {
          "description": "Required. Contact's last name.",
          "type": "string"
        },
        "phone": {
          "description": "Optional. Phone number. Only supports setting e164_number.",
          "$ref": "GoogleTypePhoneNumber"
        }
      },
      "id": "GoogleCloudChannelV1alpha1Contact",
      "description": "Contact Details.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse": {
      "properties": {
        "cloudIdentityTypes": {
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1ProvisionableCloudIdentityType"
          },
          "description": "List of cloud identity types and if you can provision them for the domain.",
          "type": "array"
        }
      },
      "id": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse",
      "description": "Response message for CloudChannelService.ListProvisionableCloudIdentityTypes",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1RebateExtension": {
      "properties": {
        "extensionRejectionReason": {
          "readOnly": true,
          "enum": [
            "EXTENSION_REJECTION_REASON_UNSPECIFIED",
            "OTHER_EXTENSION_REJECTION_REASON",
            "LACK_OF_PARTNER_ENGAGEMENT",
            "NEGATIVE_CUSTOMER_FEEDBACK",
            "PPS_REJECTION"
          ],
          "description": "Output only. Extension Rejection Reason.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Lack of Partner Engagement.",
            "Negative Customer Feedback",
            "PPS Rejection."
          ]
        },
        "comments": {
          "readOnly": true,
          "description": "Output only. Comments.",
          "type": "string"
        },
        "requestNumber": {
          "readOnly": true,
          "description": "Output only. Extension Request number.",
          "type": "string"
        },
        "extensionReason": {
          "readOnly": true,
          "enum": [
            "EXTENSION_REASON_UNSPECIFIED",
            "OTHER_EXTENSION_REASON",
            "CUSTOMER_ENGAGEMENT_DELAYED",
            "PROOF_OF_CONCEPT_LONGER_THAN_EXPECTED",
            "COMPLEX_DEAL"
          ],
          "description": "Output only. Extension Reason.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Other.",
            "Customer Engagement Delayed.",
            "Proof of Concept Longer Than Expected.",
            "Complex Deal"
          ]
        },
        "extensionStatus": {
          "readOnly": true,
          "enum": [
            "EXTENSION_STATUS_UNSPECIFIED",
            "SUBMITTED",
            "APPROVED",
            "REJECTED"
          ],
          "description": "Output only. Extension Status.",
          "type": "string",
          "enumDescriptions": [
            "Not used.",
            "Submitted.",
            "Approved.",
            "Rejected."
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1RebateExtension",
      "description": "Rebate Extension.",
      "type": "object"
    },
    "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse": {
      "id": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse",
      "description": "Response message for CloudChannelService.CheckCloudIdentityAccountsExist.",
      "type": "object",
      "properties": {
        "cloudIdentityAccounts": {
          "description": "The Cloud Identity accounts associated with the domain.",
          "type": "array",
          "items": {
            "$ref": "GoogleCloudChannelV1alpha1CloudIdentityCustomerAccount"
          }
        }
      }
    },
    "GoogleCloudChannelV1SubscriberEvent": {
      "properties": {
        "customerEvent": {
          "description": "Customer event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1CustomerEvent"
        },
        "entitlementEvent": {
          "description": "Entitlement event sent as part of Pub/Sub event to partners.",
          "$ref": "GoogleCloudChannelV1EntitlementEvent"
        }
      },
      "id": "GoogleCloudChannelV1SubscriberEvent",
      "description": "Represents information which resellers will get as part of notification from Pub/Sub.",
      "type": "object"
    },
    "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"
          ]
        }
      },
      "id": "GoogleCloudChannelV1alpha1Period",
      "description": "Represents period in days/months/years.",
      "type": "object"
    }
  },
  "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.",
  "version": "v1alpha1",
  "mtlsRootUrl": "https://cloudchannel.mtls.googleapis.com/",
  "version_module": true,
  "name": "cloudchannel",
  "batchPath": "batch",
  "protocol": "rest",
  "resources": {
    "operations": {
      "methods": {
        "list": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [
            "name"
          ],
          "id": "cloudchannel.operations.list",
          "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.",
          "httpMethod": "GET",
          "path": "v1alpha1/{+name}",
          "response": {
            "$ref": "GoogleLongrunningListOperationsResponse"
          },
          "parameters": {
            "returnPartialSuccess": {
              "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",
              "location": "query"
            },
            "pageSize": {
              "format": "int32",
              "location": "query",
              "description": "The standard list page size.",
              "type": "integer"
            },
            "name": {
              "description": "The name of the operation's parent resource.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^operations$"
            },
            "filter": {
              "description": "The standard list filter.",
              "type": "string",
              "location": "query"
            },
            "pageToken": {
              "location": "query",
              "description": "The standard list page token.",
              "type": "string"
            }
          },
          "flatPath": "v1alpha1/operations"
        },
        "cancel": {
          "flatPath": "v1alpha1/operations/{operationsId}:cancel",
          "path": "v1alpha1/{+name}:cancel",
          "response": {
            "$ref": "GoogleProtobufEmpty"
          },
          "parameters": {
            "name": {
              "location": "path",
              "required": true,
              "description": "The name of the operation resource to be cancelled.",
              "type": "string",
              "pattern": "^operations/.*$"
            }
          },
          "parameterOrder": [
            "name"
          ],
          "id": "cloudchannel.operations.cancel",
          "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`.",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "get": {
          "response": {
            "$ref": "GoogleLongrunningOperation"
          },
          "path": "v1alpha1/{+name}",
          "parameters": {
            "name": {
              "location": "path",
              "required": true,
              "description": "The name of the operation resource.",
              "type": "string",
              "pattern": "^operations/[^/]+$"
            }
          },
          "flatPath": "v1alpha1/operations/{operationsId}",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "id": "cloudchannel.operations.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.",
          "parameterOrder": [
            "name"
          ],
          "httpMethod": "GET"
        },
        "delete": {
          "path": "v1alpha1/{+name}",
          "response": {
            "$ref": "GoogleProtobufEmpty"
          },
          "parameters": {
            "name": {
              "pattern": "^operations/.*$",
              "description": "The name of the operation resource to be deleted.",
              "type": "string",
              "location": "path",
              "required": true
            }
          },
          "flatPath": "v1alpha1/operations/{operationsId}",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [
            "name"
          ],
          "id": "cloudchannel.operations.delete",
          "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`.",
          "httpMethod": "DELETE"
        }
      }
    },
    "accounts": {
      "methods": {
        "listTransferableOffers": {
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableOffersRequest"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:listTransferableOffers",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableOffersResponse"
          },
          "path": "v1alpha1/{+parent}:listTransferableOffers",
          "parameters": {
            "parent": {
              "description": "Required. The resource name of the reseller's account.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^accounts/[^/]+$"
            }
          },
          "id": "cloudchannel.accounts.listTransferableOffers",
          "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.",
          "parameterOrder": [
            "parent"
          ],
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "checkCloudIdentityAccountsExist": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [
            "parent"
          ],
          "id": "cloudchannel.accounts.checkCloudIdentityAccountsExist",
          "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.",
          "httpMethod": "POST",
          "path": "v1alpha1/{+parent}:checkCloudIdentityAccountsExist",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistResponse"
          },
          "parameters": {
            "parent": {
              "description": "Required. The reseller account's resource name. Parent uses the format: accounts/{account_id}",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^accounts/[^/]+$"
            }
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1CheckCloudIdentityAccountsExistRequest"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:checkCloudIdentityAccountsExist"
        },
        "listSubscribers": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "httpMethod": "GET",
          "parameterOrder": [
            "account"
          ],
          "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.",
          "parameters": {
            "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/[^/]+$",
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "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"
            },
            "pageSize": {
              "format": "int32",
              "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"
            }
          },
          "path": "v1alpha1/{+account}:listSubscribers",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListSubscribersResponse"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:listSubscribers"
        },
        "listProvisionableCloudIdentityTypes": {
          "parameters": {
            "parent": {
              "pattern": "^accounts/[^/]+$",
              "description": "Required. The resource name of the reseller's account. Parent uses the format: accounts/{account_id}",
              "type": "string",
              "location": "path",
              "required": true
            }
          },
          "path": "v1alpha1/{+parent}:listProvisionableCloudIdentityTypes",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesResponse"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:listProvisionableCloudIdentityTypes",
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListProvisionableCloudIdentityTypesRequest"
          },
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "httpMethod": "POST",
          "parameterOrder": [
            "parent"
          ],
          "id": "cloudchannel.accounts.listProvisionableCloudIdentityTypes",
          "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."
        },
        "unregister": {
          "parameterOrder": [
            "account"
          ],
          "id": "cloudchannel.accounts.unregister",
          "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.",
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:unregister",
          "path": "v1alpha1/{+account}:unregister",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse"
          },
          "parameters": {
            "account": {
              "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",
              "required": true
            }
          }
        },
        "listTransferableSkus": {
          "flatPath": "v1alpha1/accounts/{accountsId}:listTransferableSkus",
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableSkusRequest"
          },
          "parameters": {
            "parent": {
              "description": "Required. The reseller account's resource name. Parent uses the format: accounts/{account_id}",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^accounts/[^/]+$"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListTransferableSkusResponse"
          },
          "path": "v1alpha1/{+parent}:listTransferableSkus",
          "httpMethod": "POST",
          "id": "cloudchannel.accounts.listTransferableSkus",
          "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.",
          "parameterOrder": [
            "parent"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "register": {
          "path": "v1alpha1/{+account}:register",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse"
          },
          "parameters": {
            "account": {
              "location": "path",
              "required": true,
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "pattern": "^accounts/[^/]+$"
            }
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest"
          },
          "flatPath": "v1alpha1/accounts/{accountsId}:register",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [
            "account"
          ],
          "id": "cloudchannel.accounts.register",
          "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"
        }
      },
      "resources": {
        "customers": {
          "methods": {
            "listPurchasableOffers": {
              "parameters": {
                "changeOfferPurchase.entitlement": {
                  "location": "query",
                  "description": "Required. Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                  "type": "string"
                },
                "changeOfferPurchase.dealCode": {
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "type": "string",
                  "location": "query"
                },
                "pageSize": {
                  "location": "query",
                  "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",
                  "format": "int32"
                },
                "createEntitlementPurchase.dealCode": {
                  "location": "query",
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "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"
                },
                "createEntitlementPurchase.sku": {
                  "location": "query",
                  "description": "Required. SKU that the result should be restricted to. Format: products/{product_id}/skus/{sku_id}.",
                  "type": "string"
                },
                "customer": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the customer to list Offers for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string"
                },
                "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"
                },
                "changeOfferPurchase.billingAccount": {
                  "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",
                  "location": "query"
                },
                "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"
                },
                "pageToken": {
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string",
                  "location": "query"
                }
              },
              "path": "v1alpha1/{+customer}:listPurchasableOffers",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListPurchasableOffersResponse"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:listPurchasableOffers",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "GET",
              "parameterOrder": [
                "customer"
              ],
              "id": "cloudchannel.accounts.customers.listPurchasableOffers",
              "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."
            },
            "provisionCloudIdentity": {
              "path": "v1alpha1/{+customer}:provisionCloudIdentity",
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "parameters": {
                "customer": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Required. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ProvisionCloudIdentityRequest"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:provisionCloudIdentity",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "parameterOrder": [
                "customer"
              ],
              "id": "cloudchannel.accounts.customers.provisionCloudIdentity",
              "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.",
              "httpMethod": "POST"
            },
            "get": {
              "id": "cloudchannel.accounts.customers.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.",
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the customer to retrieve. Name uses the format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string"
                }
              }
            },
            "transferEntitlements": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.customers.transferEntitlements",
              "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.",
              "parameterOrder": [
                "parent"
              ],
              "parameters": {
                "parent": {
                  "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",
                  "required": true,
                  "pattern": "^accounts/[^/]+/customers/[^/]+$"
                }
              },
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "path": "v1alpha1/{+parent}:transferEntitlements",
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:transferEntitlements",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1TransferEntitlementsRequest"
              }
            },
            "listPurchasableSkus": {
              "httpMethod": "GET",
              "parameterOrder": [
                "customer"
              ],
              "id": "cloudchannel.accounts.customers.listPurchasableSkus",
              "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"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:listPurchasableSkus",
              "parameters": {
                "customer": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Required. The resource name of the customer to list SKUs for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "pageToken": {
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string",
                  "location": "query"
                },
                "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"
                },
                "changeOfferPurchase.changeType": {
                  "enum": [
                    "CHANGE_TYPE_UNSPECIFIED",
                    "UPGRADE",
                    "DOWNGRADE"
                  ],
                  "description": "Required. Change Type for the entitlement.",
                  "type": "string",
                  "location": "query",
                  "enumDescriptions": [
                    "Not used.",
                    "SKU is an upgrade on the current entitlement.",
                    "SKU is a downgrade on the current entitlement."
                  ]
                },
                "pageSize": {
                  "location": "query",
                  "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",
                  "format": "int32"
                },
                "languageCode": {
                  "location": "query",
                  "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"
                },
                "changeOfferPurchase.entitlement": {
                  "description": "Required. Resource name of the entitlement. Format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                  "type": "string",
                  "location": "query"
                }
              },
              "path": "v1alpha1/{+customer}:listPurchasableSkus",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListPurchasableSkusResponse"
              }
            },
            "create": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "POST",
              "parameterOrder": [
                "parent"
              ],
              "id": "cloudchannel.accounts.customers.create",
              "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.",
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "description": "Required. The resource name of reseller account in which to create the customer. Parent uses the format: accounts/{account_id}",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "path": "v1alpha1/{+parent}/customers",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              }
            },
            "import": {
              "parameterOrder": [
                "parent"
              ],
              "id": "cloudchannel.accounts.customers.import",
              "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",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ImportCustomerRequest"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers:import",
              "path": "v1alpha1/{+parent}/customers:import",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "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/[^/]+$"
                }
              }
            },
            "transferEntitlementsToGoogle": {
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:transferEntitlementsToGoogle",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1TransferEntitlementsToGoogleRequest"
              },
              "parameters": {
                "parent": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "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",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "path": "v1alpha1/{+parent}:transferEntitlementsToGoogle",
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.customers.transferEntitlementsToGoogle",
              "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.",
              "parameterOrder": [
                "parent"
              ],
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            },
            "patch": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "parameterOrder": [
                "name"
              ],
              "id": "cloudchannel.accounts.customers.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.",
              "httpMethod": "PATCH",
              "path": "v1alpha1/{+name}",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string"
                },
                "name1": {
                  "description": "Deprecated: Set Customer.name instead Name uses the format: accounts/{account_id}/customers/{customer_id}",
                  "type": "string",
                  "location": "query",
                  "deprecated": true
                },
                "updateMask": {
                  "location": "query",
                  "description": "The update mask that applies to the resource. Optional.",
                  "type": "string",
                  "format": "google-fieldmask"
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1Customer"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}"
            },
            "list": {
              "flatPath": "v1alpha1/accounts/{accountsId}/customers",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListCustomersResponse"
              },
              "path": "v1alpha1/{+parent}/customers",
              "parameters": {
                "parent": {
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the reseller account to list customers from. Parent uses the format: accounts/{account_id}.",
                  "type": "string",
                  "pattern": "^accounts/[^/]+$"
                },
                "pageSize": {
                  "location": "query",
                  "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",
                  "format": "int32"
                },
                "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"
                },
                "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"
                }
              },
              "id": "cloudchannel.accounts.customers.list",
              "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"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            },
            "queryEligibleBillingAccounts": {
              "path": "v1alpha1/{+customer}:queryEligibleBillingAccounts",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1QueryEligibleBillingAccountsResponse"
              },
              "parameters": {
                "skus": {
                  "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",
                  "location": "query",
                  "repeated": true
                },
                "customer": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the customer to list eligible billing accounts for. Format: accounts/{account_id}/customers/{customer_id}.",
                  "type": "string"
                }
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}:queryEligibleBillingAccounts",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "parameterOrder": [
                "customer"
              ],
              "id": "cloudchannel.accounts.customers.queryEligibleBillingAccounts",
              "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.",
              "httpMethod": "GET"
            },
            "delete": {
              "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}",
              "path": "v1alpha1/{+name}",
              "response": {
                "$ref": "GoogleProtobufEmpty"
              },
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/customers/[^/]+$",
                  "description": "Required. The resource name of the customer to delete.",
                  "type": "string",
                  "location": "path",
                  "required": true
                }
              },
              "parameterOrder": [
                "name"
              ],
              "id": "cloudchannel.accounts.customers.delete",
              "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",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ]
            }
          },
          "resources": {
            "customerRepricingConfigs": {
              "methods": {
                "patch": {
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "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",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "PATCH"
                },
                "list": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.list",
                  "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.",
                  "httpMethod": "GET",
                  "path": "v1alpha1/{+parent}/customerRepricingConfigs",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListCustomerRepricingConfigsResponse"
                  },
                  "parameters": {
                    "pageToken": {
                      "location": "query",
                      "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"
                    },
                    "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"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/customers/[^/]+$"
                    },
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "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"
                    }
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs"
                },
                "get": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "path": "v1alpha1/{+name}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The resource name of the CustomerRepricingConfig. Format: accounts/{account_id}/customers/{customer_id}/customerRepricingConfigs/{id}.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/customerRepricingConfigs/[^/]+$"
                    }
                  },
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.get",
                  "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"
                  ],
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "delete": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.delete",
                  "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.",
                  "httpMethod": "DELETE",
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "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/[^/]+$"
                    }
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs/{customerRepricingConfigsId}"
                },
                "create": {
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/customers/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+parent}/customerRepricingConfigs",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/customerRepricingConfigs",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CustomerRepricingConfig"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "cloudchannel.accounts.customers.customerRepricingConfigs.create",
                  "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."
                }
              }
            },
            "entitlements": {
              "methods": {
                "listEntitlementChanges": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:listEntitlementChanges",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListEntitlementChangesResponse"
                  },
                  "path": "v1alpha1/{+parent}:listEntitlementChanges",
                  "parameters": {
                    "parent": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "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
                    },
                    "pageSize": {
                      "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",
                      "location": "query"
                    },
                    "pageToken": {
                      "location": "query",
                      "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"
                    },
                    "filter": {
                      "location": "query",
                      "description": "Optional. Filters applied to the list results.",
                      "type": "string"
                    }
                  },
                  "id": "cloudchannel.accounts.customers.entitlements.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.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "cancel": {
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CancelEntitlementRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:cancel",
                  "path": "v1alpha1/{+name}:cancel",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "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",
                      "location": "path",
                      "required": true
                    }
                  },
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.cancel",
                  "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.",
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "assignChannelPartner": {
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "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",
                      "location": "path",
                      "required": true
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Entitlement"
                  },
                  "path": "v1alpha1/{+name}:assignChannelPartner",
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:assignChannelPartner",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1AssignChannelPartnerRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.assignChannelPartner",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "activate": {
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ActivateEntitlementRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:activate",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:activate",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    }
                  },
                  "id": "cloudchannel.accounts.customers.entitlements.activate",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "get": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.get",
                  "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.",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Entitlement"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}"
                },
                "changeOffer": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeOffer",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeOfferRequest"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "location": "path",
                      "required": true,
                      "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"
                    }
                  },
                  "path": "v1alpha1/{+name}:changeOffer",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.changeOffer",
                  "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.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "changePlan": {
                  "id": "cloudchannel.accounts.customers.entitlements.changePlan",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangePlanRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changePlan",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:changePlan",
                  "deprecated": true,
                  "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/[^/]+$"
                    }
                  }
                },
                "changeSku": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeSku",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeSkuRequest"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string"
                    }
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:changeSku",
                  "deprecated": true,
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.changeSku",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "suspend": {
                  "id": "cloudchannel.accounts.customers.entitlements.suspend",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1SuspendEntitlementRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:suspend",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:suspend",
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "location": "path",
                      "required": true,
                      "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"
                    }
                  }
                },
                "changeParameters": {
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "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/[^/]+$"
                    }
                  },
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:changeParameters",
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeParameters",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeParametersRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "id": "cloudchannel.accounts.customers.entitlements.changeParameters",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ]
                },
                "lookupOffer": {
                  "path": "v1alpha1/{+entitlement}:lookupOffer",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Offer"
                  },
                  "parameters": {
                    "entitlement": {
                      "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",
                      "required": true,
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$"
                    }
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:lookupOffer",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "entitlement"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.lookupOffer",
                  "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.",
                  "httpMethod": "GET"
                },
                "startPaidService": {
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1StartPaidServiceRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:startPaidService",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:startPaidService",
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "location": "path",
                      "required": true,
                      "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"
                    }
                  },
                  "id": "cloudchannel.accounts.customers.entitlements.startPaidService",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "create": {
                  "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/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+parent}/entitlements",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1CreateEntitlementRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.create",
                  "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."
                },
                "list": {
                  "id": "cloudchannel.accounts.customers.entitlements.list",
                  "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.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListEntitlementsResponse"
                  },
                  "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"
                    },
                    "parent": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+$",
                      "location": "path",
                      "required": true,
                      "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"
                    },
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "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"
                    }
                  }
                },
                "changeQuantity": {
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "name"
                  ],
                  "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"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeQuantity",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeQuantityRequest"
                  },
                  "parameters": {
                    "name": {
                      "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",
                      "required": true
                    }
                  },
                  "path": "v1alpha1/{+name}:changeQuantity",
                  "deprecated": true,
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  }
                },
                "changeRenewalSettings": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "id": "cloudchannel.accounts.customers.entitlements.changeRenewalSettings",
                  "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.",
                  "parameterOrder": [
                    "name"
                  ],
                  "httpMethod": "POST",
                  "response": {
                    "$ref": "GoogleLongrunningOperation"
                  },
                  "path": "v1alpha1/{+name}:changeRenewalSettings",
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/customers/[^/]+/entitlements/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Required. The name of the entitlement to update. Name uses the format: accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id}",
                      "type": "string"
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChangeRenewalSettingsRequest"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/customers/{customersId}/entitlements/{entitlementsId}:changeRenewalSettings"
                }
              }
            }
          }
        },
        "reportJobs": {
          "deprecated": true,
          "methods": {
            "fetchReportResults": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.reports.usage.readonly"
              ],
              "id": "cloudchannel.accounts.reportJobs.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.",
              "parameterOrder": [
                "reportJob"
              ],
              "httpMethod": "POST",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1FetchReportResultsResponse"
              },
              "path": "v1alpha1/{+reportJob}:fetchReportResults",
              "deprecated": true,
              "parameters": {
                "reportJob": {
                  "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",
                  "required": true,
                  "pattern": "^accounts/[^/]+/reportJobs/[^/]+$"
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1FetchReportResultsRequest"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/reportJobs/{reportJobsId}:fetchReportResults"
            }
          }
        },
        "channelPartnerLinks": {
          "methods": {
            "create": {
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "path": "v1alpha1/{+parent}/channelPartnerLinks",
              "parameters": {
                "parent": {
                  "description": "Required. Create a channel partner link for the provided reseller account's resource name. Parent uses the format: accounts/{account_id}",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+$"
                },
                "domain": {
                  "location": "query",
                  "deprecated": true,
                  "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",
                  "type": "string"
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "id": "cloudchannel.accounts.channelPartnerLinks.create",
              "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.",
              "parameterOrder": [
                "parent"
              ],
              "httpMethod": "POST"
            },
            "get": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "parameterOrder": [
                "name"
              ],
              "id": "cloudchannel.accounts.channelPartnerLinks.get",
              "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.",
              "httpMethod": "GET",
              "path": "v1alpha1/{+name}",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "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": {
                  "enum": [
                    "UNSPECIFIED",
                    "BASIC",
                    "FULL"
                  ],
                  "description": "Optional. The level of granularity the ChannelPartnerLink will display.",
                  "type": "string",
                  "location": "query",
                  "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."
                  ]
                }
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}"
            },
            "patch": {
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerLink"
              },
              "path": "v1alpha1/{+name}",
              "parameters": {
                "name": {
                  "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",
                  "required": true,
                  "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                }
              },
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1UpdateChannelPartnerLinkRequest"
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "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.",
              "parameterOrder": [
                "name"
              ],
              "httpMethod": "PATCH"
            },
            "list": {
              "id": "cloudchannel.accounts.channelPartnerLinks.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.",
              "parameterOrder": [
                "parent"
              ],
              "httpMethod": "GET",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListChannelPartnerLinksResponse"
              },
              "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"
                },
                "view": {
                  "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."
                  ],
                  "description": "Optional. The level of granularity the ChannelPartnerLink will display.",
                  "type": "string",
                  "location": "query",
                  "enum": [
                    "UNSPECIFIED",
                    "BASIC",
                    "FULL"
                  ]
                },
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "description": "Required. The resource name of the reseller account for listing channel partner links. Parent uses the format: accounts/{account_id}",
                  "type": "string",
                  "location": "path",
                  "required": true
                },
                "pageSize": {
                  "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",
                  "location": "query"
                }
              }
            }
          },
          "resources": {
            "customers": {
              "methods": {
                "import": {
                  "parameters": {
                    "parent": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$",
                      "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
                    }
                  },
                  "path": "v1alpha1/{+parent}/customers:import",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers:import",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ImportCustomerRequest"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.import",
                  "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."
                },
                "create": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "parameters": {
                    "parent": {
                      "description": "Required. The resource name of reseller account in which to create the customer. Parent uses the format: accounts/{account_id}",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+parent}/customers",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "httpMethod": "POST",
                  "parameterOrder": [
                    "parent"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.create",
                  "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.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "get": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "GET",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.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.",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The resource name of the customer to retrieve. Name uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}"
                },
                "delete": {
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.delete",
                  "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",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}",
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  },
                  "parameters": {
                    "name": {
                      "description": "Required. The resource name of the customer to delete.",
                      "type": "string",
                      "location": "path",
                      "required": true,
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$"
                    }
                  }
                },
                "list": {
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers",
                  "parameters": {
                    "parent": {
                      "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",
                      "required": true
                    },
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "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"
                    },
                    "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"
                    },
                    "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"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListCustomersResponse"
                  },
                  "path": "v1alpha1/{+parent}/customers",
                  "httpMethod": "GET",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.list",
                  "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"
                  ],
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ]
                },
                "patch": {
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/customers/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Output only. Resource name of the customer. Format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string"
                    },
                    "name1": {
                      "location": "query",
                      "deprecated": true,
                      "description": "Deprecated: Set Customer.name instead Name uses the format: accounts/{account_id}/customers/{customer_id}",
                      "type": "string"
                    },
                    "updateMask": {
                      "location": "query",
                      "description": "The update mask that applies to the resource. Optional.",
                      "type": "string",
                      "format": "google-fieldmask"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "path": "v1alpha1/{+name}",
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/customers/{customersId}",
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1Customer"
                  },
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "httpMethod": "PATCH",
                  "id": "cloudchannel.accounts.channelPartnerLinks.customers.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.",
                  "parameterOrder": [
                    "name"
                  ]
                }
              }
            },
            "channelPartnerRepricingConfigs": {
              "methods": {
                "patch": {
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$",
                      "description": "Output only. Resource name of the ChannelPartnerRepricingConfig. Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
                      "type": "string",
                      "location": "path",
                      "required": true
                    }
                  },
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.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.",
                  "httpMethod": "PATCH"
                },
                "list": {
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "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.",
                  "parameterOrder": [
                    "parent"
                  ],
                  "parameters": {
                    "pageToken": {
                      "location": "query",
                      "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"
                    },
                    "filter": {
                      "location": "query",
                      "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"
                    },
                    "parent": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                    },
                    "pageSize": {
                      "format": "int32",
                      "location": "query",
                      "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"
                    }
                  },
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListChannelPartnerRepricingConfigsResponse"
                  },
                  "path": "v1alpha1/{+parent}/channelPartnerRepricingConfigs",
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs"
                },
                "get": {
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.get",
                  "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",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "parameters": {
                    "name": {
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$",
                      "location": "path",
                      "required": true,
                      "description": "Required. The resource name of the ChannelPartnerRepricingConfig Format: accounts/{account_id}/channelPartnerLinks/{channel_partner_id}/channelPartnerRepricingConfigs/{id}.",
                      "type": "string"
                    }
                  }
                },
                "delete": {
                  "httpMethod": "DELETE",
                  "parameterOrder": [
                    "name"
                  ],
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.delete",
                  "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.",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs/{channelPartnerRepricingConfigsId}",
                  "parameters": {
                    "name": {
                      "location": "path",
                      "required": true,
                      "description": "Required. The resource name of the channel partner repricing config rule to delete.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+/channelPartnerRepricingConfigs/[^/]+$"
                    }
                  },
                  "path": "v1alpha1/{+name}",
                  "response": {
                    "$ref": "GoogleProtobufEmpty"
                  }
                },
                "create": {
                  "id": "cloudchannel.accounts.channelPartnerLinks.channelPartnerRepricingConfigs.create",
                  "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"
                  ],
                  "httpMethod": "POST",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "request": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "flatPath": "v1alpha1/accounts/{accountsId}/channelPartnerLinks/{channelPartnerLinksId}/channelPartnerRepricingConfigs",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ChannelPartnerRepricingConfig"
                  },
                  "path": "v1alpha1/{+parent}/channelPartnerRepricingConfigs",
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "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",
                      "pattern": "^accounts/[^/]+/channelPartnerLinks/[^/]+$"
                    }
                  }
                }
              }
            }
          }
        },
        "skuGroups": {
          "methods": {
            "list": {
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "parameterOrder": [
                "parent"
              ],
              "id": "cloudchannel.accounts.skuGroups.list",
              "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.",
              "httpMethod": "GET",
              "path": "v1alpha1/{+parent}/skuGroups",
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListSkuGroupsResponse"
              },
              "parameters": {
                "pageToken": {
                  "location": "query",
                  "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"
                },
                "parent": {
                  "pattern": "^accounts/[^/]+$",
                  "location": "path",
                  "required": true,
                  "description": "Required. The resource name of the account from which to list SKU groups. Parent uses the format: accounts/{account}.",
                  "type": "string"
                },
                "pageSize": {
                  "location": "query",
                  "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",
                  "format": "int32"
                }
              },
              "flatPath": "v1alpha1/accounts/{accountsId}/skuGroups"
            }
          },
          "resources": {
            "billableSkus": {
              "methods": {
                "list": {
                  "parameterOrder": [
                    "parent"
                  ],
                  "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.",
                  "httpMethod": "GET",
                  "scopes": [
                    "https://www.googleapis.com/auth/apps.order"
                  ],
                  "flatPath": "v1alpha1/accounts/{accountsId}/skuGroups/{skuGroupsId}/billableSkus",
                  "path": "v1alpha1/{+parent}/billableSkus",
                  "response": {
                    "$ref": "GoogleCloudChannelV1alpha1ListSkuGroupBillableSkusResponse"
                  },
                  "parameters": {
                    "parent": {
                      "location": "path",
                      "required": true,
                      "description": "Required. Resource name of the SKU group. Format: accounts/{account}/skuGroups/{sku_group}.",
                      "type": "string",
                      "pattern": "^accounts/[^/]+/skuGroups/[^/]+$"
                    },
                    "pageSize": {
                      "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",
                      "location": "query"
                    },
                    "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"
                    }
                  }
                }
              }
            }
          }
        },
        "offers": {
          "methods": {
            "list": {
              "parameters": {
                "parent": {
                  "description": "Required. The resource name of the reseller account from which to list Offers. Parent uses the format: accounts/{account_id}.",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+$"
                },
                "pageToken": {
                  "description": "Optional. A token for a page of results other than the first page.",
                  "type": "string",
                  "location": "query"
                },
                "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"
                },
                "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"
                },
                "pageSize": {
                  "format": "int32",
                  "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"
                },
                "languageCode": {
                  "location": "query",
                  "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"
                },
                "dealCode": {
                  "location": "query",
                  "description": "Optional. A string to filter for only these specific deal codes",
                  "type": "string"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListOffersResponse"
              },
              "path": "v1alpha1/{+parent}/offers",
              "flatPath": "v1alpha1/accounts/{accountsId}/offers",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "GET",
              "id": "cloudchannel.accounts.offers.list",
              "description": "Lists the Offers the reseller can sell. Possible error codes: * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
              "parameterOrder": [
                "parent"
              ]
            }
          }
        },
        "reports": {
          "methods": {
            "run": {
              "httpMethod": "POST",
              "id": "cloudchannel.accounts.reports.run",
              "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.",
              "parameterOrder": [
                "name"
              ],
              "scopes": [
                "https://www.googleapis.com/auth/apps.reports.usage.readonly"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/reports/{reportsId}:run",
              "request": {
                "$ref": "GoogleCloudChannelV1alpha1RunReportJobRequest"
              },
              "parameters": {
                "name": {
                  "pattern": "^accounts/[^/]+/reports/[^/]+$",
                  "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",
                  "location": "path",
                  "required": true
                }
              },
              "response": {
                "$ref": "GoogleLongrunningOperation"
              },
              "path": "v1alpha1/{+name}:run",
              "deprecated": true
            },
            "list": {
              "httpMethod": "GET",
              "parameterOrder": [
                "parent"
              ],
              "id": "cloudchannel.accounts.reports.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"
              ],
              "flatPath": "v1alpha1/accounts/{accountsId}/reports",
              "parameters": {
                "parent": {
                  "description": "Required. The resource name of the partner account to list available reports for. Parent uses the format: accounts/{account_id}",
                  "type": "string",
                  "location": "path",
                  "required": true,
                  "pattern": "^accounts/[^/]+$"
                },
                "pageSize": {
                  "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",
                  "location": "query"
                },
                "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"
                },
                "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",
                  "location": "query"
                }
              },
              "path": "v1alpha1/{+parent}/reports",
              "deprecated": true,
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListReportsResponse"
              }
            }
          },
          "deprecated": true
        }
      }
    },
    "integrators": {
      "methods": {
        "registerSubscriber": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "httpMethod": "POST",
          "id": "cloudchannel.integrators.registerSubscriber",
          "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.",
          "parameterOrder": [
            "integrator"
          ],
          "parameters": {
            "integrator": {
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^integrators/[^/]+$"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberResponse"
          },
          "path": "v1alpha1/{+integrator}:registerSubscriber",
          "flatPath": "v1alpha1/integrators/{integratorsId}:registerSubscriber",
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1RegisterSubscriberRequest"
          }
        },
        "unregisterSubscriber": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "id": "cloudchannel.integrators.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.",
          "parameterOrder": [
            "integrator"
          ],
          "httpMethod": "POST",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberResponse"
          },
          "path": "v1alpha1/{+integrator}:unregisterSubscriber",
          "parameters": {
            "integrator": {
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^integrators/[^/]+$"
            }
          },
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1UnregisterSubscriberRequest"
          },
          "flatPath": "v1alpha1/integrators/{integratorsId}:unregisterSubscriber"
        },
        "listSubscribers": {
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListSubscribersResponse"
          },
          "path": "v1alpha1/{+integrator}:listSubscribers",
          "parameters": {
            "account": {
              "description": "Optional. Resource name of the account. Required if integrator is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "query"
            },
            "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"
            },
            "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": {
              "description": "Optional. Resource name of the integrator. Required if account is not provided. Otherwise, leave this field empty/unset.",
              "type": "string",
              "location": "path",
              "required": true,
              "pattern": "^integrators/[^/]+$"
            }
          },
          "flatPath": "v1alpha1/integrators/{integratorsId}:listSubscribers",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "id": "cloudchannel.integrators.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.",
          "parameterOrder": [
            "integrator"
          ],
          "httpMethod": "GET"
        }
      }
    },
    "products": {
      "methods": {
        "list": {
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "parameterOrder": [],
          "id": "cloudchannel.products.list",
          "description": "Lists the Products the reseller is authorized to sell. Possible error codes: * INVALID_ARGUMENT: Required request parameters are missing or invalid.",
          "httpMethod": "GET",
          "path": "v1alpha1/products",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1ListProductsResponse"
          },
          "parameters": {
            "account": {
              "description": "Required. The resource name of the reseller account. 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.",
              "type": "string"
            },
            "languageCode": {
              "location": "query",
              "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"
            },
            "pageSize": {
              "format": "int32",
              "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"
            }
          },
          "flatPath": "v1alpha1/products"
        }
      },
      "resources": {
        "skus": {
          "methods": {
            "list": {
              "parameters": {
                "languageCode": {
                  "location": "query",
                  "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"
                },
                "pageSize": {
                  "format": "int32",
                  "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"
                },
                "account": {
                  "location": "query",
                  "description": "Required. Resource name of the reseller. Format: accounts/{account_id}.",
                  "type": "string"
                },
                "pageToken": {
                  "location": "query",
                  "description": "Optional. A token for a page of results other than the first page. Optional.",
                  "type": "string"
                },
                "parent": {
                  "pattern": "^products/[^/]+$",
                  "location": "path",
                  "required": true,
                  "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"
                }
              },
              "response": {
                "$ref": "GoogleCloudChannelV1alpha1ListSkusResponse"
              },
              "path": "v1alpha1/{+parent}/skus",
              "flatPath": "v1alpha1/products/{productsId}/skus",
              "scopes": [
                "https://www.googleapis.com/auth/apps.order"
              ],
              "httpMethod": "GET",
              "id": "cloudchannel.products.skus.list",
              "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.",
              "parameterOrder": [
                "parent"
              ]
            }
          }
        }
      }
    },
    "opportunities": {
      "methods": {
        "create": {
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "flatPath": "v1alpha1/opportunities",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "path": "v1alpha1/opportunities",
          "parameters": {},
          "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.",
          "parameterOrder": [],
          "httpMethod": "POST",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ]
        },
        "get": {
          "httpMethod": "GET",
          "id": "cloudchannel.opportunities.get",
          "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.",
          "parameterOrder": [
            "name"
          ],
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "flatPath": "v1alpha1/opportunities/{opportunitiesId}",
          "parameters": {
            "partner": {
              "description": "Required. Provide the Partner Id for which the Opportunity is being retrieved. Format: partner = partners/{id}",
              "type": "string",
              "location": "query"
            },
            "name": {
              "location": "path",
              "required": true,
              "description": "Required. The name of the opportunity to retrieve. Format: opportunities/{opportunity}",
              "type": "string",
              "pattern": "^opportunities/[^/]+$"
            }
          },
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "path": "v1alpha1/{+name}"
        },
        "patch": {
          "parameters": {
            "name": {
              "pattern": "^opportunities/[^/]+$",
              "description": "Identifier. Resource name of an Opportunity in the form: opportunities/{opportunity_id}. Available in Limited view.",
              "type": "string",
              "location": "path",
              "required": true
            },
            "partner": {
              "location": "query",
              "description": "Required. Provide the Partner Id for which the Opportunity is being updated. Format: partner = partners/{id}",
              "type": "string"
            },
            "updateMask": {
              "format": "google-fieldmask",
              "description": "Required. The list of fields to update.",
              "type": "string",
              "location": "query"
            }
          },
          "path": "v1alpha1/{+name}",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "flatPath": "v1alpha1/opportunities/{opportunitiesId}",
          "request": {
            "$ref": "GoogleCloudChannelV1alpha1Opportunity"
          },
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "httpMethod": "PATCH",
          "parameterOrder": [
            "name"
          ],
          "id": "cloudchannel.opportunities.patch",
          "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."
        },
        "query": {
          "httpMethod": "GET",
          "parameterOrder": [],
          "id": "cloudchannel.opportunities.query",
          "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.",
          "scopes": [
            "https://www.googleapis.com/auth/apps.order"
          ],
          "flatPath": "v1alpha1/opportunities:query",
          "parameters": {
            "partner": {
              "location": "query",
              "description": "Required. Provide the Partner ID for which the Opportunities are being queried. Format: partner = partners/{id}",
              "type": "string"
            },
            "pageSize": {
              "format": "int32",
              "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"
            },
            "orderBy": {
              "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",
              "location": "query"
            },
            "pageToken": {
              "location": "query",
              "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"
            },
            "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"
            }
          },
          "path": "v1alpha1/opportunities:query",
          "response": {
            "$ref": "GoogleCloudChannelV1alpha1QueryOpportunitiesResponse"
          }
        }
      }
    }
  },
  "revision": "20260504",
  "canonicalName": "Cloudchannel",
  "rootUrl": "https://cloudchannel.googleapis.com/",
  "documentationLink": "https://cloud.google.com/channel",
  "ownerDomain": "google.com",
  "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"
}
