google-cloud-gke_hub-v1beta1 0.2.1 → 0.4.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 01a4e77e82741c997b88548a6a7c6f9123ffa6ae08e6770a64240630add8bd51
4
- data.tar.gz: c82167de635033fb5c3eee89f5be950725882122e7ad293d595d4f4fc295eb6c
3
+ metadata.gz: 5719911f694aee3b33fa77d735704aff86f303cbf707adc152e5409eabcdf507
4
+ data.tar.gz: ac519d5d01a5b49a6d720458497d32acb0a856149b17dc6e39d0e714f898e0ed
5
5
  SHA512:
6
- metadata.gz: c4d0fdef95f97fa7f0c99509ebc83de3cc23aca52af2281007a30720e02a9917096509fa98d72bde27606fe5f618c963f3c81150638bee879daafdbee495de58
7
- data.tar.gz: 196b8e17562d63556d0be80cf1ccb75119fc0edcef8cabdaf83fd79856886a49d6ea04d97f39b5edb2da82a00eccbdbdb6408269c71fa149b505b20973f1603f
6
+ metadata.gz: 1c00949f0abecfa12e926c707cbee15e25fcbe2f5516c928a099a266f6199dcca429428a00246b8f6967b585f7d5bb57dd07e552740a556eff3f47f0a5efe146
7
+ data.tar.gz: 32654eb627900ac47573f22a3c3e844876c04be8ac80c4d56e25f3e58584169638c28dc990fa5dc9967593eba62363d844522114cf56357090acd55750ae58d7
data/.yardopts CHANGED
@@ -1,5 +1,5 @@
1
1
  --no-private
2
- --title=GKE Hub V1beta1 API
2
+ --title="GKE Hub V1beta1 API"
3
3
  --exclude _pb\.rb$
4
4
  --markup markdown
5
5
  --markup-provider redcarpet
data/AUTHENTICATION.md CHANGED
@@ -120,15 +120,6 @@ To configure your system for this, simply:
120
120
  **NOTE:** This is _not_ recommended for running in production. The Cloud SDK
121
121
  *should* only be used during development.
122
122
 
123
- [gce-how-to]: https://cloud.google.com/compute/docs/authentication#using
124
- [dev-console]: https://console.cloud.google.com/project
125
-
126
- [enable-apis]: https://raw.githubusercontent.com/GoogleCloudPlatform/gcloud-common/master/authentication/enable-apis.png
127
-
128
- [create-new-service-account]: https://raw.githubusercontent.com/GoogleCloudPlatform/gcloud-common/master/authentication/create-new-service-account.png
129
- [create-new-service-account-existing-keys]: https://raw.githubusercontent.com/GoogleCloudPlatform/gcloud-common/master/authentication/create-new-service-account-existing-keys.png
130
- [reuse-service-account]: https://raw.githubusercontent.com/GoogleCloudPlatform/gcloud-common/master/authentication/reuse-service-account.png
131
-
132
123
  ## Creating a Service Account
133
124
 
134
125
  Google Cloud requires **Service Account Credentials** to
