401 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Ruby
		
	
	
	
		
		
			
		
	
	
			401 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			Ruby
		
	
	
	
|  | # Copyright 2020 Google LLC | ||
|  | # | ||
|  | # 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 AccessapprovalV1 | ||
|  |        | ||
|  |       # Settings on a Project/Folder/Organization related to Access Approval. | ||
|  |       class AccessApprovalSettings | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # Output only. This field is read only (not settable via | ||
|  |         # UpdateAccessAccessApprovalSettings method). If the field is true, that | ||
|  |         # indicates that at least one service is enrolled for Access Approval in one or | ||
|  |         # more ancestors of the Project or Folder (this field will always be unset for | ||
|  |         # the organization since organizations do not have ancestors). | ||
|  |         # Corresponds to the JSON property `enrolledAncestor` | ||
|  |         # @return [Boolean] | ||
|  |         attr_accessor :enrolled_ancestor | ||
|  |         alias_method :enrolled_ancestor?, :enrolled_ancestor | ||
|  |        | ||
|  |         # A list of Google Cloud Services for which the given resource has Access | ||
|  |         # Approval enrolled. Access requests for the resource given by name against any | ||
|  |         # of these services contained here will be required to have explicit approval. | ||
|  |         # If name refers to an organization, enrollment can be done for individual | ||
|  |         # services. If name refers to a folder or project, enrollment can only be done | ||
|  |         # on an all or nothing basis. If a cloud_product is repeated in this list, the | ||
|  |         # first entry will be honored and all following entries will be discarded. A | ||
|  |         # maximum of 10 enrolled services will be enforced, to be expanded as the set of | ||
|  |         # supported services is expanded. | ||
|  |         # Corresponds to the JSON property `enrolledServices` | ||
|  |         # @return [Array<Google::Apis::AccessapprovalV1::EnrolledService>] | ||
|  |         attr_accessor :enrolled_services | ||
|  |        | ||
|  |         # The resource name of the settings. Format is one of: * "projects/`project`/ | ||
|  |         # accessApprovalSettings" * "folders/`folder`/accessApprovalSettings" * " | ||
|  |         # organizations/`organization`/accessApprovalSettings" | ||
|  |         # Corresponds to the JSON property `name` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :name | ||
|  |        | ||
|  |         # A list of email addresses to which notifications relating to approval requests | ||
|  |         # should be sent. Notifications relating to a resource will be sent to all | ||
|  |         # emails in the settings of ancestor resources of that resource. A maximum of 50 | ||
|  |         # email addresses are allowed. | ||
|  |         # Corresponds to the JSON property `notificationEmails` | ||
|  |         # @return [Array<String>] | ||
|  |         attr_accessor :notification_emails | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @enrolled_ancestor = args[:enrolled_ancestor] if args.key?(:enrolled_ancestor) | ||
|  |           @enrolled_services = args[:enrolled_services] if args.key?(:enrolled_services) | ||
|  |           @name = args[:name] if args.key?(:name) | ||
|  |           @notification_emails = args[:notification_emails] if args.key?(:notification_emails) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # Home office and physical location of the principal. | ||
|  |       class AccessLocations | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # The "home office" location of the principal. A two-letter country code (ISO | ||
|  |         # 3166-1 alpha-2), such as "US", "DE" or "GB" or a region code. In some limited | ||
|  |         # situations Google systems may refer refer to a region code instead of a | ||
|  |         # country code. Possible Region Codes: * ASI: Asia * EUR: Europe * OCE: Oceania * | ||
|  |         # AFR: Africa * NAM: North America * SAM: South America * ANT: Antarctica * ANY: | ||
|  |         # Any location | ||
|  |         # Corresponds to the JSON property `principalOfficeCountry` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :principal_office_country | ||
|  |        | ||
|  |         # Physical location of the principal at the time of the access. A two-letter | ||
|  |         # country code (ISO 3166-1 alpha-2), such as "US", "DE" or "GB" or a region code. | ||
|  |         # In some limited situations Google systems may refer refer to a region code | ||
|  |         # instead of a country code. Possible Region Codes: * ASI: Asia * EUR: Europe * | ||
|  |         # OCE: Oceania * AFR: Africa * NAM: North America * SAM: South America * ANT: | ||
|  |         # Antarctica * ANY: Any location | ||
|  |         # Corresponds to the JSON property `principalPhysicalLocationCountry` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :principal_physical_location_country | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @principal_office_country = args[:principal_office_country] if args.key?(:principal_office_country) | ||
|  |           @principal_physical_location_country = args[:principal_physical_location_country] if args.key?(:principal_physical_location_country) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       #  | ||
|  |       class AccessReason | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # More detail about certain reason types. See comments for each type above. | ||
|  |         # Corresponds to the JSON property `detail` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :detail | ||
|  |        | ||
|  |         # Type of access justification. | ||
|  |         # Corresponds to the JSON property `type` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :type | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @detail = args[:detail] if args.key?(:detail) | ||
|  |           @type = args[:type] if args.key?(:type) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # A request for the customer to approve access to a resource. | ||
|  |       class ApprovalRequest | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # A decision that has been made to approve access to a resource. | ||
|  |         # Corresponds to the JSON property `approve` | ||
|  |         # @return [Google::Apis::AccessapprovalV1::ApproveDecision] | ||
|  |         attr_accessor :approve | ||
|  |        | ||
|  |         # A decision that has been made to dismiss an approval request. | ||
|  |         # Corresponds to the JSON property `dismiss` | ||
|  |         # @return [Google::Apis::AccessapprovalV1::DismissDecision] | ||
|  |         attr_accessor :dismiss | ||
|  |        | ||
|  |         # The resource name of the request. Format is "`projects|folders|organizations`/` | ||
|  |         # id`/approvalRequests/`approval_request`". | ||
|  |         # Corresponds to the JSON property `name` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :name | ||
|  |        | ||
|  |         # The time at which approval was requested. | ||
|  |         # Corresponds to the JSON property `requestTime` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :request_time | ||
|  |        | ||
|  |         # The requested expiration for the approval. If the request is approved, access | ||
|  |         # will be granted from the time of approval until the expiration time. | ||
|  |         # Corresponds to the JSON property `requestedExpiration` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :requested_expiration | ||
|  |        | ||
|  |         # Home office and physical location of the principal. | ||
|  |         # Corresponds to the JSON property `requestedLocations` | ||
|  |         # @return [Google::Apis::AccessapprovalV1::AccessLocations] | ||
|  |         attr_accessor :requested_locations | ||
|  |        | ||
|  |         # The justification for which approval is being requested. | ||
|  |         # Corresponds to the JSON property `requestedReason` | ||
|  |         # @return [Google::Apis::AccessapprovalV1::AccessReason] | ||
|  |         attr_accessor :requested_reason | ||
|  |        | ||
|  |         # The resource for which approval is being requested. The format of the resource | ||
|  |         # name is defined at https://cloud.google.com/apis/design/resource_names. The | ||
|  |         # resource name here may either be a "full" resource name (e.g. "//library. | ||
|  |         # googleapis.com/shelves/shelf1/books/book2") or a "relative" resource name (e.g. | ||
|  |         # "shelves/shelf1/books/book2") as described in the resource name specification. | ||
|  |         # Corresponds to the JSON property `requestedResourceName` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :requested_resource_name | ||
|  |        | ||
|  |         # The properties associated with the resource of the request. | ||
|  |         # Corresponds to the JSON property `requestedResourceProperties` | ||
|  |         # @return [Google::Apis::AccessapprovalV1::ResourceProperties] | ||
|  |         attr_accessor :requested_resource_properties | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @approve = args[:approve] if args.key?(:approve) | ||
|  |           @dismiss = args[:dismiss] if args.key?(:dismiss) | ||
|  |           @name = args[:name] if args.key?(:name) | ||
|  |           @request_time = args[:request_time] if args.key?(:request_time) | ||
|  |           @requested_expiration = args[:requested_expiration] if args.key?(:requested_expiration) | ||
|  |           @requested_locations = args[:requested_locations] if args.key?(:requested_locations) | ||
|  |           @requested_reason = args[:requested_reason] if args.key?(:requested_reason) | ||
|  |           @requested_resource_name = args[:requested_resource_name] if args.key?(:requested_resource_name) | ||
|  |           @requested_resource_properties = args[:requested_resource_properties] if args.key?(:requested_resource_properties) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # Request to approve an ApprovalRequest. | ||
|  |       class ApproveApprovalRequestMessage | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # The expiration time of this approval. | ||
|  |         # Corresponds to the JSON property `expireTime` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :expire_time | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @expire_time = args[:expire_time] if args.key?(:expire_time) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # A decision that has been made to approve access to a resource. | ||
|  |       class ApproveDecision | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # The time at which approval was granted. | ||
|  |         # Corresponds to the JSON property `approveTime` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :approve_time | ||
|  |        | ||
|  |         # The time at which the approval expires. | ||
|  |         # Corresponds to the JSON property `expireTime` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :expire_time | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @approve_time = args[:approve_time] if args.key?(:approve_time) | ||
|  |           @expire_time = args[:expire_time] if args.key?(:expire_time) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # Request to dismiss an approval request. | ||
|  |       class DismissApprovalRequestMessage | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # A decision that has been made to dismiss an approval request. | ||
|  |       class DismissDecision | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # The time at which the approval request was dismissed. | ||
|  |         # Corresponds to the JSON property `dismissTime` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :dismiss_time | ||
|  |        | ||
|  |         # This field will be true if the ApprovalRequest was implcitly dismissed due to | ||
|  |         # inaction by the access approval approvers (the request is not acted on by the | ||
|  |         # approvers before the exiration time). | ||
|  |         # Corresponds to the JSON property `implicit` | ||
|  |         # @return [Boolean] | ||
|  |         attr_accessor :implicit | ||
|  |         alias_method :implicit?, :implicit | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @dismiss_time = args[:dismiss_time] if args.key?(:dismiss_time) | ||
|  |           @implicit = args[:implicit] if args.key?(:implicit) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # 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 | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # Represents the enrollment of a cloud resource into a specific service. | ||
|  |       class EnrolledService | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # The product for which Access Approval will be enrolled. Allowed values are | ||
|  |         # listed below (case-sensitive): * all * App Engine * BigQuery * Cloud Bigtable * | ||
|  |         # Cloud Key Management Service * Compute Engine * Cloud Dataflow * Cloud | ||
|  |         # Identity and Access Management * Cloud Pub/Sub * Cloud Storage * Persistent | ||
|  |         # Disk Note: These values are supported as input for legacy purposes, but will | ||
|  |         # not be returned from the API. * all * appengine.googleapis.com * bigquery. | ||
|  |         # googleapis.com * bigtable.googleapis.com * cloudkms.googleapis.com * compute. | ||
|  |         # googleapis.com * dataflow.googleapis.com * iam.googleapis.com * pubsub. | ||
|  |         # googleapis.com * storage.googleapis.com Calls to UpdateAccessApprovalSettings | ||
|  |         # using 'all' or any of the XXX.googleapis.com will be translated to the | ||
|  |         # associated product name ('all', 'App Engine', etc.). Note: 'all' will enroll | ||
|  |         # the resource in all products supported at both 'GA' and 'Preview' levels. More | ||
|  |         # information about levels of support is available at https://cloud.google.com/ | ||
|  |         # access-approval/docs/supported-services | ||
|  |         # Corresponds to the JSON property `cloudProduct` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :cloud_product | ||
|  |        | ||
|  |         # The enrollment level of the service. | ||
|  |         # Corresponds to the JSON property `enrollmentLevel` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :enrollment_level | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @cloud_product = args[:cloud_product] if args.key?(:cloud_product) | ||
|  |           @enrollment_level = args[:enrollment_level] if args.key?(:enrollment_level) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # Response to listing of ApprovalRequest objects. | ||
|  |       class ListApprovalRequestsResponse | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # Approval request details. | ||
|  |         # Corresponds to the JSON property `approvalRequests` | ||
|  |         # @return [Array<Google::Apis::AccessapprovalV1::ApprovalRequest>] | ||
|  |         attr_accessor :approval_requests | ||
|  |        | ||
|  |         # Token to retrieve the next page of results, or empty if there are no more. | ||
|  |         # Corresponds to the JSON property `nextPageToken` | ||
|  |         # @return [String] | ||
|  |         attr_accessor :next_page_token | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @approval_requests = args[:approval_requests] if args.key?(:approval_requests) | ||
|  |           @next_page_token = args[:next_page_token] if args.key?(:next_page_token) | ||
|  |         end | ||
|  |       end | ||
|  |        | ||
|  |       # The properties associated with the resource of the request. | ||
|  |       class ResourceProperties | ||
|  |         include Google::Apis::Core::Hashable | ||
|  |        | ||
|  |         # Whether an approval will exclude the descendants of the resource being | ||
|  |         # requested. | ||
|  |         # Corresponds to the JSON property `excludesDescendants` | ||
|  |         # @return [Boolean] | ||
|  |         attr_accessor :excludes_descendants | ||
|  |         alias_method :excludes_descendants?, :excludes_descendants | ||
|  |        | ||
|  |         def initialize(**args) | ||
|  |            update!(**args) | ||
|  |         end | ||
|  |        | ||
|  |         # Update properties of this object | ||
|  |         def update!(**args) | ||
|  |           @excludes_descendants = args[:excludes_descendants] if args.key?(:excludes_descendants) | ||
|  |         end | ||
|  |       end | ||
|  |     end | ||
|  |   end | ||
|  | end |