* $vmwareengineService = new Google\Service\VMwareEngine(...); * $managementDnsZoneBindings = $vmwareengineService->projects_locations_privateClouds_managementDnsZoneBindings; * */ class ProjectsLocationsPrivateCloudsManagementDnsZoneBindings extends \Google\Service\Resource { /** * Creates a new `ManagementDnsZoneBinding` resource in a private cloud. This * RPC creates the DNS binding and the resource that represents the DNS binding * of the consumer VPC network to the management DNS zone. A management DNS zone * is the Cloud DNS cross-project binding zone that VMware Engine creates for * each private cloud. It contains FQDNs and corresponding IP addresses for the * private cloud's ESXi hosts and management VM appliances like vCenter and NSX * Manager. (managementDnsZoneBindings.create) * * @param string $parent Required. The resource name of the private cloud to * create a new management DNS zone binding for. Resource names are schemeless * URIs that follow the conventions in * https://cloud.google.com/apis/design/resource_names. For example: * `projects/my-project/locations/us-central1-a/privateClouds/my-cloud` * @param ManagementDnsZoneBinding $postBody * @param array $optParams Optional parameters. * * @opt_param string managementDnsZoneBindingId Required. The user-provided * identifier of the `ManagementDnsZoneBinding` resource to be created. This * identifier must be unique among `ManagementDnsZoneBinding` resources within * the parent and becomes the final token in the name URI. The identifier must * meet the following requirements: * Only contains 1-63 alphanumeric characters * and hyphens * Begins with an alphabetical character * Ends with a non-hyphen * character * Not formatted as a UUID * Complies with [RFC * 1034](https://datatracker.ietf.org/doc/html/rfc1034) (section 3.5) * @opt_param string requestId Optional. A request ID to identify requests. * Specify a unique request ID so that if you must retry your request, the * server will know to ignore the request if it has already been completed. The * server guarantees that a request doesn't result in creation of duplicate * commitments for at least 60 minutes. For example, consider a situation where * 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 the original * operation with the same request ID was received, and if so, will ignore the * second request. This prevents clients from accidentally creating duplicate * commitments. The request ID must be a valid UUID with the exception that zero * UUID is not supported (00000000-0000-0000-0000-000000000000). * @return Operation * @throws \Google\Service\Exception */ public function create($parent, ManagementDnsZoneBinding $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('create', [$params], Operation::class); } /** * Deletes a `ManagementDnsZoneBinding` resource. When a management DNS zone * binding is deleted, the corresponding consumer VPC network is no longer bound * to the management DNS zone. (managementDnsZoneBindings.delete) * * @param string $name Required. The resource name of the management DNS zone * binding to delete. Resource names are schemeless URIs that follow the * conventions in https://cloud.google.com/apis/design/resource_names. For * example: `projects/my-project/locations/us-central1-a/privateClouds/my- * cloud/managementDnsZoneBindings/my-management-dns-zone-binding` * @param array $optParams Optional parameters. * * @opt_param string requestId Optional. A request ID to identify requests. * Specify a unique request ID so that if you must retry your request, the * server will know to ignore the request if it has already been completed. The * server guarantees that a request doesn't result in creation of duplicate * commitments for at least 60 minutes. For example, consider a situation where * 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 the original * operation with the same request ID was received, and if so, will ignore the * second request. This prevents clients from accidentally creating duplicate * commitments. The request ID must be a valid UUID with the exception that zero * UUID is not supported (00000000-0000-0000-0000-000000000000). * @return Operation * @throws \Google\Service\Exception */ public function delete($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('delete', [$params], Operation::class); } /** * Retrieves a 'ManagementDnsZoneBinding' resource by its resource name. * (managementDnsZoneBindings.get) * * @param string $name Required. The resource name of the management DNS zone * binding to retrieve. Resource names are schemeless URIs that follow the * conventions in https://cloud.google.com/apis/design/resource_names. For * example: `projects/my-project/locations/us-central1-a/privateClouds/my- * cloud/managementDnsZoneBindings/my-management-dns-zone-binding` * @param array $optParams Optional parameters. * @return ManagementDnsZoneBinding * @throws \Google\Service\Exception */ public function get($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('get', [$params], ManagementDnsZoneBinding::class); } /** * Lists Consumer VPCs bound to Management DNS Zone of a given private cloud. (m * anagementDnsZoneBindings.listProjectsLocationsPrivateCloudsManagementDnsZoneB * indings) * * @param string $parent Required. The resource name of the private cloud to be * queried for management DNS zone bindings. Resource names are schemeless URIs * that follow the conventions in * https://cloud.google.com/apis/design/resource_names. For example: * `projects/my-project/locations/us-central1-a/privateClouds/my-cloud` * @param array $optParams Optional parameters. * * @opt_param string filter A filter expression that matches resources returned * in the response. The expression must specify the field name, a comparison * operator, and the value that you want to use for filtering. The value must be * a string, a number, or a boolean. The comparison operator must be `=`, `!=`, * `>`, or `<`. For example, if you are filtering a list of Management DNS Zone * Bindings, you can exclude the ones named `example-management-dns-zone- * binding` by specifying `name != "example-management-dns-zone-binding"`. To * filter on multiple expressions, provide each separate expression within * parentheses. For example: ``` (name = "example-management-dns-zone-binding") * (createTime > "2021-04-12T08:15:10.40Z") ``` By default, each expression is * an `AND` expression. However, you can include `AND` and `OR` expressions * explicitly. For example: ``` (name = "example-management-dns-zone-binding-1") * AND (createTime > "2021-04-12T08:15:10.40Z") OR (name = "example-management- * dns-zone-binding-2") ``` * @opt_param string orderBy Sorts list results by a certain order. By default, * returned results are ordered by `name` in ascending order. You can also sort * results in descending order based on the `name` value using `orderBy="name * desc"`. Currently, only ordering by `name` is supported. * @opt_param int pageSize The maximum number of management DNS zone bindings to * return in one page. The service may return fewer than this value. The maximum * value is coerced to 1000. The default value of this field is 500. * @opt_param string pageToken A page token, received from a previous * `ListManagementDnsZoneBindings` call. Provide this to retrieve the subsequent * page. When paginating, all other parameters provided to * `ListManagementDnsZoneBindings` must match the call that provided the page * token. * @return ListManagementDnsZoneBindingsResponse * @throws \Google\Service\Exception */ public function listProjectsLocationsPrivateCloudsManagementDnsZoneBindings($parent, $optParams = []) { $params = ['parent' => $parent]; $params = array_merge($params, $optParams); return $this->call('list', [$params], ListManagementDnsZoneBindingsResponse::class); } /** * Updates a `ManagementDnsZoneBinding` resource. Only fields specified in * `update_mask` are applied. (managementDnsZoneBindings.patch) * * @param string $name Output only. The resource name of this binding. Resource * names are schemeless URIs that follow the conventions in * https://cloud.google.com/apis/design/resource_names. For example: * `projects/my-project/locations/us-central1-a/privateClouds/my- * cloud/managementDnsZoneBindings/my-management-dns-zone-binding` * @param ManagementDnsZoneBinding $postBody * @param array $optParams Optional parameters. * * @opt_param string requestId Optional. A request ID to identify requests. * Specify a unique request ID so that if you must retry your request, the * server will know to ignore the request if it has already been completed. The * server guarantees that a request doesn't result in creation of duplicate * commitments for at least 60 minutes. For example, consider a situation where * 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 the original * operation with the same request ID was received, and if so, will ignore the * second request. This prevents clients from accidentally creating duplicate * commitments. The request ID must be a valid UUID with the exception that zero * UUID is not supported (00000000-0000-0000-0000-000000000000). * @opt_param string updateMask Required. Field mask is used to specify the * fields to be overwritten in the `ManagementDnsZoneBinding` resource by the * update. The fields specified in the `update_mask` are relative to the * resource, not the full request. A field will be overwritten if it is in the * mask. If the user does not provide a mask then all fields will be * overwritten. * @return Operation * @throws \Google\Service\Exception */ public function patch($name, ManagementDnsZoneBinding $postBody, $optParams = []) { $params = ['name' => $name, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('patch', [$params], Operation::class); } /** * Retries to create a `ManagementDnsZoneBinding` resource that is in failed * state. (managementDnsZoneBindings.repair) * * @param string $name Required. The resource name of the management DNS zone * binding to repair. Resource names are schemeless URIs that follow the * conventions in https://cloud.google.com/apis/design/resource_names. For * example: `projects/my-project/locations/us-central1-a/privateClouds/my- * cloud/managementDnsZoneBindings/my-management-dns-zone-binding` * @param RepairManagementDnsZoneBindingRequest $postBody * @param array $optParams Optional parameters. * @return Operation * @throws \Google\Service\Exception */ public function repair($name, RepairManagementDnsZoneBindingRequest $postBody, $optParams = []) { $params = ['name' => $name, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('repair', [$params], Operation::class); } } // Adding a class alias for backwards compatibility with the previous class name. class_alias(ProjectsLocationsPrivateCloudsManagementDnsZoneBindings::class, 'Google_Service_VMwareEngine_Resource_ProjectsLocationsPrivateCloudsManagementDnsZoneBindings');