@@ -139,31 +130,22 @@ If you are not running this client within
139
130
  [Google Cloud Platform environments](#google-cloud-platform-environments), you
140
131
  need a Google Developers service account.
141
132
 
142
- 1. Visit the [Google Developers Console][dev-console].
133
+ 1. Visit the [Google Cloud Console](https://console.cloud.google.com/project).
143
134
  2. Create a new project or click on an existing project.
144
- 3. Activate the slide-out navigation tray and select **API Manager**. From
135
+ 3. Activate the menu in the upper left and select **APIs & Services**. From
145
136
  here, you will enable the APIs that your application requires.
146
137
 
147
- ![Enable the APIs that your application requires][enable-apis]
148
-
149
138
  *Note: You may need to enable billing in order to use these services.*
150
139
 
151
140
  4. Select **Credentials** from the side navigation.
152
141
 
153
- You should see a screen like one of the following.
154
-
155
- ![Create a new service account][create-new-service-account]
156
-
157
- ![Create a new service account With Existing Keys][create-new-service-account-existing-keys]
158
-
159
- Find the "Add credentials" drop down and select "Service account" to be
160
- guided through downloading a new JSON key file.
142
+ Find the "Create credentials" drop down near the top of the page, and select
143
+ "Service account" to be guided through downloading a new JSON key file.
161
144
 
162
145
  If you want to re-use an existing service account, you can easily generate a
163
- new key file. Just select the account you wish to re-use, and click "Generate
164
- new JSON key":
165
-
166
- ![Re-use an existing service account][reuse-service-account]
146
+ new key file. Just select the account you wish to re-use, click the pencil
147
+ tool on the right side to edit the service account, select the **Keys** tab,
148
+ and then select **Add Key**.
167
149
 
168
150
  The key file you download will be used by this library to authenticate API
169
151
  requests and should be stored in a secure location.
data/README.md CHANGED
@@ -37,7 +37,7 @@ request = ::Google::Cloud::GkeHub::V1beta1::ListMembershipsRequest.new # (reques
37
37
  response = client.list_memberships request
38
38
  ```
39
39
 
40
- View the [Client Library Documentation](https://googleapis.dev/ruby/google-cloud-gke_hub-v1beta1/latest)
40
+ View the [Client Library Documentation](https://cloud.google.com/ruby/docs/reference/google-cloud-gke_hub-v1beta1/latest)
41
41
  for class and method documentation.
42
42
 
43
43
  See also the [Product Documentation](https://cloud.google.com/anthos/clusters/docs)
@@ -69,6 +69,11 @@ module GRPC
69
69
  end
70
70
  ```
71
71
 
72
+
73
+ ## Google Cloud Samples
74
+
75
+ To browse ready to use code samples check [Google Cloud Samples](https://cloud.google.com/docs/samples).
76
+
72
77
  ## Supported Ruby Versions
73
78
 
74
79
  This library is supported on Ruby 2.5+.
@@ -18,6 +18,8 @@
18
18
 
19
19
  require "google/cloud/errors"
20
20
  require "google/cloud/gkehub/v1beta1/membership_pb"
21
+ require "google/cloud/location"
22
+ require "google/iam/v1/iam_policy"
21
23
 
22
24
  module Google
23
25
  module Cloud
@@ -147,6 +149,19 @@ module Google
147
149
 
148
150
  @operations_client = Operations.new do |config|
149
151
  config.credentials = credentials
152
+ config.quota_project = @quota_project_id
153
+ config.endpoint = @config.endpoint
154
+ end
155
+
156
+ @location_client = Google::Cloud::Location::Locations::Client.new do |config|
157
+ config.credentials = credentials
158
+ config.quota_project = @quota_project_id
159
+ config.endpoint = @config.endpoint
160
+ end
161
+
162
+ @iam_policy_client = Google::Iam::V1::IAMPolicy::Client.new do |config|
163
+ config.credentials = credentials
164
+ config.quota_project = @quota_project_id
150
165
  config.endpoint = @config.endpoint
151
166
  end
152
167
 
@@ -166,6 +181,20 @@ module Google
166
181
  #
167
182
  attr_reader :operations_client
168
183
 
184
+ ##
185
+ # Get the associated client for mix-in of the Locations.
186
+ #
187
+ # @return [Google::Cloud::Location::Locations::Client]
188
+ #
189
+ attr_reader :location_client
190
+
191
+ ##
192
+ # Get the associated client for mix-in of the IAMPolicy.
193
+ #
194
+ # @return [Google::Iam::V1::IAMPolicy::Client]
195
+ #
196
+ attr_reader :iam_policy_client
197
+
169
198
  # Service calls
170
199
 
171
200
  ##
@@ -24,6 +24,23 @@ module Google
24
24
  module GkeHubMembershipService
25
25
  # Path helper methods for the GkeHubMembershipService API.
26
26
  module Paths
27
+ ##
28
+ # Create a fully-qualified Location resource string.
29
+ #
30
+ # The resource will be in the following format:
31
+ #
32
+ # `projects/{project}/locations/{location}`
33
+ #
34
+ # @param project [String]
35
+ # @param location [String]
36
+ #
37
+ # @return [::String]
38
+ def location_path project:, location:
39
+ raise ::ArgumentError, "project cannot contain /" if project.to_s.include? "/"
40
+
41
+ "projects/#{project}/locations/#{location}"
42
+ end
43
+
27
44
  ##
28
45
  # Create a fully-qualified Membership resource string.
29
46
  #
@@ -21,7 +21,7 @@ module Google
21
21
  module Cloud
22
22
  module GkeHub
23
23
  module V1beta1
24
- VERSION = "0.2.1"
24
+ VERSION = "0.4.0"
25
25
  end
26
26
  end
27
27
  end
@@ -25,6 +25,8 @@ module Google
25
25
  ##
26
26
  # To load this package, including all its services, and instantiate a client:
27
27
  #
28
+ # @example
29
+ #
28
30
  # require "google/cloud/gke_hub/v1beta1"
29
31
  # client = ::Google::Cloud::GkeHub::V1beta1::GkeHubMembershipService::Client.new
30
32
  #
@@ -1,6 +1,8 @@
1
1
  # Generated by the protocol buffer compiler. DO NOT EDIT!
2
2
  # source: google/cloud/gkehub/v1beta1/membership.proto
3
3
 
4
+ require 'google/protobuf'
5
+
4
6
  require 'google/api/annotations_pb'
5
7
  require 'google/api/client_pb'
6
8
  require 'google/api/field_behavior_pb'
@@ -9,7 +11,6 @@ require 'google/longrunning/operations_pb'
9
11
  require 'google/protobuf/field_mask_pb'
10
12
  require 'google/protobuf/timestamp_pb'
11
13
  require 'google/rpc/status_pb'
12
- require 'google/protobuf'
13
14
 
14
15
  Google::Protobuf::DescriptorPool.generated_pool.build do
15
16
  add_file("google/cloud/gkehub/v1beta1/membership.proto", :syntax => :proto3) do
@@ -42,6 +43,8 @@ Google::Protobuf::DescriptorPool.generated_pool.build do
42
43
  optional :gke_cluster, :message, 4, "google.cloud.gkehub.v1beta1.GkeCluster"
43
44
  optional :on_prem_cluster, :message, 7, "google.cloud.gkehub.v1beta1.OnPremCluster"
44
45
  optional :multi_cloud_cluster, :message, 8, "google.cloud.gkehub.v1beta1.MultiCloudCluster"
46
+ optional :edge_cluster, :message, 9, "google.cloud.gkehub.v1beta1.EdgeCluster"
47
+ optional :appliance_cluster, :message, 10, "google.cloud.gkehub.v1beta1.ApplianceCluster"
45
48
  end
46
49
  end
47
50
  add_message "google.cloud.gkehub.v1beta1.KubernetesResource" do
@@ -53,6 +56,7 @@ Google::Protobuf::DescriptorPool.generated_pool.build do
53
56
  add_message "google.cloud.gkehub.v1beta1.ResourceOptions" do
54
57
  optional :connect_version, :string, 1
55
58
  optional :v1beta1_crd, :bool, 2
59
+ optional :k8s_version, :string, 3
56
60
  end
57
61
  add_message "google.cloud.gkehub.v1beta1.ResourceManifest" do
58
62
  optional :manifest, :string, 1
@@ -66,11 +70,25 @@ Google::Protobuf::DescriptorPool.generated_pool.build do
66
70
  optional :resource_link, :string, 1
67
71
  optional :cluster_missing, :bool, 2
68
72
  optional :admin_cluster, :bool, 3
73
+ optional :cluster_type, :enum, 4, "google.cloud.gkehub.v1beta1.OnPremCluster.ClusterType"
74
+ end
75
+ add_enum "google.cloud.gkehub.v1beta1.OnPremCluster.ClusterType" do
76
+ value :CLUSTERTYPE_UNSPECIFIED, 0
77
+ value :BOOTSTRAP, 1
78
+ value :HYBRID, 2
79
+ value :STANDALONE, 3
80
+ value :USER, 4
69
81
  end
70
82
  add_message "google.cloud.gkehub.v1beta1.MultiCloudCluster" do
71
83
  optional :resource_link, :string, 1
72
84
  optional :cluster_missing, :bool, 2
73
85
  end
86
+ add_message "google.cloud.gkehub.v1beta1.EdgeCluster" do
87
+ optional :resource_link, :string, 1
88
+ end
89
+ add_message "google.cloud.gkehub.v1beta1.ApplianceCluster" do
90
+ optional :resource_link, :string, 1
91
+ end
74
92
  add_message "google.cloud.gkehub.v1beta1.KubernetesMetadata" do
75
93
  optional :kubernetes_api_server_version, :string, 1
76
94
  optional :node_provider_id, :string, 2
@@ -194,7 +212,10 @@ module Google
194
212
  ResourceManifest = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.ResourceManifest").msgclass
195
213
  GkeCluster = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.GkeCluster").msgclass
196
214
  OnPremCluster = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.OnPremCluster").msgclass
215
+ OnPremCluster::ClusterType = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.OnPremCluster.ClusterType").enummodule
197
216
  MultiCloudCluster = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.MultiCloudCluster").msgclass
217
+ EdgeCluster = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.EdgeCluster").msgclass
218
+ ApplianceCluster = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.ApplianceCluster").msgclass
198
219
  KubernetesMetadata = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.KubernetesMetadata").msgclass
199
220
  Authority = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.Authority").msgclass
200
221
  MembershipState = ::Google::Protobuf::DescriptorPool.generated_pool.lookup("google.cloud.gkehub.v1beta1.MembershipState").msgclass
@@ -33,11 +33,7 @@ module Google
33
33
  # // For Kubernetes resources, the format is {api group}/{kind}.
34
34
  # option (google.api.resource) = {
35
35
  # type: "pubsub.googleapis.com/Topic"
36
- # name_descriptor: {
37
- # pattern: "projects/{project}/topics/{topic}"
38
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
39
- # parent_name_extractor: "projects/{project}"
40
- # }
36
+ # pattern: "projects/{project}/topics/{topic}"
41
37
  # };
42
38
  # }
43
39
  #
@@ -45,10 +41,7 @@ module Google
45
41
  #
46
42
  # resources:
47
43
  # - type: "pubsub.googleapis.com/Topic"
48
- # name_descriptor:
49
- # - pattern: "projects/{project}/topics/{topic}"
50
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
51
- # parent_name_extractor: "projects/{project}"
44
+ # pattern: "projects/{project}/topics/{topic}"
52
45
  #
53
46
  # Sometimes, resources have multiple patterns, typically because they can
54
47
  # live under multiple parents.
@@ -58,26 +51,10 @@ module Google
58
51
  # message LogEntry {
59
52
  # option (google.api.resource) = {
60
53
  # type: "logging.googleapis.com/LogEntry"
61
- # name_descriptor: {
62
- # pattern: "projects/{project}/logs/{log}"
63
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
64
- # parent_name_extractor: "projects/{project}"
65
- # }
66
- # name_descriptor: {
67
- # pattern: "folders/{folder}/logs/{log}"
68
- # parent_type: "cloudresourcemanager.googleapis.com/Folder"
69
- # parent_name_extractor: "folders/{folder}"
70
- # }
71
- # name_descriptor: {
72
- # pattern: "organizations/{organization}/logs/{log}"
73
- # parent_type: "cloudresourcemanager.googleapis.com/Organization"
74
- # parent_name_extractor: "organizations/{organization}"
75
- # }
76
- # name_descriptor: {
77
- # pattern: "billingAccounts/{billing_account}/logs/{log}"
78
- # parent_type: "billing.googleapis.com/BillingAccount"
79
- # parent_name_extractor: "billingAccounts/{billing_account}"
80
- # }
54
+ # pattern: "projects/{project}/logs/{log}"
55
+ # pattern: "folders/{folder}/logs/{log}"
56
+ # pattern: "organizations/{organization}/logs/{log}"
57
+ # pattern: "billingAccounts/{billing_account}/logs/{log}"
81
58
  # };
82
59
  # }
83
60
  #
@@ -85,48 +62,10 @@ module Google
85
62
  #
86
63
  # resources:
87
64
  # - type: 'logging.googleapis.com/LogEntry'
88
- # name_descriptor:
89
- # - pattern: "projects/{project}/logs/{log}"
90
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
91
- # parent_name_extractor: "projects/{project}"
92
- # - pattern: "folders/{folder}/logs/{log}"
93
- # parent_type: "cloudresourcemanager.googleapis.com/Folder"
94
- # parent_name_extractor: "folders/{folder}"
95
- # - pattern: "organizations/{organization}/logs/{log}"
96
- # parent_type: "cloudresourcemanager.googleapis.com/Organization"
97
- # parent_name_extractor: "organizations/{organization}"
98
- # - pattern: "billingAccounts/{billing_account}/logs/{log}"
99
- # parent_type: "billing.googleapis.com/BillingAccount"
100
- # parent_name_extractor: "billingAccounts/{billing_account}"
101
- #
102
- # For flexible resources, the resource name doesn't contain parent names, but
103
- # the resource itself has parents for policy evaluation.
104
- #
105
- # Example:
106
- #
107
- # message Shelf {
108
- # option (google.api.resource) = {
109
- # type: "library.googleapis.com/Shelf"
110
- # name_descriptor: {
111
- # pattern: "shelves/{shelf}"
112
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
113
- # }
114
- # name_descriptor: {
115
- # pattern: "shelves/{shelf}"
116
- # parent_type: "cloudresourcemanager.googleapis.com/Folder"
117
- # }
118
- # };
119
- # }
120
- #
121
- # The ResourceDescriptor Yaml config will look like:
122
- #
123
- # resources:
124
- # - type: 'library.googleapis.com/Shelf'
125
- # name_descriptor:
126
- # - pattern: "shelves/{shelf}"
127
- # parent_type: "cloudresourcemanager.googleapis.com/Project"
128
- # - pattern: "shelves/{shelf}"
129
- # parent_type: "cloudresourcemanager.googleapis.com/Folder"
65
+ # pattern: "projects/{project}/logs/{log}"
66
+ # pattern: "folders/{folder}/logs/{log}"
67
+ # pattern: "organizations/{organization}/logs/{log}"
68
+ # pattern: "billingAccounts/{billing_account}/logs/{log}"
130
69
  # @!attribute [rw] type
131
70
  # @return [::String]
132
71
  # The resource type. It must be in the format of
@@ -126,10 +126,18 @@ module Google
126
126
  # Optional. Specific information for a GKE-on-GCP cluster.
127
127
  # @!attribute [rw] on_prem_cluster
128
128
  # @return [::Google::Cloud::GkeHub::V1beta1::OnPremCluster]
129
- # Optional. Specific information for a GKE On-Prem cluster.
129
+ # Optional. Specific information for a GKE On-Prem cluster. An onprem user-cluster
130
+ # who has no resourceLink is not allowed to use this field, it should have
131
+ # a nil "type" instead.
130
132
  # @!attribute [rw] multi_cloud_cluster
131
133
  # @return [::Google::Cloud::GkeHub::V1beta1::MultiCloudCluster]
132
134
  # Optional. Specific information for a GKE Multi-Cloud cluster.
135
+ # @!attribute [rw] edge_cluster
136
+ # @return [::Google::Cloud::GkeHub::V1beta1::EdgeCluster]
137
+ # Optional. Specific information for a Google Edge cluster.
138
+ # @!attribute [rw] appliance_cluster
139
+ # @return [::Google::Cloud::GkeHub::V1beta1::ApplianceCluster]
140
+ # Optional. Specific information for a GDC Edge Appliance cluster.
133
141
  # @!attribute [r] kubernetes_metadata
134
142
  # @return [::Google::Cloud::GkeHub::V1beta1::KubernetesMetadata]
135
143
  # Output only. Useful Kubernetes-specific metadata.
@@ -199,6 +207,11 @@ module Google
199
207
  # CustomResourceDefinition resources.
200
208
  # This option should be set for clusters with Kubernetes apiserver versions
201
209
  # <1.16.
210
+ # @!attribute [rw] k8s_version
211
+ # @return [::String]
212
+ # Optional. Major version of the Kubernetes cluster. This is only used to determine
213
+ # which version to use for the CustomResourceDefinition resources,
214
+ # `apiextensions/v1beta1` or`apiextensions/v1`.
202
215
  class ResourceOptions
203
216
  include ::Google::Protobuf::MessageExts
204
217
  extend ::Google::Protobuf::MessageExts::ClassMethods
@@ -253,9 +266,30 @@ module Google
253
266
  # @!attribute [rw] admin_cluster
254
267
  # @return [::Boolean]
255
268
  # Immutable. Whether the cluster is an admin cluster.
269
+ # @!attribute [rw] cluster_type
270
+ # @return [::Google::Cloud::GkeHub::V1beta1::OnPremCluster::ClusterType]
271
+ # Immutable. The on prem cluster's type.
256
272
  class OnPremCluster
257
273
  include ::Google::Protobuf::MessageExts
258
274
  extend ::Google::Protobuf::MessageExts::ClassMethods
275
+
276
+ # ClusterType describes on prem cluster's type.
277
+ module ClusterType
278
+ # The ClusterType is not set.
279
+ CLUSTERTYPE_UNSPECIFIED = 0
280
+
281
+ # The ClusterType is bootstrap cluster.
282
+ BOOTSTRAP = 1
283
+
284
+ # The ClusterType is baremetal hybrid cluster.
285
+ HYBRID = 2
286
+
287
+ # The ClusterType is baremetal standalone cluster.
288
+ STANDALONE = 3
289
+
290
+ # The ClusterType is user cluster.
291
+ USER = 4
292
+ end
259
293
  end
260
294
 
261
295
  # MultiCloudCluster contains information specific to GKE Multi-Cloud clusters.
@@ -276,6 +310,31 @@ module Google
276
310
  extend ::Google::Protobuf::MessageExts::ClassMethods
277
311
  end
278
312
 
313
+ # EdgeCluster contains information specific to Google Edge Clusters.
314
+ # @!attribute [rw] resource_link
315
+ # @return [::String]
316
+ # Immutable. Self-link of the GCP resource for the Edge Cluster. For
317
+ # example:
318
+ #
319
+ # //edgecontainer.googleapis.com/projects/my-project/locations/us-west1-a/clusters/my-cluster
320
+ class EdgeCluster
321
+ include ::Google::Protobuf::MessageExts
322
+ extend ::Google::Protobuf::MessageExts::ClassMethods
323
+ end
324
+
325
+ # ApplianceCluster contains information specific to GDC Edge Appliance
326
+ # Clusters.
327
+ # @!attribute [rw] resource_link
328
+ # @return [::String]
329
+ # Immutable. Self-link of the GCP resource for the Appliance Cluster. For
330
+ # example:
331
+ #
332
+ # //transferappliance.googleapis.com/projects/my-project/locations/us-west1-a/appliances/my-appliance
333
+ class ApplianceCluster
334
+ include ::Google::Protobuf::MessageExts
335
+ extend ::Google::Protobuf::MessageExts::ClassMethods
336
+ end
337
+
279
338
  # KubernetesMetadata provides informational metadata for Memberships
280
339
  # representing Kubernetes clusters.
281
340
  # @!attribute [r] kubernetes_api_server_version
@@ -0,0 +1,87 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://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,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Iam
22
+ module V1
23
+ # Request message for `SetIamPolicy` method.
24
+ # @!attribute [rw] resource
25
+ # @return [::String]
26
+ # REQUIRED: The resource for which the policy is being specified.
27
+ # See the operation documentation for the appropriate value for this field.
28
+ # @!attribute [rw] policy
29
+ # @return [::Google::Iam::V1::Policy]
30
+ # REQUIRED: The complete policy to be applied to the `resource`. The size of
31
+ # the policy is limited to a few 10s of KB. An empty policy is a
32
+ # valid policy but certain Cloud Platform services (such as Projects)
33
+ # might reject them.
34
+ # @!attribute [rw] update_mask
35
+ # @return [::Google::Protobuf::FieldMask]
36
+ # OPTIONAL: A FieldMask specifying which fields of the policy to modify. Only
37
+ # the fields in the mask will be modified. If no mask is provided, the
38
+ # following default mask is used:
39
+ #
40
+ # `paths: "bindings, etag"`
41
+ class SetIamPolicyRequest
42
+ include ::Google::Protobuf::MessageExts
43
+ extend ::Google::Protobuf::MessageExts::ClassMethods
44
+ end
45
+
46
+ # Request message for `GetIamPolicy` method.
47
+ # @!attribute [rw] resource
48
+ # @return [::String]
49
+ # REQUIRED: The resource for which the policy is being requested.
50
+ # See the operation documentation for the appropriate value for this field.
51
+ # @!attribute [rw] options
52
+ # @return [::Google::Iam::V1::GetPolicyOptions]
53
+ # OPTIONAL: A `GetPolicyOptions` object for specifying options to
54
+ # `GetIamPolicy`.
55
+ class GetIamPolicyRequest
56
+ include ::Google::Protobuf::MessageExts
57
+ extend ::Google::Protobuf::MessageExts::ClassMethods
58
+ end
59
+
60
+ # Request message for `TestIamPermissions` method.
61
+ # @!attribute [rw] resource
62
+ # @return [::String]
63
+ # REQUIRED: The resource for which the policy detail is being requested.
64
+ # See the operation documentation for the appropriate value for this field.
65
+ # @!attribute [rw] permissions
66
+ # @return [::Array<::String>]
67
+ # The set of permissions to check for the `resource`. Permissions with
68
+ # wildcards (such as '*' or 'storage.*') are not allowed. For more
69
+ # information see
70
+ # [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions).
71
+ class TestIamPermissionsRequest
72
+ include ::Google::Protobuf::MessageExts
73
+ extend ::Google::Protobuf::MessageExts::ClassMethods
74
+ end
75
+
76
+ # Response message for `TestIamPermissions` method.
77
+ # @!attribute [rw] permissions
78
+ # @return [::Array<::String>]
79
+ # A subset of `TestPermissionsRequest.permissions` that the caller is
80
+ # allowed.
81
+ class TestIamPermissionsResponse
82
+ include ::Google::Protobuf::MessageExts
83
+ extend ::Google::Protobuf::MessageExts::ClassMethods
84
+ end
85
+ end
86
+ end
87
+ end
@@ -0,0 +1,50 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://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,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Iam
22
+ module V1
23
+ # Encapsulates settings provided to GetIamPolicy.
24
+ # @!attribute [rw] requested_policy_version
25
+ # @return [::Integer]
26
+ # Optional. The maximum policy version that will be used to format the
27
+ # policy.
28
+ #
29
+ # Valid values are 0, 1, and 3. Requests specifying an invalid value will be
30
+ # rejected.
31
+ #
32
+ # Requests for policies with any conditional role bindings must specify
33
+ # version 3. Policies with no conditional role bindings may specify any valid
34
+ # value or leave the field unset.
35
+ #
36
+ # The policy in the response might use the policy version that you specified,
37
+ # or it might use a lower policy version. For example, if you specify version
38
+ # 3, but the policy has no conditional role bindings, the response uses
39
+ # version 1.
40
+ #
41
+ # To learn which resources support conditions in their IAM policies, see the
42
+ # [IAM
43
+ # documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
44
+ class GetPolicyOptions
45
+ include ::Google::Protobuf::MessageExts
46
+ extend ::Google::Protobuf::MessageExts::ClassMethods
47
+ end
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,418 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://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,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Iam
22
+ module V1
23
+ # An Identity and Access Management (IAM) policy, which specifies access
24
+ # controls for Google Cloud resources.
25
+ #
26
+ #
27
+ # A `Policy` is a collection of `bindings`. A `binding` binds one or more
28
+ # `members`, or principals, to a single `role`. Principals can be user
29
+ # accounts, service accounts, Google groups, and domains (such as G Suite). A
30
+ # `role` is a named list of permissions; each `role` can be an IAM predefined
31
+ # role or a user-created custom role.
32
+ #
33
+ # For some types of Google Cloud resources, a `binding` can also specify a
34
+ # `condition`, which is a logical expression that allows access to a resource
35
+ # only if the expression evaluates to `true`. A condition can add constraints
36
+ # based on attributes of the request, the resource, or both. To learn which
37
+ # resources support conditions in their IAM policies, see the
38
+ # [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
39
+ #
40
+ # **JSON example:**
41
+ #
42
+ # {
43
+ # "bindings": [
44
+ # {
45
+ # "role": "roles/resourcemanager.organizationAdmin",
46
+ # "members": [
47
+ # "user:mike@example.com",
48
+ # "group:admins@example.com",
49
+ # "domain:google.com",
50
+ # "serviceAccount:my-project-id@appspot.gserviceaccount.com"
51
+ # ]
52
+ # },
53
+ # {
54
+ # "role": "roles/resourcemanager.organizationViewer",
55
+ # "members": [
56
+ # "user:eve@example.com"
57
+ # ],
58
+ # "condition": {
59
+ # "title": "expirable access",
60
+ # "description": "Does not grant access after Sep 2020",
61
+ # "expression": "request.time < timestamp('2020-10-01T00:00:00.000Z')",
62
+ # }
63
+ # }
64
+ # ],
65
+ # "etag": "BwWWja0YfJA=",
66
+ # "version": 3
67
+ # }
68
+ #
69
+ # **YAML example:**
70
+ #
71
+ # bindings:
72
+ # - members:
73
+ # - user:mike@example.com
74
+ # - group:admins@example.com
75
+ # - domain:google.com
76
+ # - serviceAccount:my-project-id@appspot.gserviceaccount.com
77
+ # role: roles/resourcemanager.organizationAdmin
78
+ # - members:
79
+ # - user:eve@example.com
80
+ # role: roles/resourcemanager.organizationViewer
81
+ # condition:
82
+ # title: expirable access
83
+ # description: Does not grant access after Sep 2020
84
+ # expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
85
+ # etag: BwWWja0YfJA=
86
+ # version: 3
87
+ #
88
+ # For a description of IAM and its features, see the
89
+ # [IAM documentation](https://cloud.google.com/iam/docs/).
90
+ # @!attribute [rw] version
91
+ # @return [::Integer]
92
+ # Specifies the format of the policy.
93
+ #
94
+ # Valid values are `0`, `1`, and `3`. Requests that specify an invalid value
95
+ # are rejected.
96
+ #
97
+ # Any operation that affects conditional role bindings must specify version
98
+ # `3`. This requirement applies to the following operations:
99
+ #
100
+ # * Getting a policy that includes a conditional role binding
101
+ # * Adding a conditional role binding to a policy
102
+ # * Changing a conditional role binding in a policy
103
+ # * Removing any role binding, with or without a condition, from a policy
104
+ # that includes conditions
105
+ #
106
+ # **Important:** If you use IAM Conditions, you must include the `etag` field
107
+ # whenever you call `setIamPolicy`. If you omit this field, then IAM allows
108
+ # you to overwrite a version `3` policy with a version `1` policy, and all of
109
+ # the conditions in the version `3` policy are lost.
110
+ #
111
+ # If a policy does not include any conditions, operations on that policy may
112
+ # specify any valid version or leave the field unset.
113
+ #
114
+ # To learn which resources support conditions in their IAM policies, see the
115
+ # [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
116
+ # @!attribute [rw] bindings
117
+ # @return [::Array<::Google::Iam::V1::Binding>]
118
+ # Associates a list of `members`, or principals, with a `role`. Optionally,
119
+ # may specify a `condition` that determines how and when the `bindings` are
120
+ # applied. Each of the `bindings` must contain at least one principal.
121
+ #
122
+ # The `bindings` in a `Policy` can refer to up to 1,500 principals; up to 250
123
+ # of these principals can be Google groups. Each occurrence of a principal
124
+ # counts towards these limits. For example, if the `bindings` grant 50
125
+ # different roles to `user:alice@example.com`, and not to any other
126
+ # principal, then you can add another 1,450 principals to the `bindings` in
127
+ # the `Policy`.
128
+ # @!attribute [rw] audit_configs
129
+ # @return [::Array<::Google::Iam::V1::AuditConfig>]
130
+ # Specifies cloud audit logging configuration for this policy.
131
+ # @!attribute [rw] etag
132
+ # @return [::String]
133
+ # `etag` is used for optimistic concurrency control as a way to help
134
+ # prevent simultaneous updates of a policy from overwriting each other.
135
+ # It is strongly suggested that systems make use of the `etag` in the
136
+ # read-modify-write cycle to perform policy updates in order to avoid race
137
+ # conditions: An `etag` is returned in the response to `getIamPolicy`, and
138
+ # systems are expected to put that etag in the request to `setIamPolicy` to
139
+ # ensure that their change will be applied to the same version of the policy.
140
+ #
141
+ # **Important:** If you use IAM Conditions, you must include the `etag` field
142
+ # whenever you call `setIamPolicy`. If you omit this field, then IAM allows
143
+ # you to overwrite a version `3` policy with a version `1` policy, and all of
144
+ # the conditions in the version `3` policy are lost.
145
+ class Policy
146
+ include ::Google::Protobuf::MessageExts
147
+ extend ::Google::Protobuf::MessageExts::ClassMethods
148
+ end
149
+
150
+ # Associates `members`, or principals, with a `role`.
151
+ # @!attribute [rw] role
152
+ # @return [::String]
153
+ # Role that is assigned to the list of `members`, or principals.
154
+ # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
155
+ # @!attribute [rw] members
156
+ # @return [::Array<::String>]
157
+ # Specifies the principals requesting access for a Cloud Platform resource.
158
+ # `members` can have the following values:
159
+ #
160
+ # * `allUsers`: A special identifier that represents anyone who is
161
+ # on the internet; with or without a Google account.
162
+ #
163
+ # * `allAuthenticatedUsers`: A special identifier that represents anyone
164
+ # who is authenticated with a Google account or a service account.
165
+ #
166
+ # * `user:{emailid}`: An email address that represents a specific Google
167
+ # account. For example, `alice@example.com` .
168
+ #
169
+ #
170
+ # * `serviceAccount:{emailid}`: An email address that represents a service
171
+ # account. For example, `my-other-app@appspot.gserviceaccount.com`.
172
+ #
173
+ # * `group:{emailid}`: An email address that represents a Google group.
174
+ # For example, `admins@example.com`.
175
+ #
176
+ # * `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique
177
+ # identifier) representing a user that has been recently deleted. For
178
+ # example, `alice@example.com?uid=123456789012345678901`. If the user is
179
+ # recovered, this value reverts to `user:{emailid}` and the recovered user
180
+ # retains the role in the binding.
181
+ #
182
+ # * `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus
183
+ # unique identifier) representing a service account that has been recently
184
+ # deleted. For example,
185
+ # `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`.
186
+ # If the service account is undeleted, this value reverts to
187
+ # `serviceAccount:{emailid}` and the undeleted service account retains the
188
+ # role in the binding.
189
+ #
190
+ # * `deleted:group:{emailid}?uid={uniqueid}`: An email address (plus unique
191
+ # identifier) representing a Google group that has been recently
192
+ # deleted. For example, `admins@example.com?uid=123456789012345678901`. If
193
+ # the group is recovered, this value reverts to `group:{emailid}` and the
194
+ # recovered group retains the role in the binding.
195
+ #
196
+ #
197
+ # * `domain:{domain}`: The G Suite domain (primary) that represents all the
198
+ # users of that domain. For example, `google.com` or `example.com`.
199
+ # @!attribute [rw] condition
200
+ # @return [::Google::Type::Expr]
201
+ # The condition that is associated with this binding.
202
+ #
203
+ # If the condition evaluates to `true`, then this binding applies to the
204
+ # current request.
205
+ #
206
+ # If the condition evaluates to `false`, then this binding does not apply to
207
+ # the current request. However, a different role binding might grant the same
208
+ # role to one or more of the principals in this binding.
209
+ #
210
+ # To learn which resources support conditions in their IAM policies, see the
211
+ # [IAM
212
+ # documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
213
+ class Binding
214
+ include ::Google::Protobuf::MessageExts
215
+ extend ::Google::Protobuf::MessageExts::ClassMethods
216
+ end
217
+
218
+ # Specifies the audit configuration for a service.
219
+ # The configuration determines which permission types are logged, and what
220
+ # identities, if any, are exempted from logging.
221
+ # An AuditConfig must have one or more AuditLogConfigs.
222
+ #
223
+ # If there are AuditConfigs for both `allServices` and a specific service,
224
+ # the union of the two AuditConfigs is used for that service: the log_types
225
+ # specified in each AuditConfig are enabled, and the exempted_members in each
226
+ # AuditLogConfig are exempted.
227
+ #
228
+ # Example Policy with multiple AuditConfigs:
229
+ #
230
+ # {
231
+ # "audit_configs": [
232
+ # {
233
+ # "service": "allServices",
234
+ # "audit_log_configs": [
235
+ # {
236
+ # "log_type": "DATA_READ",
237
+ # "exempted_members": [
238
+ # "user:jose@example.com"
239
+ # ]
240
+ # },
241
+ # {
242
+ # "log_type": "DATA_WRITE"
243
+ # },
244
+ # {
245
+ # "log_type": "ADMIN_READ"
246
+ # }
247
+ # ]
248
+ # },
249
+ # {
250
+ # "service": "sampleservice.googleapis.com",
251
+ # "audit_log_configs": [
252
+ # {
253
+ # "log_type": "DATA_READ"
254
+ # },
255
+ # {
256
+ # "log_type": "DATA_WRITE",
257
+ # "exempted_members": [
258
+ # "user:aliya@example.com"
259
+ # ]
260
+ # }
261
+ # ]
262
+ # }
263
+ # ]
264
+ # }
265
+ #
266
+ # For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ
267
+ # logging. It also exempts jose@example.com from DATA_READ logging, and
268
+ # aliya@example.com from DATA_WRITE logging.
269
+ # @!attribute [rw] service
270
+ # @return [::String]
271
+ # Specifies a service that will be enabled for audit logging.
272
+ # For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
273
+ # `allServices` is a special value that covers all services.
274
+ # @!attribute [rw] audit_log_configs
275
+ # @return [::Array<::Google::Iam::V1::AuditLogConfig>]
276
+ # The configuration for logging of each type of permission.
277
+ class AuditConfig
278
+ include ::Google::Protobuf::MessageExts
279
+ extend ::Google::Protobuf::MessageExts::ClassMethods
280
+ end
281
+
282
+ # Provides the configuration for logging a type of permissions.
283
+ # Example:
284
+ #
285
+ # {
286
+ # "audit_log_configs": [
287
+ # {
288
+ # "log_type": "DATA_READ",
289
+ # "exempted_members": [
290
+ # "user:jose@example.com"
291
+ # ]
292
+ # },
293
+ # {
294
+ # "log_type": "DATA_WRITE"
295
+ # }
296
+ # ]
297
+ # }
298
+ #
299
+ # This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting
300
+ # jose@example.com from DATA_READ logging.
301
+ # @!attribute [rw] log_type
302
+ # @return [::Google::Iam::V1::AuditLogConfig::LogType]
303
+ # The log type that this config enables.
304
+ # @!attribute [rw] exempted_members
305
+ # @return [::Array<::String>]
306
+ # Specifies the identities that do not cause logging for this type of
307
+ # permission.
308
+ # Follows the same format of {::Google::Iam::V1::Binding#members Binding.members}.
309
+ class AuditLogConfig
310
+ include ::Google::Protobuf::MessageExts
311
+ extend ::Google::Protobuf::MessageExts::ClassMethods
312
+
313
+ # The list of valid permission types for which logging can be configured.
314
+ # Admin writes are always logged, and are not configurable.
315
+ module LogType
316
+ # Default case. Should never be this.
317
+ LOG_TYPE_UNSPECIFIED = 0
318
+
319
+ # Admin reads. Example: CloudIAM getIamPolicy
320
+ ADMIN_READ = 1
321
+
322
+ # Data writes. Example: CloudSQL Users create
323
+ DATA_WRITE = 2
324
+
325
+ # Data reads. Example: CloudSQL Users list
326
+ DATA_READ = 3
327
+ end
328
+ end
329
+
330
+ # The difference delta between two policies.
331
+ # @!attribute [rw] binding_deltas
332
+ # @return [::Array<::Google::Iam::V1::BindingDelta>]
333
+ # The delta for Bindings between two policies.
334
+ # @!attribute [rw] audit_config_deltas
335
+ # @return [::Array<::Google::Iam::V1::AuditConfigDelta>]
336
+ # The delta for AuditConfigs between two policies.
337
+ class PolicyDelta
338
+ include ::Google::Protobuf::MessageExts
339
+ extend ::Google::Protobuf::MessageExts::ClassMethods
340
+ end
341
+
342
+ # One delta entry for Binding. Each individual change (only one member in each
343
+ # entry) to a binding will be a separate entry.
344
+ # @!attribute [rw] action
345
+ # @return [::Google::Iam::V1::BindingDelta::Action]
346
+ # The action that was performed on a Binding.
347
+ # Required
348
+ # @!attribute [rw] role
349
+ # @return [::String]
350
+ # Role that is assigned to `members`.
351
+ # For example, `roles/viewer`, `roles/editor`, or `roles/owner`.
352
+ # Required
353
+ # @!attribute [rw] member
354
+ # @return [::String]
355
+ # A single identity requesting access for a Cloud Platform resource.
356
+ # Follows the same format of Binding.members.
357
+ # Required
358
+ # @!attribute [rw] condition
359
+ # @return [::Google::Type::Expr]
360
+ # The condition that is associated with this binding.
361
+ class BindingDelta
362
+ include ::Google::Protobuf::MessageExts
363
+ extend ::Google::Protobuf::MessageExts::ClassMethods
364
+
365
+ # The type of action performed on a Binding in a policy.
366
+ module Action
367
+ # Unspecified.
368
+ ACTION_UNSPECIFIED = 0
369
+
370
+ # Addition of a Binding.
371
+ ADD = 1
372
+
373
+ # Removal of a Binding.
374
+ REMOVE = 2
375
+ end
376
+ end
377
+
378
+ # One delta entry for AuditConfig. Each individual change (only one
379
+ # exempted_member in each entry) to a AuditConfig will be a separate entry.
380
+ # @!attribute [rw] action
381
+ # @return [::Google::Iam::V1::AuditConfigDelta::Action]
382
+ # The action that was performed on an audit configuration in a policy.
383
+ # Required
384
+ # @!attribute [rw] service
385
+ # @return [::String]
386
+ # Specifies a service that was configured for Cloud Audit Logging.
387
+ # For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
388
+ # `allServices` is a special value that covers all services.
389
+ # Required
390
+ # @!attribute [rw] exempted_member
391
+ # @return [::String]
392
+ # A single identity that is exempted from "data access" audit
393
+ # logging for the `service` specified above.
394
+ # Follows the same format of Binding.members.
395
+ # @!attribute [rw] log_type
396
+ # @return [::String]
397
+ # Specifies the log_type that was be enabled. ADMIN_ACTIVITY is always
398
+ # enabled, and cannot be configured.
399
+ # Required
400
+ class AuditConfigDelta
401
+ include ::Google::Protobuf::MessageExts
402
+ extend ::Google::Protobuf::MessageExts::ClassMethods
403
+
404
+ # The type of action performed on an audit configuration in a policy.
405
+ module Action
406
+ # Unspecified.
407
+ ACTION_UNSPECIFIED = 0
408
+
409
+ # Addition of an audit configuration.
410
+ ADD = 1
411
+
412
+ # Removal of an audit configuration.
413
+ REMOVE = 2
414
+ end
415
+ end
416
+ end
417
+ end
418
+ end
@@ -44,7 +44,7 @@ module Google
44
44
  # foo = any.unpack(Foo.class);
45
45
  # }
46
46
  #
47
- # Example 3: Pack and unpack a message in Python.
47
+ # Example 3: Pack and unpack a message in Python.
48
48
  #
49
49
  # foo = Foo(...)
50
50
  # any = Any()
@@ -54,7 +54,7 @@ module Google
54
54
  # any.Unpack(foo)
55
55
  # ...
56
56
  #
57
- # Example 4: Pack and unpack a message in Go
57
+ # Example 4: Pack and unpack a message in Go
58
58
  #
59
59
  # foo := &pb.Foo{...}
60
60
  # any, err := anypb.New(foo)
@@ -75,7 +75,7 @@ module Google
75
75
  #
76
76
  #
77
77
  # JSON
78
- # ====
78
+ #
79
79
  # The JSON representation of an `Any` value uses the regular
80
80
  # representation of the deserialized, embedded message, with an
81
81
  # additional field `@type` which contains the type URL. Example:
@@ -0,0 +1,75 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Copyright 2022 Google LLC
4
+ #
5
+ # Licensed under the Apache License, Version 2.0 (the "License");
6
+ # you may not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # https://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,
13
+ # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ # See the License for the specific language governing permissions and
15
+ # limitations under the License.
16
+
17
+ # Auto-generated by gapic-generator-ruby. DO NOT EDIT!
18
+
19
+
20
+ module Google
21
+ module Type
22
+ # Represents a textual expression in the Common Expression Language (CEL)
23
+ # syntax. CEL is a C-like expression language. The syntax and semantics of CEL
24
+ # are documented at https://github.com/google/cel-spec.
25
+ #
26
+ # Example (Comparison):
27
+ #
28
+ # title: "Summary size limit"
29
+ # description: "Determines if a summary is less than 100 chars"
30
+ # expression: "document.summary.size() < 100"
31
+ #
32
+ # Example (Equality):
33
+ #
34
+ # title: "Requestor is owner"
35
+ # description: "Determines if requestor is the document owner"
36
+ # expression: "document.owner == request.auth.claims.email"
37
+ #
38
+ # Example (Logic):
39
+ #
40
+ # title: "Public documents"
41
+ # description: "Determine whether the document should be publicly visible"
42
+ # expression: "document.type != 'private' && document.type != 'internal'"
43
+ #
44
+ # Example (Data Manipulation):
45
+ #
46
+ # title: "Notification string"
47
+ # description: "Create a notification string with a timestamp."
48
+ # expression: "'New message received at ' + string(document.create_time)"
49
+ #
50
+ # The exact variables and functions that may be referenced within an expression
51
+ # are determined by the service that evaluates it. See the service
52
+ # documentation for additional information.
53
+ # @!attribute [rw] expression
54
+ # @return [::String]
55
+ # Textual representation of an expression in Common Expression Language
56
+ # syntax.
57
+ # @!attribute [rw] title
58
+ # @return [::String]
59
+ # Optional. Title for the expression, i.e. a short string describing
60
+ # its purpose. This can be used e.g. in UIs which allow to enter the
61
+ # expression.
62
+ # @!attribute [rw] description
63
+ # @return [::String]
64
+ # Optional. Description of the expression. This is a longer text which
65
+ # describes the expression, e.g. when hovered over it in a UI.
66
+ # @!attribute [rw] location
67
+ # @return [::String]
68
+ # Optional. String indicating the location of the expression for error
69
+ # reporting, e.g. a file name and a position in the file.
70
+ class Expr
71
+ include ::Google::Protobuf::MessageExts
72
+ extend ::Google::Protobuf::MessageExts::ClassMethods
73
+ end
74
+ end
75
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: google-cloud-gke_hub-v1beta1
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.1
4
+ version: 0.4.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Google LLC
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-11-08 00:00:00.000000000 Z
11
+ date: 2022-06-17 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: gapic-common
@@ -44,6 +44,46 @@ dependencies:
44
44
  - - "~>"
45
45
  - !ruby/object:Gem::Version
46
46
  version: '1.0'
47
+ - !ruby/object:Gem::Dependency
48
+ name: google-cloud-location
49
+ requirement: !ruby/object:Gem::Requirement
50
+ requirements:
51
+ - - ">="
52
+ - !ruby/object:Gem::Version
53
+ version: '0.0'
54
+ - - "<"
55
+ - !ruby/object:Gem::Version
56
+ version: 2.a
57
+ type: :runtime
58
+ prerelease: false
59
+ version_requirements: !ruby/object:Gem::Requirement
60
+ requirements:
61
+ - - ">="
62
+ - !ruby/object:Gem::Version
63
+ version: '0.0'
64
+ - - "<"
65
+ - !ruby/object:Gem::Version
66
+ version: 2.a
67
+ - !ruby/object:Gem::Dependency
68
+ name: google-iam-v1
69
+ requirement: !ruby/object:Gem::Requirement
70
+ requirements:
71
+ - - ">="
72
+ - !ruby/object:Gem::Version
73
+ version: '0.0'
74
+ - - "<"
75
+ - !ruby/object:Gem::Version
76
+ version: 2.a
77
+ type: :runtime
78
+ prerelease: false
79
+ version_requirements: !ruby/object:Gem::Requirement
80
+ requirements:
81
+ - - ">="
82
+ - !ruby/object:Gem::Version
83
+ version: '0.0'
84
+ - - "<"
85
+ - !ruby/object:Gem::Version
86
+ version: 2.a
47
87
  - !ruby/object:Gem::Dependency
48
88
  name: google-style
49
89
  requirement: !ruby/object:Gem::Requirement
@@ -184,6 +224,9 @@ files:
184
224
  - proto_docs/google/api/field_behavior.rb
185
225
  - proto_docs/google/api/resource.rb
186
226
  - proto_docs/google/cloud/gkehub/v1beta1/membership.rb
227
+ - proto_docs/google/iam/v1/iam_policy.rb
228
+ - proto_docs/google/iam/v1/options.rb
229
+ - proto_docs/google/iam/v1/policy.rb
187
230
  - proto_docs/google/longrunning/operations.rb
188
231
  - proto_docs/google/protobuf/any.rb
189
232
  - proto_docs/google/protobuf/duration.rb
@@ -191,6 +234,7 @@ files:
191
234
  - proto_docs/google/protobuf/field_mask.rb
192
235
  - proto_docs/google/protobuf/timestamp.rb
193
236
  - proto_docs/google/rpc/status.rb
237
+ - proto_docs/google/type/expr.rb
194
238
  homepage: https://github.com/googleapis/google-cloud-ruby
195
239
  licenses:
196
240
  - Apache-2.0
@@ -210,7 +254,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
210
254
  - !ruby/object:Gem::Version
211
255
  version: '0'
212
256
  requirements: []
213
- rubygems_version: 3.2.17
257
+ rubygems_version: 3.3.14
214
258
  signing_key:
215
259
  specification_version: 4
216
260
  summary: API Client library for the GKE Hub V1beta1 API