1<?php 2/* 3 * Copyright 2014 Google Inc. 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); you may not 6 * use this file except in compliance with the License. You may obtain a copy of 7 * the License at 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 13 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the 14 * License for the specific language governing permissions and limitations under 15 * the License. 16 */ 17 18namespace Google\Service\Compute\Resource; 19 20use Google\Service\Compute\Operation; 21use Google\Service\Compute\TargetGrpcProxy; 22use Google\Service\Compute\TargetGrpcProxyList; 23 24/** 25 * The "targetGrpcProxies" collection of methods. 26 * Typical usage is: 27 * <code> 28 * $computeService = new Google\Service\Compute(...); 29 * $targetGrpcProxies = $computeService->targetGrpcProxies; 30 * </code> 31 */ 32class TargetGrpcProxies extends \Google\Service\Resource 33{ 34 /** 35 * Deletes the specified TargetGrpcProxy in the given scope 36 * (targetGrpcProxies.delete) 37 * 38 * @param string $project Project ID for this request. 39 * @param string $targetGrpcProxy Name of the TargetGrpcProxy resource to 40 * delete. 41 * @param array $optParams Optional parameters. 42 * 43 * @opt_param string requestId An optional request ID to identify requests. 44 * Specify a unique request ID so that if you must retry your request, the 45 * server will know to ignore the request if it has already been completed. For 46 * example, consider a situation where you make an initial request and the 47 * request times out. If you make the request again with the same request ID, 48 * the server can check if original operation with the same request ID was 49 * received, and if so, will ignore the second request. This prevents clients 50 * from accidentally creating duplicate commitments. The request ID must be a 51 * valid UUID with the exception that zero UUID is not supported ( 52 * 00000000-0000-0000-0000-000000000000). 53 * @return Operation 54 */ 55 public function delete($project, $targetGrpcProxy, $optParams = []) 56 { 57 $params = ['project' => $project, 'targetGrpcProxy' => $targetGrpcProxy]; 58 $params = array_merge($params, $optParams); 59 return $this->call('delete', [$params], Operation::class); 60 } 61 /** 62 * Returns the specified TargetGrpcProxy resource in the given scope. 63 * (targetGrpcProxies.get) 64 * 65 * @param string $project Project ID for this request. 66 * @param string $targetGrpcProxy Name of the TargetGrpcProxy resource to 67 * return. 68 * @param array $optParams Optional parameters. 69 * @return TargetGrpcProxy 70 */ 71 public function get($project, $targetGrpcProxy, $optParams = []) 72 { 73 $params = ['project' => $project, 'targetGrpcProxy' => $targetGrpcProxy]; 74 $params = array_merge($params, $optParams); 75 return $this->call('get', [$params], TargetGrpcProxy::class); 76 } 77 /** 78 * Creates a TargetGrpcProxy in the specified project in the given scope using 79 * the parameters that are included in the request. (targetGrpcProxies.insert) 80 * 81 * @param string $project Project ID for this request. 82 * @param TargetGrpcProxy $postBody 83 * @param array $optParams Optional parameters. 84 * 85 * @opt_param string requestId An optional request ID to identify requests. 86 * Specify a unique request ID so that if you must retry your request, the 87 * server will know to ignore the request if it has already been completed. For 88 * example, consider a situation where you make an initial request and the 89 * request times out. If you make the request again with the same request ID, 90 * the server can check if original operation with the same request ID was 91 * received, and if so, will ignore the second request. This prevents clients 92 * from accidentally creating duplicate commitments. The request ID must be a 93 * valid UUID with the exception that zero UUID is not supported ( 94 * 00000000-0000-0000-0000-000000000000). 95 * @return Operation 96 */ 97 public function insert($project, TargetGrpcProxy $postBody, $optParams = []) 98 { 99 $params = ['project' => $project, 'postBody' => $postBody]; 100 $params = array_merge($params, $optParams); 101 return $this->call('insert', [$params], Operation::class); 102 } 103 /** 104 * Lists the TargetGrpcProxies for a project in the given scope. 105 * (targetGrpcProxies.listTargetGrpcProxies) 106 * 107 * @param string $project Project ID for this request. 108 * @param array $optParams Optional parameters. 109 * 110 * @opt_param string filter A filter expression that filters resources listed in 111 * the response. The expression must specify the field name, an operator, and 112 * the value that you want to use for filtering. The value must be a string, a 113 * number, or a boolean. The operator must be either `=`, `!=`, `>`, `<`, `<=`, 114 * `>=` or `:`. For example, if you are filtering Compute Engine instances, you 115 * can exclude instances named `example-instance` by specifying `name != 116 * example-instance`. The `:` operator can be used with string fields to match 117 * substrings. For non-string fields it is equivalent to the `=` operator. The 118 * `:*` comparison can be used to test whether a key has been defined. For 119 * example, to find all objects with `owner` label use: ``` labels.owner:* ``` 120 * You can also filter nested fields. For example, you could specify 121 * `scheduling.automaticRestart = false` to include instances only if they are 122 * not scheduled for automatic restarts. You can use filtering on nested fields 123 * to filter based on resource labels. To filter on multiple expressions, 124 * provide each separate expression within parentheses. For example: ``` 125 * (scheduling.automaticRestart = true) (cpuPlatform = "Intel Skylake") ``` By 126 * default, each expression is an `AND` expression. However, you can include 127 * `AND` and `OR` expressions explicitly. For example: ``` (cpuPlatform = "Intel 128 * Skylake") OR (cpuPlatform = "Intel Broadwell") AND 129 * (scheduling.automaticRestart = true) ``` 130 * @opt_param string maxResults The maximum number of results per page that 131 * should be returned. If the number of available results is larger than 132 * `maxResults`, Compute Engine returns a `nextPageToken` that can be used to 133 * get the next page of results in subsequent list requests. Acceptable values 134 * are `0` to `500`, inclusive. (Default: `500`) 135 * @opt_param string orderBy Sorts list results by a certain order. By default, 136 * results are returned in alphanumerical order based on the resource name. You 137 * can also sort results in descending order based on the creation timestamp 138 * using `orderBy="creationTimestamp desc"`. This sorts results based on the 139 * `creationTimestamp` field in reverse chronological order (newest result 140 * first). Use this to sort resources like operations so that the newest 141 * operation is returned first. Currently, only sorting by `name` or 142 * `creationTimestamp desc` is supported. 143 * @opt_param string pageToken Specifies a page token to use. Set `pageToken` to 144 * the `nextPageToken` returned by a previous list request to get the next page 145 * of results. 146 * @opt_param bool returnPartialSuccess Opt-in for partial success behavior 147 * which provides partial results in case of failure. The default value is 148 * false. 149 * @return TargetGrpcProxyList 150 */ 151 public function listTargetGrpcProxies($project, $optParams = []) 152 { 153 $params = ['project' => $project]; 154 $params = array_merge($params, $optParams); 155 return $this->call('list', [$params], TargetGrpcProxyList::class); 156 } 157 /** 158 * Patches the specified TargetGrpcProxy resource with the data included in the 159 * request. This method supports PATCH semantics and uses JSON merge patch 160 * format and processing rules. (targetGrpcProxies.patch) 161 * 162 * @param string $project Project ID for this request. 163 * @param string $targetGrpcProxy Name of the TargetGrpcProxy resource to patch. 164 * @param TargetGrpcProxy $postBody 165 * @param array $optParams Optional parameters. 166 * 167 * @opt_param string requestId An optional request ID to identify requests. 168 * Specify a unique request ID so that if you must retry your request, the 169 * server will know to ignore the request if it has already been completed. For 170 * example, consider a situation where you make an initial request and the 171 * request times out. If you make the request again with the same request ID, 172 * the server can check if original operation with the same request ID was 173 * received, and if so, will ignore the second request. This prevents clients 174 * from accidentally creating duplicate commitments. The request ID must be a 175 * valid UUID with the exception that zero UUID is not supported ( 176 * 00000000-0000-0000-0000-000000000000). 177 * @return Operation 178 */ 179 public function patch($project, $targetGrpcProxy, TargetGrpcProxy $postBody, $optParams = []) 180 { 181 $params = ['project' => $project, 'targetGrpcProxy' => $targetGrpcProxy, 'postBody' => $postBody]; 182 $params = array_merge($params, $optParams); 183 return $this->call('patch', [$params], Operation::class); 184 } 185} 186 187// Adding a class alias for backwards compatibility with the previous class name. 188class_alias(TargetGrpcProxies::class, 'Google_Service_Compute_Resource_TargetGrpcProxies'); 189