| 
									
										
										
										
											2018-05-01 00:36:47 +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 ServicebrokerV1 | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Associates `members` with a `role`. | 
					
						
							|  |  |  |       class GoogleIamV1Binding | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2018-08-22 21:14:52 +00:00
										 |  |  |         # Represents an expression text. Example: | 
					
						
							|  |  |  |         # title: "User account presence" | 
					
						
							|  |  |  |         # description: "Determines whether the request has a user account" | 
					
						
							|  |  |  |         # expression: "size(request.user) > 0" | 
					
						
							|  |  |  |         # Corresponds to the JSON property `condition` | 
					
						
							|  |  |  |         # @return [Google::Apis::ServicebrokerV1::GoogleTypeExpr] | 
					
						
							|  |  |  |         attr_accessor :condition | 
					
						
							|  |  |  |        | 
					
						
							| 
									
										
										
										
											2018-05-01 00:36:47 +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` . | 
					
						
							|  |  |  |         # * `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 | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Role that is assigned to `members`. | 
					
						
							|  |  |  |         # For example, `roles/viewer`, `roles/editor`, or `roles/owner`. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `role` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :role | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							| 
									
										
										
										
											2018-08-22 21:14:52 +00:00
										 |  |  |           @condition = args[:condition] if args.key?(:condition) | 
					
						
							| 
									
										
										
										
											2018-05-01 00:36:47 +00:00
										 |  |  |           @members = args[:members] if args.key?(:members) | 
					
						
							|  |  |  |           @role = args[:role] if args.key?(:role) | 
					
						
							|  |  |  |         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. | 
					
						
							|  |  |  |       # **JSON 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"] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # ] | 
					
						
							|  |  |  |       # ` | 
					
						
							|  |  |  |       # **YAML Example** | 
					
						
							|  |  |  |       # bindings: | 
					
						
							|  |  |  |       # - members: | 
					
						
							|  |  |  |       # - user:mike@example.com | 
					
						
							|  |  |  |       # - group:admins@example.com | 
					
						
							|  |  |  |       # - domain:google.com | 
					
						
							|  |  |  |       # - serviceAccount:my-other-app@appspot.gserviceaccount.com | 
					
						
							|  |  |  |       # role: roles/owner | 
					
						
							|  |  |  |       # - members: | 
					
						
							|  |  |  |       # - user:sean@example.com | 
					
						
							|  |  |  |       # role: roles/viewer | 
					
						
							|  |  |  |       # For a description of IAM and its features, see the | 
					
						
							|  |  |  |       # [IAM developer's guide](https://cloud.google.com/iam/docs). | 
					
						
							|  |  |  |       class GoogleIamV1Policy | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Associates a list of `members` to a `role`. | 
					
						
							|  |  |  |         # `bindings` with no members will result in an error. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `bindings` | 
					
						
							|  |  |  |         # @return [Array<Google::Apis::ServicebrokerV1::GoogleIamV1Binding>] | 
					
						
							|  |  |  |         attr_accessor :bindings | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # `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 | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Deprecated. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `version` | 
					
						
							|  |  |  |         # @return [Fixnum] | 
					
						
							|  |  |  |         attr_accessor :version | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @bindings = args[:bindings] if args.key?(:bindings) | 
					
						
							|  |  |  |           @etag = args[:etag] if args.key?(:etag) | 
					
						
							|  |  |  |           @version = args[:version] if args.key?(:version) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Request message for `SetIamPolicy` method. | 
					
						
							|  |  |  |       class GoogleIamV1SetIamPolicyRequest | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # 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. | 
					
						
							|  |  |  |         # **JSON 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"] | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # ] | 
					
						
							|  |  |  |         # ` | 
					
						
							|  |  |  |         # **YAML Example** | 
					
						
							|  |  |  |         # bindings: | 
					
						
							|  |  |  |         # - members: | 
					
						
							|  |  |  |         # - user:mike@example.com | 
					
						
							|  |  |  |         # - group:admins@example.com | 
					
						
							|  |  |  |         # - domain:google.com | 
					
						
							|  |  |  |         # - serviceAccount:my-other-app@appspot.gserviceaccount.com | 
					
						
							|  |  |  |         # role: roles/owner | 
					
						
							|  |  |  |         # - members: | 
					
						
							|  |  |  |         # - user:sean@example.com | 
					
						
							|  |  |  |         # role: roles/viewer | 
					
						
							|  |  |  |         # For a description of IAM and its features, see the | 
					
						
							|  |  |  |         # [IAM developer's guide](https://cloud.google.com/iam/docs). | 
					
						
							|  |  |  |         # Corresponds to the JSON property `policy` | 
					
						
							|  |  |  |         # @return [Google::Apis::ServicebrokerV1::GoogleIamV1Policy] | 
					
						
							|  |  |  |         attr_accessor :policy | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @policy = args[:policy] if args.key?(:policy) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Request message for `TestIamPermissions` method. | 
					
						
							|  |  |  |       class GoogleIamV1TestIamPermissionsRequest | 
					
						
							|  |  |  |         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 | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |       # Response message for `TestIamPermissions` method. | 
					
						
							|  |  |  |       class GoogleIamV1TestIamPermissionsResponse | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # A subset of `TestPermissionsRequest.permissions` that the caller is | 
					
						
							|  |  |  |         # allowed. | 
					
						
							|  |  |  |         # 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 | 
					
						
							| 
									
										
										
										
											2018-08-22 21:14:52 +00:00
										 |  |  |        | 
					
						
							|  |  |  |       # Represents an expression text. Example: | 
					
						
							|  |  |  |       # title: "User account presence" | 
					
						
							|  |  |  |       # description: "Determines whether the request has a user account" | 
					
						
							|  |  |  |       # expression: "size(request.user) > 0" | 
					
						
							|  |  |  |       class GoogleTypeExpr | 
					
						
							|  |  |  |         include Google::Apis::Core::Hashable | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # An optional description of the expression. This is a longer text which | 
					
						
							|  |  |  |         # describes the expression, e.g. when hovered over it in a UI. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `description` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :description | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Textual representation of an expression in | 
					
						
							|  |  |  |         # Common Expression Language syntax. | 
					
						
							|  |  |  |         # The application context of the containing message determines which | 
					
						
							|  |  |  |         # well-known feature set of CEL is supported. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `expression` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :expression | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # An optional string indicating the location of the expression for error | 
					
						
							|  |  |  |         # reporting, e.g. a file name and a position in the file. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `location` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :location | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # An optional title for the expression, i.e. a short string describing | 
					
						
							|  |  |  |         # its purpose. This can be used e.g. in UIs which allow to enter the | 
					
						
							|  |  |  |         # expression. | 
					
						
							|  |  |  |         # Corresponds to the JSON property `title` | 
					
						
							|  |  |  |         # @return [String] | 
					
						
							|  |  |  |         attr_accessor :title | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         def initialize(**args) | 
					
						
							|  |  |  |            update!(**args) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |         # Update properties of this object | 
					
						
							|  |  |  |         def update!(**args) | 
					
						
							|  |  |  |           @description = args[:description] if args.key?(:description) | 
					
						
							|  |  |  |           @expression = args[:expression] if args.key?(:expression) | 
					
						
							|  |  |  |           @location = args[:location] if args.key?(:location) | 
					
						
							|  |  |  |           @title = args[:title] if args.key?(:title) | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							| 
									
										
										
										
											2018-05-01 00:36:47 +00:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |