* $cloudchannelService = new Google\Service\Cloudchannel(...); * $customers = $cloudchannelService->customers; * */ class AccountsCustomers extends \Google\Service\Resource { /** * 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. * * 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. (customers.create) * * @param string $parent Required. The resource name of reseller account in * which to create the customer. Parent uses the format: accounts/{account_id} * @param GoogleCloudChannelV1Customer $postBody * @param array $optParams Optional parameters. * @return GoogleCloudChannelV1Customer */ public function create($parent, GoogleCloudChannelV1Customer $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('create', [$params], GoogleCloudChannelV1Customer::class); } /** * 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. (customers.delete) * * @param string $name Required. The resource name of the customer to delete. * @param array $optParams Optional parameters. * @return GoogleProtobufEmpty */ public function delete($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('delete', [$params], GoogleProtobufEmpty::class); } /** * 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. (customers.get) * * @param string $name Required. The resource name of the customer to retrieve. * Name uses the format: accounts/{account_id}/customers/{customer_id} * @param array $optParams Optional parameters. * @return GoogleCloudChannelV1Customer */ public function get($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('get', [$params], GoogleCloudChannelV1Customer::class); } /** * 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. * 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. (customers.import) * * @param string $parent Required. The resource name of the reseller's account. * Parent takes the format: accounts/{account_id} or * accounts/{account_id}/channelPartnerLinks/{channel_partner_id} * @param GoogleCloudChannelV1ImportCustomerRequest $postBody * @param array $optParams Optional parameters. * @return GoogleCloudChannelV1Customer */ public function import($parent, GoogleCloudChannelV1ImportCustomerRequest $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('import', [$params], GoogleCloudChannelV1Customer::class); } /** * 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. (customers.listAccountsCustomers) * * @param string $parent Required. The resource name of the reseller account to * list customers from. Parent uses the format: accounts/{account_id}. * @param array $optParams Optional parameters. * * @opt_param string filter Optional. Filters applied to the * [CloudChannelService.ListCustomers] results. See * https://cloud.google.com/channel/docs/concepts/google-cloud/filter-customers * for more information. * @opt_param int pageSize 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. * @opt_param string pageToken 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. * @return GoogleCloudChannelV1ListCustomersResponse */ public function listAccountsCustomers($parent, $optParams = []) { $params = ['parent' => $parent]; $params = array_merge($params, $optParams); return $this->call('list', [$params], GoogleCloudChannelV1ListCustomersResponse::class); } /** * 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 * * INVALID_ARGUMENT: Required request parameters are missing or invalid. * (customers.listPurchasableOffers) * * @param string $customer Required. The resource name of the customer to list * Offers for. Format: accounts/{account_id}/customers/{customer_id}. * @param array $optParams Optional parameters. * * @opt_param string changeOfferPurchase.entitlement Required. Resource name of * the entitlement. Format: * accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id} * @opt_param string changeOfferPurchase.newSku Optional. Resource name of the * new target SKU. Provide this SKU when upgrading or downgrading an * entitlement. Format: products/{product_id}/skus/{sku_id} * @opt_param string createEntitlementPurchase.sku Required. SKU that the result * should be restricted to. Format: products/{product_id}/skus/{sku_id}. * @opt_param string languageCode 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". * @opt_param int pageSize 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. * @opt_param string pageToken Optional. A token for a page of results other * than the first page. * @return GoogleCloudChannelV1ListPurchasableOffersResponse */ public function listPurchasableOffers($customer, $optParams = []) { $params = ['customer' => $customer]; $params = array_merge($params, $optParams); return $this->call('listPurchasableOffers', [$params], GoogleCloudChannelV1ListPurchasableOffersResponse::class); } /** * 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. * (customers.listPurchasableSkus) * * @param string $customer Required. The resource name of the customer to list * SKUs for. Format: accounts/{account_id}/customers/{customer_id}. * @param array $optParams Optional parameters. * * @opt_param string changeOfferPurchase.changeType Required. Change Type for * the entitlement. * @opt_param string changeOfferPurchase.entitlement Required. Resource name of * the entitlement. Format: * accounts/{account_id}/customers/{customer_id}/entitlements/{entitlement_id} * @opt_param string createEntitlementPurchase.product Required. List SKUs * belonging to this Product. Format: products/{product_id}. Supports products/- * to retrieve SKUs for all products. * @opt_param string languageCode 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". * @opt_param int pageSize 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. * @opt_param string pageToken Optional. A token for a page of results other * than the first page. * @return GoogleCloudChannelV1ListPurchasableSkusResponse */ public function listPurchasableSkus($customer, $optParams = []) { $params = ['customer' => $customer]; $params = array_merge($params, $optParams); return $this->call('listPurchasableSkus', [$params], GoogleCloudChannelV1ListPurchasableSkusResponse::class); } /** * 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. (customers.patch) * * @param string $name Output only. Resource name of the customer. Format: * accounts/{account_id}/customers/{customer_id} * @param GoogleCloudChannelV1Customer $postBody * @param array $optParams Optional parameters. * * @opt_param string updateMask The update mask that applies to the resource. * Optional. * @return GoogleCloudChannelV1Customer */ public function patch($name, GoogleCloudChannelV1Customer $postBody, $optParams = []) { $params = ['name' => $name, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('patch', [$params], GoogleCloudChannelV1Customer::class); } /** * 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. * * 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. * (customers.provisionCloudIdentity) * * @param string $customer Required. Resource name of the customer. Format: * accounts/{account_id}/customers/{customer_id} * @param GoogleCloudChannelV1ProvisionCloudIdentityRequest $postBody * @param array $optParams Optional parameters. * @return GoogleLongrunningOperation */ public function provisionCloudIdentity($customer, GoogleCloudChannelV1ProvisionCloudIdentityRequest $postBody, $optParams = []) { $params = ['customer' => $customer, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('provisionCloudIdentity', [$params], GoogleLongrunningOperation::class); } /** * Transfers customer entitlements to new reseller. 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. * 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. * (customers.transferEntitlements) * * @param string $parent 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} * @param GoogleCloudChannelV1TransferEntitlementsRequest $postBody * @param array $optParams Optional parameters. * @return GoogleLongrunningOperation */ public function transferEntitlements($parent, GoogleCloudChannelV1TransferEntitlementsRequest $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('transferEntitlements', [$params], GoogleLongrunningOperation::class); } /** * 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. (customers.transferEntitlementsToGoogle) * * @param string $parent 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} * @param GoogleCloudChannelV1TransferEntitlementsToGoogleRequest $postBody * @param array $optParams Optional parameters. * @return GoogleLongrunningOperation */ public function transferEntitlementsToGoogle($parent, GoogleCloudChannelV1TransferEntitlementsToGoogleRequest $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('transferEntitlementsToGoogle', [$params], GoogleLongrunningOperation::class); } } // Adding a class alias for backwards compatibility with the previous class name. class_alias(AccountsCustomers::class, 'Google_Service_Cloudchannel_Resource_AccountsCustomers');