<?php /* * Copyright 2014 Google Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy of * the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations under * the License. */ namespace Google\Service\VMMigrationService\Resource; use Google\Service\VMMigrationService\AddGroupMigrationRequest; use Google\Service\VMMigrationService\Group; use Google\Service\VMMigrationService\ListGroupsResponse; use Google\Service\VMMigrationService\Operation; use Google\Service\VMMigrationService\RemoveGroupMigrationRequest; /** * The "groups" collection of methods. * Typical usage is: * <code> * $vmmigrationService = new Google\Service\VMMigrationService(...); * $groups = $vmmigrationService->groups; * </code> */ class ProjectsLocationsGroups extends \Google\Service\Resource { /** * Adds a MigratingVm to a Group. (groups.addGroupMigration) * * @param string $group Required. The full path name of the Group to add to. * @param AddGroupMigrationRequest $postBody * @param array $optParams Optional parameters. * @return Operation */ public function addGroupMigration($group, AddGroupMigrationRequest $postBody, $optParams = []) { $params = ['group' => $group, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('addGroupMigration', [$params], Operation::class); } /** * Creates a new Group in a given project and location. (groups.create) * * @param string $parent Required. The Group's parent. * @param Group $postBody * @param array $optParams Optional parameters. * * @opt_param string groupId Required. The group identifier. * @opt_param string requestId 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 will * guarantee that for at least 60 minutes since the first request. For example, * consider a situation where you make an initial request and t he request times * out. If you make the request again with the same request ID, the server can * check if 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 */ public function create($parent, Group $postBody, $optParams = []) { $params = ['parent' => $parent, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('create', [$params], Operation::class); } /** * Deletes a single Group. (groups.delete) * * @param string $name Required. The Group name. * @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 will guarantee that for at least 60 minutes after the first request. * For example, consider a situation where you make an initial request and t he * request times out. If you make the request again with the same request ID, * the server can check if 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 */ public function delete($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('delete', [$params], Operation::class); } /** * Gets details of a single Group. (groups.get) * * @param string $name Required. The group name. * @param array $optParams Optional parameters. * @return Group */ public function get($name, $optParams = []) { $params = ['name' => $name]; $params = array_merge($params, $optParams); return $this->call('get', [$params], Group::class); } /** * Lists Groups in a given project and location. * (groups.listProjectsLocationsGroups) * * @param string $parent Required. The parent, which owns this collection of * groups. * @param array $optParams Optional parameters. * * @opt_param string filter Optional. The filter request. * @opt_param string orderBy Optional. the order by fields for the result. * @opt_param int pageSize Optional. The maximum number of groups to return. The * service may return fewer than this value. If unspecified, at most 500 groups * will be returned. The maximum value is 1000; values above 1000 will be * coerced to 1000. * @opt_param string pageToken Required. A page token, received from a previous * `ListGroups` call. Provide this to retrieve the subsequent page. When * paginating, all other parameters provided to `ListGroups` must match the call * that provided the page token. * @return ListGroupsResponse */ public function listProjectsLocationsGroups($parent, $optParams = []) { $params = ['parent' => $parent]; $params = array_merge($params, $optParams); return $this->call('list', [$params], ListGroupsResponse::class); } /** * Updates the parameters of a single Group. (groups.patch) * * @param string $name Output only. The Group name. * @param Group $postBody * @param array $optParams Optional parameters. * * @opt_param string requestId 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 will * guarantee that for at least 60 minutes since the first request. For example, * consider a situation where you make an initial request and t he request times * out. If you make the request again with the same request ID, the server can * check if 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 Field mask is used to specify the fields to be * overwritten in the Group 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 */ public function patch($name, Group $postBody, $optParams = []) { $params = ['name' => $name, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('patch', [$params], Operation::class); } /** * Removes a MigratingVm from a Group. (groups.removeGroupMigration) * * @param string $group Required. The name of the Group. * @param RemoveGroupMigrationRequest $postBody * @param array $optParams Optional parameters. * @return Operation */ public function removeGroupMigration($group, RemoveGroupMigrationRequest $postBody, $optParams = []) { $params = ['group' => $group, 'postBody' => $postBody]; $params = array_merge($params, $optParams); return $this->call('removeGroupMigration', [$params], Operation::class); } } // Adding a class alias for backwards compatibility with the previous class name. class_alias(ProjectsLocationsGroups::class, 'Google_Service_VMMigrationService_Resource_ProjectsLocationsGroups');