| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  | # Copyright 2015 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. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require 'date' | 
					
						
							|  |  |  | require 'google/apis/core/base_service' | 
					
						
							|  |  |  | require 'google/apis/core/json_representation' | 
					
						
							|  |  |  | require 'google/apis/core/hashable' | 
					
						
							|  |  |  | require 'google/apis/errors' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module Google | 
					
						
							|  |  |  |   module Apis | 
					
						
							|  |  |  |     module CloudresourcemanagerV1beta1 | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # Associates `members` with a `role`. | 
					
						
							|  |  |  |       class Binding | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Specifies the identities requesting access for a Cloud Platform resource. | 
					
						
							|  |  |  |         # `members` can have the following values: | 
					
						
							|  |  |  |         # * `allUsers`: A special identifier that represents anyone who is | 
					
						
							|  |  |  |         # on the internet; with or without a Google account. | 
					
						
							|  |  |  |         # * `allAuthenticatedUsers`: A special identifier that represents anyone | 
					
						
							|  |  |  |         # who is authenticated with a Google account or a service account. | 
					
						
							|  |  |  |         # * `user:`emailid``: An email address that represents a specific Google | 
					
						
							|  |  |  |         # account. For example, `alice@gmail.com` or `joe@example.com`. | 
					
						
							|  |  |  |         # * `serviceAccount:`emailid``: An email address that represents a service | 
					
						
							|  |  |  |         # account. For example, `my-other-app@appspot.gserviceaccount.com`. | 
					
						
							|  |  |  |         # * `group:`emailid``: An email address that represents a Google group. | 
					
						
							|  |  |  |         # For example, `admins@example.com`. | 
					
						
							|  |  |  |         # * `domain:`domain``: A Google Apps domain name that represents all the | 
					
						
							|  |  |  |         # users of that domain. For example, `google.com` or `example.com`. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `members` | 
					
						
							|  |  |  |         # @return [Array<String>] | 
					
						
							|  |  |  |         attr_accessor :members | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Role that is assigned to `members`. | 
					
						
							|  |  |  |         # For example, `roles/viewer`, `roles/editor`, or `roles/owner`. | 
					
						
							|  |  |  |         # Required | 
					
						
							|  |  |  |         # Corresponds to the JSON property `role` | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :role | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @members = args[:members] if args.key?(:members) | 
					
						
							|  |  |  |           @role = args[:role] if args.key?(:role) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # A generic empty message that you can re-use to avoid defining duplicated | 
					
						
							|  |  |  |       # empty messages in your APIs. A typical example is to use it as the request | 
					
						
							|  |  |  |       # or the response type of an API method. For instance: | 
					
						
							|  |  |  |       # service Foo ` | 
					
						
							|  |  |  |       # rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # The JSON representation for `Empty` is empty JSON object ````. | 
					
						
							|  |  |  |       class Empty | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-02-13 23:28:52 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-02-13 23:28:52 +00:00
										 |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # The request sent to the UndeleteProject | 
					
						
							|  |  |  |       # method. | 
					
						
							|  |  |  |       class UndeleteProjectRequest | 
					
						
							| 
									
										
										
										
											2017-02-13 23:28:52 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # The root node in the resource hierarchy to which a particular entity's | 
					
						
							|  |  |  |       # (e.g., company) resources belong. | 
					
						
							|  |  |  |       class Organization | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Timestamp when the Organization was created. Assigned by the server. | 
					
						
							|  |  |  |         # @OutputOnly | 
					
						
							|  |  |  |         # Corresponds to the JSON property `creationTime` | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         attr_accessor :creation_time | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The entity that owns an Organization. The lifetime of the Organization and | 
					
						
							|  |  |  |         # all of its descendants are bound to the `OrganizationOwner`. If the | 
					
						
							|  |  |  |         # `OrganizationOwner` is deleted, the Organization and all its descendants will | 
					
						
							|  |  |  |         # be deleted. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `owner` | 
					
						
							|  |  |  |         # @return [Google::Apis::CloudresourcemanagerV1beta1::OrganizationOwner] | 
					
						
							|  |  |  |         attr_accessor :owner | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Output Only. The resource name of the organization. This is the | 
					
						
							|  |  |  |         # organization's relative path in the API. Its format is | 
					
						
							|  |  |  |         # "organizations/[organization_id]". For example, "organizations/1234". | 
					
						
							|  |  |  |         # Corresponds to the JSON property `name` | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         attr_accessor :name | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # An immutable id for the Organization that is assigned on creation. This | 
					
						
							|  |  |  |         # should be omitted when creating a new Organization. | 
					
						
							|  |  |  |         # This field is read-only. | 
					
						
							|  |  |  |         # This field is deprecated and will be removed in v1. Use name instead. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `organizationId` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :organization_id | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The organization's current lifecycle state. Assigned by the server. | 
					
						
							|  |  |  |         # @OutputOnly | 
					
						
							|  |  |  |         # Corresponds to the JSON property `lifecycleState` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :lifecycle_state | 
					
						
							| 
									
										
										
										
											2017-02-03 19:29:28 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # A friendly string to be used to refer to the Organization in the UI. | 
					
						
							|  |  |  |         # Assigned by the server, set to the primary domain of the G Suite | 
					
						
							|  |  |  |         # customer that owns the organization. | 
					
						
							|  |  |  |         # @OutputOnly | 
					
						
							|  |  |  |         # Corresponds to the JSON property `displayName` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :display_name | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @creation_time = args[:creation_time] if args.key?(:creation_time) | 
					
						
							|  |  |  |           @owner = args[:owner] if args.key?(:owner) | 
					
						
							|  |  |  |           @name = args[:name] if args.key?(:name) | 
					
						
							|  |  |  |           @organization_id = args[:organization_id] if args.key?(:organization_id) | 
					
						
							|  |  |  |           @lifecycle_state = args[:lifecycle_state] if args.key?(:lifecycle_state) | 
					
						
							|  |  |  |           @display_name = args[:display_name] if args.key?(:display_name) | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # A status object which is used as the `metadata` field for the Operation | 
					
						
							|  |  |  |       # returned by CreateProject. It provides insight for when significant phases of | 
					
						
							|  |  |  |       # Project creation have completed. | 
					
						
							|  |  |  |       class ProjectCreationStatus | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # True if the project creation process is complete. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `ready` | 
					
						
							|  |  |  |         # @return [Boolean] | 
					
						
							|  |  |  |         attr_accessor :ready | 
					
						
							|  |  |  |         alias_method :ready?, :ready | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Creation time of the project creation workflow. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `createTime` | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :create_time | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # True if the project can be retrieved using GetProject. No other operations | 
					
						
							|  |  |  |         # on the project are guaranteed to work until the project creation is | 
					
						
							|  |  |  |         # complete. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `gettable` | 
					
						
							|  |  |  |         # @return [Boolean] | 
					
						
							|  |  |  |         attr_accessor :gettable | 
					
						
							|  |  |  |         alias_method :gettable?, :gettable | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |           @ready = args[:ready] if args.key?(:ready) | 
					
						
							|  |  |  |           @create_time = args[:create_time] if args.key?(:create_time) | 
					
						
							|  |  |  |           @gettable = args[:gettable] if args.key?(:gettable) | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # Request message for `GetIamPolicy` method. | 
					
						
							|  |  |  |       class GetIamPolicyRequest | 
					
						
							| 
									
										
										
										
											2015-12-03 01:10:07 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # Response message for `TestIamPermissions` method. | 
					
						
							|  |  |  |       class TestIamPermissionsResponse | 
					
						
							| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # A subset of `TestPermissionsRequest.permissions` that the caller is | 
					
						
							|  |  |  |         # allowed. | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         # Corresponds to the JSON property `permissions` | 
					
						
							|  |  |  |         # @return [Array<String>] | 
					
						
							|  |  |  |         attr_accessor :permissions | 
					
						
							| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |           @permissions = args[:permissions] if args.key?(:permissions) | 
					
						
							| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # The entity that owns an Organization. The lifetime of the Organization and | 
					
						
							|  |  |  |       # all of its descendants are bound to the `OrganizationOwner`. If the | 
					
						
							|  |  |  |       # `OrganizationOwner` is deleted, the Organization and all its descendants will | 
					
						
							|  |  |  |       # be deleted. | 
					
						
							|  |  |  |       class OrganizationOwner | 
					
						
							| 
									
										
										
										
											2016-02-25 23:16:53 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The Google for Work customer id used in the Directory API. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `directoryCustomerId` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :directory_customer_id | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2016-02-25 23:16:53 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @directory_customer_id = args[:directory_customer_id] if args.key?(:directory_customer_id) | 
					
						
							| 
									
										
										
										
											2016-02-25 23:16:53 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # Response from the GetAncestry method. | 
					
						
							|  |  |  |       class GetAncestryResponse | 
					
						
							| 
									
										
										
										
											2016-05-25 16:16:15 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Ancestors are ordered from bottom to top of the resource hierarchy. The | 
					
						
							|  |  |  |         # first ancestor is the project itself, followed by the project's parent, | 
					
						
							|  |  |  |         # etc. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `ancestor` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::Ancestor>] | 
					
						
							|  |  |  |         attr_accessor :ancestor | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @ancestor = args[:ancestor] if args.key?(:ancestor) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Provides the configuration for logging a type of permissions. | 
					
						
							|  |  |  |       # Example: | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "audit_log_configs": [ | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_READ", | 
					
						
							|  |  |  |       # "exempted_members": [ | 
					
						
							|  |  |  |       # "user:foo@gmail.com" | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_WRITE", | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # This enables 'DATA_READ' and 'DATA_WRITE' logging, while exempting | 
					
						
							|  |  |  |       # foo@gmail.com from DATA_READ logging. | 
					
						
							|  |  |  |       class AuditLogConfig | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Specifies the identities that do not cause logging for this type of | 
					
						
							|  |  |  |         # permission. | 
					
						
							|  |  |  |         # Follows the same format of Binding.members. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `exemptedMembers` | 
					
						
							|  |  |  |         # @return [Array<String>] | 
					
						
							|  |  |  |         attr_accessor :exempted_members | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The log type that this config enables. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `logType` | 
					
						
							| 
									
										
										
										
											2017-02-13 23:28:52 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         attr_accessor :log_type | 
					
						
							| 
									
										
										
										
											2016-05-25 16:16:15 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							| 
									
										
										
										
											2016-05-25 16:16:15 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @exempted_members = args[:exempted_members] if args.key?(:exempted_members) | 
					
						
							|  |  |  |           @log_type = args[:log_type] if args.key?(:log_type) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # A page of the response received from the | 
					
						
							|  |  |  |       # ListProjects | 
					
						
							|  |  |  |       # method. | 
					
						
							|  |  |  |       # A paginated response where more pages are available has | 
					
						
							|  |  |  |       # `next_page_token` set. This token can be used in a subsequent request to | 
					
						
							|  |  |  |       # retrieve the next request page. | 
					
						
							|  |  |  |       class ListProjectsResponse | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Pagination token. | 
					
						
							|  |  |  |         # If the result set is too large to fit in a single response, this token | 
					
						
							|  |  |  |         # is returned. It encodes the position of the current result cursor. | 
					
						
							|  |  |  |         # Feeding this value into a new list request with the `page_token` parameter | 
					
						
							|  |  |  |         # gives the next page of the results. | 
					
						
							|  |  |  |         # When `next_page_token` is not filled in, there is no next page and | 
					
						
							|  |  |  |         # the list returned is the last page in the result set. | 
					
						
							|  |  |  |         # Pagination tokens have a limited lifetime. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `nextPageToken` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :next_page_token | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The list of Projects that matched the list filter. This list can | 
					
						
							|  |  |  |         # be paginated. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `projects` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::Project>] | 
					
						
							|  |  |  |         attr_accessor :projects | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2016-05-25 16:16:15 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |           @next_page_token = args[:next_page_token] if args.key?(:next_page_token) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @projects = args[:projects] if args.key?(:projects) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # The request sent to the | 
					
						
							|  |  |  |       # GetAncestry | 
					
						
							|  |  |  |       # method. | 
					
						
							|  |  |  |       class GetAncestryRequest | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2016-05-25 16:16:15 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # A Project is a high-level Google Cloud Platform entity.  It is a | 
					
						
							|  |  |  |       # container for ACLs, APIs, App Engine Apps, VMs, and other | 
					
						
							|  |  |  |       # Google Cloud Platform resources. | 
					
						
							|  |  |  |       class Project | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # The Project lifecycle state. | 
					
						
							|  |  |  |         # Read-only. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `lifecycleState` | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :lifecycle_state | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # The number uniquely identifying the project. | 
					
						
							|  |  |  |         # Example: <code>415104041262</code> | 
					
						
							|  |  |  |         # Read-only. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `projectNumber` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :project_number | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # A container to reference an id for any resource type. A `resource` in Google | 
					
						
							|  |  |  |         # Cloud Platform is a generic term for something you (a developer) may want to | 
					
						
							|  |  |  |         # interact with through one of our API's. Some examples are an App Engine app, | 
					
						
							|  |  |  |         # a Compute Engine instance, a Cloud SQL database, and so on. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `parent` | 
					
						
							|  |  |  |         # @return [Google::Apis::CloudresourcemanagerV1beta1::ResourceId] | 
					
						
							|  |  |  |         attr_accessor :parent | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The labels associated with this Project. | 
					
						
							|  |  |  |         # Label keys must be between 1 and 63 characters long and must conform | 
					
						
							|  |  |  |         # to the following regular expression: \[a-z\](\[-a-z0-9\]*\[a-z0-9\])?. | 
					
						
							|  |  |  |         # Label values must be between 0 and 63 characters long and must conform | 
					
						
							|  |  |  |         # to the regular expression (\[a-z\](\[-a-z0-9\]*\[a-z0-9\])?)?. | 
					
						
							|  |  |  |         # No more than 256 labels can be associated with a given resource. | 
					
						
							|  |  |  |         # Clients should store labels in a representation such as JSON that does not | 
					
						
							|  |  |  |         # depend on specific characters being disallowed. | 
					
						
							|  |  |  |         # Example: <code>"environment" : "dev"</code> | 
					
						
							|  |  |  |         # Read-write. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `labels` | 
					
						
							|  |  |  |         # @return [Hash<String,String>] | 
					
						
							|  |  |  |         attr_accessor :labels | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Creation time. | 
					
						
							|  |  |  |         # Read-only. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `createTime` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :create_time | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The user-assigned display name of the Project. | 
					
						
							|  |  |  |         # It must be 4 to 30 characters. | 
					
						
							|  |  |  |         # Allowed characters are: lowercase and uppercase letters, numbers, | 
					
						
							|  |  |  |         # hyphen, single-quote, double-quote, space, and exclamation point. | 
					
						
							|  |  |  |         # Example: <code>My Project</code> | 
					
						
							|  |  |  |         # Read-write. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `name` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :name | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The unique, user-assigned ID of the Project. | 
					
						
							|  |  |  |         # It must be 6 to 30 lowercase letters, digits, or hyphens. | 
					
						
							|  |  |  |         # It must start with a letter. | 
					
						
							|  |  |  |         # Trailing hyphens are prohibited. | 
					
						
							|  |  |  |         # Example: <code>tokyo-rain-123</code> | 
					
						
							|  |  |  |         # Read-only after creation. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `projectId` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :project_id | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @lifecycle_state = args[:lifecycle_state] if args.key?(:lifecycle_state) | 
					
						
							|  |  |  |           @project_number = args[:project_number] if args.key?(:project_number) | 
					
						
							|  |  |  |           @parent = args[:parent] if args.key?(:parent) | 
					
						
							|  |  |  |           @labels = args[:labels] if args.key?(:labels) | 
					
						
							|  |  |  |           @create_time = args[:create_time] if args.key?(:create_time) | 
					
						
							|  |  |  |           @name = args[:name] if args.key?(:name) | 
					
						
							|  |  |  |           @project_id = args[:project_id] if args.key?(:project_id) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Request message for `TestIamPermissions` method. | 
					
						
							|  |  |  |       class TestIamPermissionsRequest | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The set of permissions to check for the `resource`. Permissions with | 
					
						
							|  |  |  |         # wildcards (such as '*' or 'storage.*') are not allowed. For more | 
					
						
							|  |  |  |         # information see | 
					
						
							|  |  |  |         # [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions). | 
					
						
							|  |  |  |         # Corresponds to the JSON property `permissions` | 
					
						
							|  |  |  |         # @return [Array<String>] | 
					
						
							|  |  |  |         attr_accessor :permissions | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @permissions = args[:permissions] if args.key?(:permissions) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Defines an Identity and Access Management (IAM) policy. It is used to | 
					
						
							|  |  |  |       # specify access control policies for Cloud Platform resources. | 
					
						
							|  |  |  |       # A `Policy` consists of a list of `bindings`. A `Binding` binds a list of | 
					
						
							|  |  |  |       # `members` to a `role`, where the members can be user accounts, Google groups, | 
					
						
							|  |  |  |       # Google domains, and service accounts. A `role` is a named list of permissions | 
					
						
							|  |  |  |       # defined by IAM. | 
					
						
							|  |  |  |       # **Example** | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "bindings": [ | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "role": "roles/owner", | 
					
						
							|  |  |  |       # "members": [ | 
					
						
							|  |  |  |       # "user:mike@example.com", | 
					
						
							|  |  |  |       # "group:admins@example.com", | 
					
						
							|  |  |  |       # "domain:google.com", | 
					
						
							|  |  |  |       # "serviceAccount:my-other-app@appspot.gserviceaccount.com", | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "role": "roles/viewer", | 
					
						
							|  |  |  |       # "members": ["user:sean@example.com"] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # For a description of IAM and its features, see the | 
					
						
							|  |  |  |       # [IAM developer's guide](https://cloud.google.com/iam). | 
					
						
							|  |  |  |       class Policy | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # `etag` is used for optimistic concurrency control as a way to help | 
					
						
							|  |  |  |         # prevent simultaneous updates of a policy from overwriting each other. | 
					
						
							|  |  |  |         # It is strongly suggested that systems make use of the `etag` in the | 
					
						
							|  |  |  |         # read-modify-write cycle to perform policy updates in order to avoid race | 
					
						
							|  |  |  |         # conditions: An `etag` is returned in the response to `getIamPolicy`, and | 
					
						
							|  |  |  |         # systems are expected to put that etag in the request to `setIamPolicy` to | 
					
						
							|  |  |  |         # ensure that their change will be applied to the same version of the policy. | 
					
						
							|  |  |  |         # If no `etag` is provided in the call to `setIamPolicy`, then the existing | 
					
						
							|  |  |  |         # policy is overwritten blindly. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `etag` | 
					
						
							|  |  |  |         # NOTE: Values are automatically base64 encoded/decoded in the client library. | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :etag | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Version of the `Policy`. The default version is 0. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `version` | 
					
						
							|  |  |  |         # @return [Fixnum] | 
					
						
							|  |  |  |         attr_accessor :version | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Specifies cloud audit logging configuration for this policy. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `auditConfigs` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::AuditConfig>] | 
					
						
							|  |  |  |         attr_accessor :audit_configs | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Associates a list of `members` to a `role`. | 
					
						
							|  |  |  |         # Multiple `bindings` must not be specified for the same `role`. | 
					
						
							|  |  |  |         # `bindings` with no members will result in an error. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `bindings` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::Binding>] | 
					
						
							|  |  |  |         attr_accessor :bindings | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @etag = args[:etag] if args.key?(:etag) | 
					
						
							|  |  |  |           @version = args[:version] if args.key?(:version) | 
					
						
							|  |  |  |           @audit_configs = args[:audit_configs] if args.key?(:audit_configs) | 
					
						
							|  |  |  |           @bindings = args[:bindings] if args.key?(:bindings) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # Metadata describing a long running folder operation | 
					
						
							|  |  |  |       class FolderOperation | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The type of this operation. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `operationType` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :operation_type | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The display name of the folder. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `displayName` | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         attr_accessor :display_name | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The resource name of the folder's parent. | 
					
						
							|  |  |  |         # Only applicable when the operation_type is MOVE. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `sourceParent` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :source_parent | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # The resource name of the folder or organization we are either creating | 
					
						
							|  |  |  |         # the folder under or moving the folder to. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `destinationParent` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :destination_parent | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @operation_type = args[:operation_type] if args.key?(:operation_type) | 
					
						
							|  |  |  |           @display_name = args[:display_name] if args.key?(:display_name) | 
					
						
							|  |  |  |           @source_parent = args[:source_parent] if args.key?(:source_parent) | 
					
						
							|  |  |  |           @destination_parent = args[:destination_parent] if args.key?(:destination_parent) | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # A classification of the Folder Operation error. | 
					
						
							|  |  |  |       class FolderOperationError | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # The type of operation error experienced. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `errorMessageId` | 
					
						
							| 
									
										
										
										
											2017-01-28 03:38:40 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :error_message_id | 
					
						
							| 
									
										
										
										
											2017-01-13 23:04:35 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @error_message_id = args[:error_message_id] if args.key?(:error_message_id) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # A container to reference an id for any resource type. A `resource` in Google | 
					
						
							|  |  |  |       # Cloud Platform is a generic term for something you (a developer) may want to | 
					
						
							|  |  |  |       # interact with through one of our API's. Some examples are an App Engine app, | 
					
						
							|  |  |  |       # a Compute Engine instance, a Cloud SQL database, and so on. | 
					
						
							|  |  |  |       class ResourceId | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Required field representing the resource type this id is for. | 
					
						
							|  |  |  |         # At present, the valid types are "project" and "organization". | 
					
						
							|  |  |  |         # Corresponds to the JSON property `type` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :type | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Required field for the type-specific id. This should correspond to the id | 
					
						
							|  |  |  |         # used in the type-specific API's. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `id` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :id | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @type = args[:type] if args.key?(:type) | 
					
						
							|  |  |  |           @id = args[:id] if args.key?(:id) | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # Specifies the audit configuration for a service. | 
					
						
							|  |  |  |       # The configuration determines which permission types are logged, and what | 
					
						
							|  |  |  |       # identities, if any, are exempted from logging. | 
					
						
							|  |  |  |       # An AuditConifg must have one or more AuditLogConfigs. | 
					
						
							|  |  |  |       # If there are AuditConfigs for both `allServices` and a specific service, | 
					
						
							|  |  |  |       # the union of the two AuditConfigs is used for that service: the log_types | 
					
						
							|  |  |  |       # specified in each AuditConfig are enabled, and the exempted_members in each | 
					
						
							|  |  |  |       # AuditConfig are exempted. | 
					
						
							|  |  |  |       # Example Policy with multiple AuditConfigs: | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "audit_configs": [ | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "service": "allServices" | 
					
						
							|  |  |  |       # "audit_log_configs": [ | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_READ", | 
					
						
							|  |  |  |       # "exempted_members": [ | 
					
						
							|  |  |  |       # "user:foo@gmail.com" | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_WRITE", | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "ADMIN_READ", | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "service": "fooservice@googleapis.com" | 
					
						
							|  |  |  |       # "audit_log_configs": [ | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_READ", | 
					
						
							|  |  |  |       # `, | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # "log_type": "DATA_WRITE", | 
					
						
							|  |  |  |       # "exempted_members": [ | 
					
						
							|  |  |  |       # "user:bar@gmail.com" | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # For fooservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ | 
					
						
							|  |  |  |       # logging. It also exempts foo@gmail.com from DATA_READ logging, and | 
					
						
							|  |  |  |       # bar@gmail.com from DATA_WRITE logging. | 
					
						
							|  |  |  |       class AuditConfig | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # Specifies a service that will be enabled for audit logging. | 
					
						
							|  |  |  |         # For example, `storage.googleapis.com`, `cloudsql.googleapis.com`. | 
					
						
							|  |  |  |         # `allServices` is a special value that covers all services. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `service` | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         attr_accessor :service | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The configuration for logging of each type of permission. | 
					
						
							|  |  |  |         # Next ID: 4 | 
					
						
							|  |  |  |         # Corresponds to the JSON property `auditLogConfigs` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::AuditLogConfig>] | 
					
						
							|  |  |  |         attr_accessor :audit_log_configs | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @service = args[:service] if args.key?(:service) | 
					
						
							|  |  |  |           @audit_log_configs = args[:audit_log_configs] if args.key?(:audit_log_configs) | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # Identifying information for a single ancestor of a project. | 
					
						
							|  |  |  |       class Ancestor | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # A container to reference an id for any resource type. A `resource` in Google | 
					
						
							|  |  |  |         # Cloud Platform is a generic term for something you (a developer) may want to | 
					
						
							|  |  |  |         # interact with through one of our API's. Some examples are an App Engine app, | 
					
						
							|  |  |  |         # a Compute Engine instance, a Cloud SQL database, and so on. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `resourceId` | 
					
						
							|  |  |  |         # @return [Google::Apis::CloudresourcemanagerV1beta1::ResourceId] | 
					
						
							|  |  |  |         attr_accessor :resource_id | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |           @resource_id = args[:resource_id] if args.key?(:resource_id) | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |       # Request message for `SetIamPolicy` method. | 
					
						
							|  |  |  |       class SetIamPolicyRequest | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # OPTIONAL: A FieldMask specifying which fields of the policy to modify. Only | 
					
						
							|  |  |  |         # the fields in the mask will be modified. If no mask is provided, the | 
					
						
							|  |  |  |         # following default mask is used: | 
					
						
							|  |  |  |         # paths: "bindings, etag" | 
					
						
							|  |  |  |         # This field is only used by Cloud IAM. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `updateMask` | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :update_mask | 
					
						
							| 
									
										
										
										
											2017-03-27 22:14:47 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Defines an Identity and Access Management (IAM) policy. It is used to | 
					
						
							|  |  |  |         # specify access control policies for Cloud Platform resources. | 
					
						
							|  |  |  |         # A `Policy` consists of a list of `bindings`. A `Binding` binds a list of | 
					
						
							|  |  |  |         # `members` to a `role`, where the members can be user accounts, Google groups, | 
					
						
							|  |  |  |         # Google domains, and service accounts. A `role` is a named list of permissions | 
					
						
							|  |  |  |         # defined by IAM. | 
					
						
							|  |  |  |         # **Example** | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # "bindings": [ | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # "role": "roles/owner", | 
					
						
							|  |  |  |         # "members": [ | 
					
						
							|  |  |  |         # "user:mike@example.com", | 
					
						
							|  |  |  |         # "group:admins@example.com", | 
					
						
							|  |  |  |         # "domain:google.com", | 
					
						
							|  |  |  |         # "serviceAccount:my-other-app@appspot.gserviceaccount.com", | 
					
						
							|  |  |  |         # ] | 
					
						
							|  |  |  |         # `, | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # "role": "roles/viewer", | 
					
						
							|  |  |  |         # "members": ["user:sean@example.com"] | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # ] | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # For a description of IAM and its features, see the | 
					
						
							|  |  |  |         # [IAM developer's guide](https://cloud.google.com/iam). | 
					
						
							|  |  |  |         # Corresponds to the JSON property `policy` | 
					
						
							|  |  |  |         # @return [Google::Apis::CloudresourcemanagerV1beta1::Policy] | 
					
						
							|  |  |  |         attr_accessor :policy | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |           @update_mask = args[:update_mask] if args.key?(:update_mask) | 
					
						
							|  |  |  |           @policy = args[:policy] if args.key?(:policy) | 
					
						
							| 
									
										
										
										
											2015-07-31 00:05:47 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |       # The response returned from the `ListOrganizations` method. | 
					
						
							|  |  |  |       class ListOrganizationsResponse | 
					
						
							| 
									
										
										
										
											2016-10-04 00:27:26 +00:00
										 |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # A pagination token to be used to retrieve the next page of results. If the | 
					
						
							|  |  |  |         # result is too large to fit within the page size specified in the request, | 
					
						
							|  |  |  |         # this field will be set with a token that can be used to fetch the next page | 
					
						
							|  |  |  |         # of results. If this field is empty, it indicates that this response | 
					
						
							|  |  |  |         # contains the last page of results. | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         # Corresponds to the JSON property `nextPageToken` | 
					
						
							| 
									
										
										
										
											2017-02-13 23:28:52 +00:00
										 |  |  |         # @return [String] | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |         attr_accessor :next_page_token | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |         # The list of Organizations that matched the list query, possibly paginated. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `organizations` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::CloudresourcemanagerV1beta1::Organization>] | 
					
						
							|  |  |  |         attr_accessor :organizations | 
					
						
							| 
									
										
										
										
											2017-03-10 21:11:09 +00:00
										 |  |  |        | 
					
						
							| 
									
										
										
										
											2017-01-28 03:38:40 +00:00
										 |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2017-03-30 22:30:51 +00:00
										 |  |  |           @next_page_token = args[:next_page_token] if args.key?(:next_page_token) | 
					
						
							| 
									
										
										
										
											2017-03-31 19:53:27 +00:00
										 |  |  |           @organizations = args[:organizations] if args.key?(:organizations) | 
					
						
							| 
									
										
										
										
											2017-01-28 03:38:40 +00:00
										 |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2015-06-23 23:05:46 +00:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |