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\Logging\Resource; 19 20use Google\Service\Logging\ListBucketsResponse; 21use Google\Service\Logging\LogBucket; 22use Google\Service\Logging\LoggingEmpty; 23use Google\Service\Logging\UndeleteBucketRequest; 24 25/** 26 * The "buckets" collection of methods. 27 * Typical usage is: 28 * <code> 29 * $loggingService = new Google\Service\Logging(...); 30 * $buckets = $loggingService->buckets; 31 * </code> 32 */ 33class ProjectsLocationsBuckets extends \Google\Service\Resource 34{ 35 /** 36 * Creates a log bucket that can be used to store log entries. After a bucket 37 * has been created, the bucket's location cannot be changed. (buckets.create) 38 * 39 * @param string $parent Required. The resource in which to create the log 40 * bucket: "projects/[PROJECT_ID]/locations/[LOCATION_ID]" For example:"projects 41 * /my-project/locations/global" 42 * @param LogBucket $postBody 43 * @param array $optParams Optional parameters. 44 * 45 * @opt_param string bucketId Required. A client-assigned identifier such as 46 * "my-bucket". Identifiers are limited to 100 characters and can include only 47 * letters, digits, underscores, hyphens, and periods. 48 * @return LogBucket 49 */ 50 public function create($parent, LogBucket $postBody, $optParams = []) 51 { 52 $params = ['parent' => $parent, 'postBody' => $postBody]; 53 $params = array_merge($params, $optParams); 54 return $this->call('create', [$params], LogBucket::class); 55 } 56 /** 57 * Deletes a log bucket.Changes the bucket's lifecycle_state to the 58 * DELETE_REQUESTED state. After 7 days, the bucket will be purged and all log 59 * entries in the bucket will be permanently deleted. (buckets.delete) 60 * 61 * @param string $name Required. The full resource name of the bucket to delete. 62 * "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 63 * "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 64 * "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET 65 * _ID]" "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" For 66 * example:"projects/my-project/locations/global/buckets/my-bucket" 67 * @param array $optParams Optional parameters. 68 * @return LoggingEmpty 69 */ 70 public function delete($name, $optParams = []) 71 { 72 $params = ['name' => $name]; 73 $params = array_merge($params, $optParams); 74 return $this->call('delete', [$params], LoggingEmpty::class); 75 } 76 /** 77 * Gets a log bucket. (buckets.get) 78 * 79 * @param string $name Required. The resource name of the bucket: 80 * "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 81 * "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 82 * "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET 83 * _ID]" "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" For 84 * example:"projects/my-project/locations/global/buckets/my-bucket" 85 * @param array $optParams Optional parameters. 86 * @return LogBucket 87 */ 88 public function get($name, $optParams = []) 89 { 90 $params = ['name' => $name]; 91 $params = array_merge($params, $optParams); 92 return $this->call('get', [$params], LogBucket::class); 93 } 94 /** 95 * Lists log buckets. (buckets.listProjectsLocationsBuckets) 96 * 97 * @param string $parent Required. The parent resource whose buckets are to be 98 * listed: "projects/[PROJECT_ID]/locations/[LOCATION_ID]" 99 * "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]" 100 * "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]" 101 * "folders/[FOLDER_ID]/locations/[LOCATION_ID]" Note: The locations portion of 102 * the resource must be specified, but supplying the character - in place of 103 * LOCATION_ID will return all buckets. 104 * @param array $optParams Optional parameters. 105 * 106 * @opt_param int pageSize Optional. The maximum number of results to return 107 * from this request. Non-positive values are ignored. The presence of 108 * nextPageToken in the response indicates that more results might be available. 109 * @opt_param string pageToken Optional. If present, then retrieve the next 110 * batch of results from the preceding call to this method. pageToken must be 111 * the value of nextPageToken from the previous response. The values of other 112 * method parameters should be identical to those in the previous call. 113 * @return ListBucketsResponse 114 */ 115 public function listProjectsLocationsBuckets($parent, $optParams = []) 116 { 117 $params = ['parent' => $parent]; 118 $params = array_merge($params, $optParams); 119 return $this->call('list', [$params], ListBucketsResponse::class); 120 } 121 /** 122 * Updates a log bucket. This method replaces the following fields in the 123 * existing bucket with values from the new bucket: retention_periodIf the 124 * retention period is decreased and the bucket is locked, FAILED_PRECONDITION 125 * will be returned.If the bucket has a lifecycle_state of DELETE_REQUESTED, 126 * then FAILED_PRECONDITION will be returned.After a bucket has been created, 127 * the bucket's location cannot be changed. (buckets.patch) 128 * 129 * @param string $name Required. The full resource name of the bucket to update. 130 * "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 131 * "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 132 * "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET 133 * _ID]" "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" For 134 * example:"projects/my-project/locations/global/buckets/my-bucket" 135 * @param LogBucket $postBody 136 * @param array $optParams Optional parameters. 137 * 138 * @opt_param string updateMask Required. Field mask that specifies the fields 139 * in bucket that need an update. A bucket field will be overwritten if, and 140 * only if, it is in the update mask. name and output only fields cannot be 141 * updated.For a detailed FieldMask definition, see: 142 * https://developers.google.com/protocol- 143 * buffers/docs/reference/google.protobuf#google.protobuf.FieldMaskFor example: 144 * updateMask=retention_days 145 * @return LogBucket 146 */ 147 public function patch($name, LogBucket $postBody, $optParams = []) 148 { 149 $params = ['name' => $name, 'postBody' => $postBody]; 150 $params = array_merge($params, $optParams); 151 return $this->call('patch', [$params], LogBucket::class); 152 } 153 /** 154 * Undeletes a log bucket. A bucket that has been deleted can be undeleted 155 * within the grace period of 7 days. (buckets.undelete) 156 * 157 * @param string $name Required. The full resource name of the bucket to 158 * undelete. "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 159 * "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" 160 * "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET 161 * _ID]" "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]" For 162 * example:"projects/my-project/locations/global/buckets/my-bucket" 163 * @param UndeleteBucketRequest $postBody 164 * @param array $optParams Optional parameters. 165 * @return LoggingEmpty 166 */ 167 public function undelete($name, UndeleteBucketRequest $postBody, $optParams = []) 168 { 169 $params = ['name' => $name, 'postBody' => $postBody]; 170 $params = array_merge($params, $optParams); 171 return $this->call('undelete', [$params], LoggingEmpty::class); 172 } 173} 174 175// Adding a class alias for backwards compatibility with the previous class name. 176class_alias(ProjectsLocationsBuckets::class, 'Google_Service_Logging_Resource_ProjectsLocationsBuckets'); 177