3711 lines
		
	
	
		
			152 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			3711 lines
		
	
	
		
			152 KiB
		
	
	
	
		
			Ruby
		
	
	
	
# 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 DlpV2beta1
 | 
						|
      
 | 
						|
      # The request message for Operations.CancelOperation.
 | 
						|
      class GoogleLongrunningCancelOperationRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The response message for Operations.ListOperations.
 | 
						|
      class GoogleLongrunningListOperationsResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The standard List next-page token.
 | 
						|
        # Corresponds to the JSON property `nextPageToken`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :next_page_token
 | 
						|
      
 | 
						|
        # A list of operations that matches the specified filter in the request.
 | 
						|
        # Corresponds to the JSON property `operations`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GoogleLongrunningOperation>]
 | 
						|
        attr_accessor :operations
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | 
						|
          @operations = args[:operations] if args.key?(:operations)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # This resource represents a long-running operation that is the result of a
 | 
						|
      # network API call.
 | 
						|
      class GoogleLongrunningOperation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # If the value is `false`, it means the operation is still in progress.
 | 
						|
        # If `true`, the operation is completed, and either `error` or `response` is
 | 
						|
        # available.
 | 
						|
        # Corresponds to the JSON property `done`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :done
 | 
						|
        alias_method :done?, :done
 | 
						|
      
 | 
						|
        # The `Status` type defines a logical error model that is suitable for different
 | 
						|
        # programming environments, including REST APIs and RPC APIs. It is used by
 | 
						|
        # [gRPC](https://github.com/grpc). The error model is designed to be:
 | 
						|
        # - Simple to use and understand for most users
 | 
						|
        # - Flexible enough to meet unexpected needs
 | 
						|
        # # Overview
 | 
						|
        # The `Status` message contains three pieces of data: error code, error message,
 | 
						|
        # and error details. The error code should be an enum value of
 | 
						|
        # google.rpc.Code, but it may accept additional error codes if needed.  The
 | 
						|
        # error message should be a developer-facing English message that helps
 | 
						|
        # developers *understand* and *resolve* the error. If a localized user-facing
 | 
						|
        # error message is needed, put the localized message in the error details or
 | 
						|
        # localize it in the client. The optional error details may contain arbitrary
 | 
						|
        # information about the error. There is a predefined set of error detail types
 | 
						|
        # in the package `google.rpc` that can be used for common error conditions.
 | 
						|
        # # Language mapping
 | 
						|
        # The `Status` message is the logical representation of the error model, but it
 | 
						|
        # is not necessarily the actual wire format. When the `Status` message is
 | 
						|
        # exposed in different client libraries and different wire protocols, it can be
 | 
						|
        # mapped differently. For example, it will likely be mapped to some exceptions
 | 
						|
        # in Java, but more likely mapped to some error codes in C.
 | 
						|
        # # Other uses
 | 
						|
        # The error model and the `Status` message can be used in a variety of
 | 
						|
        # environments, either with or without APIs, to provide a
 | 
						|
        # consistent developer experience across different environments.
 | 
						|
        # Example uses of this error model include:
 | 
						|
        # - Partial errors. If a service needs to return partial errors to the client,
 | 
						|
        # it may embed the `Status` in the normal response to indicate the partial
 | 
						|
        # errors.
 | 
						|
        # - Workflow errors. A typical workflow has multiple steps. Each step may
 | 
						|
        # have a `Status` message for error reporting.
 | 
						|
        # - Batch operations. If a client uses batch request and batch response, the
 | 
						|
        # `Status` message should be used directly inside batch response, one for
 | 
						|
        # each error sub-response.
 | 
						|
        # - Asynchronous operations. If an API call embeds asynchronous operation
 | 
						|
        # results in its response, the status of those operations should be
 | 
						|
        # represented directly using the `Status` message.
 | 
						|
        # - Logging. If some API errors are stored in logs, the message `Status` could
 | 
						|
        # be used directly after any stripping needed for security/privacy reasons.
 | 
						|
        # Corresponds to the JSON property `error`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GoogleRpcStatus]
 | 
						|
        attr_accessor :error
 | 
						|
      
 | 
						|
        # This field will contain an InspectOperationMetadata object for `inspect.
 | 
						|
        # operations.create` or a RiskAnalysisOperationMetadata object for `dataSource.
 | 
						|
        # analyze`.  This will always be returned with the Operation.
 | 
						|
        # Corresponds to the JSON property `metadata`
 | 
						|
        # @return [Hash<String,Object>]
 | 
						|
        attr_accessor :metadata
 | 
						|
      
 | 
						|
        # The server-assigned name. The `name` should have the format of `inspect/
 | 
						|
        # operations/<identifier>`.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        # This field will contain an InspectOperationResult object for `inspect.
 | 
						|
        # operations.create` or a RiskAnalysisOperationResult object for `dataSource.
 | 
						|
        # analyze`.
 | 
						|
        # Corresponds to the JSON property `response`
 | 
						|
        # @return [Hash<String,Object>]
 | 
						|
        attr_accessor :response
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @done = args[:done] if args.key?(:done)
 | 
						|
          @error = args[:error] if args.key?(:error)
 | 
						|
          @metadata = args[:metadata] if args.key?(:metadata)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
          @response = args[:response] if args.key?(:response)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Request for creating a risk analysis operation.
 | 
						|
      class GooglePrivacyDlpV2beta1AnalyzeDataSourceRiskRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Privacy metric to compute for reidentification risk analysis.
 | 
						|
        # Corresponds to the JSON property `privacyMetric`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PrivacyMetric]
 | 
						|
        attr_accessor :privacy_metric
 | 
						|
      
 | 
						|
        # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
        # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
        # a table is often referenced with a string in the format of:
 | 
						|
        # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
        # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
        # Corresponds to the JSON property `sourceTable`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryTable]
 | 
						|
        attr_accessor :source_table
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @privacy_metric = args[:privacy_metric] if args.key?(:privacy_metric)
 | 
						|
          @source_table = args[:source_table] if args.key?(:source_table)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # An auxiliary table contains statistical information on the relative
 | 
						|
      # frequency of different quasi-identifiers values. It has one or several
 | 
						|
      # quasi-identifiers columns, and one column that indicates the relative
 | 
						|
      # frequency of each quasi-identifier tuple.
 | 
						|
      # If a tuple is present in the data but not in the auxiliary table, the
 | 
						|
      # corresponding relative frequency is assumed to be zero (and thus, the
 | 
						|
      # tuple is highly reidentifiable).
 | 
						|
      class GooglePrivacyDlpV2beta1AuxiliaryTable
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Quasi-identifier columns. [required]
 | 
						|
        # Corresponds to the JSON property `quasiIds`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1QuasiIdField>]
 | 
						|
        attr_accessor :quasi_ids
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `relativeFrequency`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :relative_frequency
 | 
						|
      
 | 
						|
        # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
        # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
        # a table is often referenced with a string in the format of:
 | 
						|
        # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
        # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
        # Corresponds to the JSON property `table`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryTable]
 | 
						|
        attr_accessor :table
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @quasi_ids = args[:quasi_ids] if args.key?(:quasi_ids)
 | 
						|
          @relative_frequency = args[:relative_frequency] if args.key?(:relative_frequency)
 | 
						|
          @table = args[:table] if args.key?(:table)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Options defining BigQuery table and row identifiers.
 | 
						|
      class GooglePrivacyDlpV2beta1BigQueryOptions
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # References to fields uniquely identifying rows within the table.
 | 
						|
        # Nested fields in the format, like `person.birthdate.year`, are allowed.
 | 
						|
        # Corresponds to the JSON property `identifyingFields`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId>]
 | 
						|
        attr_accessor :identifying_fields
 | 
						|
      
 | 
						|
        # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
        # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
        # a table is often referenced with a string in the format of:
 | 
						|
        # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
        # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
        # Corresponds to the JSON property `tableReference`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryTable]
 | 
						|
        attr_accessor :table_reference
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @identifying_fields = args[:identifying_fields] if args.key?(:identifying_fields)
 | 
						|
          @table_reference = args[:table_reference] if args.key?(:table_reference)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
      # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
      # a table is often referenced with a string in the format of:
 | 
						|
      # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
      # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
      class GooglePrivacyDlpV2beta1BigQueryTable
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Dataset ID of the table.
 | 
						|
        # Corresponds to the JSON property `datasetId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :dataset_id
 | 
						|
      
 | 
						|
        # The Google Cloud Platform project ID of the project containing the table.
 | 
						|
        # If omitted, project ID is inferred from the API call.
 | 
						|
        # Corresponds to the JSON property `projectId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :project_id
 | 
						|
      
 | 
						|
        # Name of the table.
 | 
						|
        # Corresponds to the JSON property `tableId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :table_id
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dataset_id = args[:dataset_id] if args.key?(:dataset_id)
 | 
						|
          @project_id = args[:project_id] if args.key?(:project_id)
 | 
						|
          @table_id = args[:table_id] if args.key?(:table_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Buckets represented as ranges, along with replacement values. Ranges must
 | 
						|
      # be non-overlapping.
 | 
						|
      class GooglePrivacyDlpV2beta1Bucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `max`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :max
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `min`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :min
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `replacementValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :replacement_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @max = args[:max] if args.key?(:max)
 | 
						|
          @min = args[:min] if args.key?(:min)
 | 
						|
          @replacement_value = args[:replacement_value] if args.key?(:replacement_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Generalization function that buckets values based on ranges. The ranges and
 | 
						|
      # replacement values are dynamically provided by the user for custom behavior,
 | 
						|
      # such as 1-30 -> LOW 31-65 -> MEDIUM 66-100 -> HIGH
 | 
						|
      # This can be used on
 | 
						|
      # data of type: number, long, string, timestamp.
 | 
						|
      # If the bound `Value` type differs from the type of data being transformed, we
 | 
						|
      # will first attempt converting the type of the data to be transformed to match
 | 
						|
      # the type of the bound before comparing.
 | 
						|
      class GooglePrivacyDlpV2beta1BucketingConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `buckets`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Bucket>]
 | 
						|
        attr_accessor :buckets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @buckets = args[:buckets] if args.key?(:buckets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Compute numerical stats over an individual column, including
 | 
						|
      # number of distinct values and value count distribution.
 | 
						|
      class GooglePrivacyDlpV2beta1CategoricalStatsConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Histogram bucket of value frequencies in the column.
 | 
						|
      class GooglePrivacyDlpV2beta1CategoricalStatsHistogramBucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Total number of records in this bucket.
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # Sample of value frequencies in this bucket. The total number of
 | 
						|
        # values returned per bucket is capped at 20.
 | 
						|
        # Corresponds to the JSON property `bucketValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ValueFrequency>]
 | 
						|
        attr_accessor :bucket_values
 | 
						|
      
 | 
						|
        # Lower bound on the value frequency of the values in this bucket.
 | 
						|
        # Corresponds to the JSON property `valueFrequencyLowerBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :value_frequency_lower_bound
 | 
						|
      
 | 
						|
        # Upper bound on the value frequency of the values in this bucket.
 | 
						|
        # Corresponds to the JSON property `valueFrequencyUpperBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :value_frequency_upper_bound
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @bucket_values = args[:bucket_values] if args.key?(:bucket_values)
 | 
						|
          @value_frequency_lower_bound = args[:value_frequency_lower_bound] if args.key?(:value_frequency_lower_bound)
 | 
						|
          @value_frequency_upper_bound = args[:value_frequency_upper_bound] if args.key?(:value_frequency_upper_bound)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of the categorical stats computation.
 | 
						|
      class GooglePrivacyDlpV2beta1CategoricalStatsResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Histogram of value frequencies in the column.
 | 
						|
        # Corresponds to the JSON property `valueFrequencyHistogramBuckets`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CategoricalStatsHistogramBucket>]
 | 
						|
        attr_accessor :value_frequency_histogram_buckets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @value_frequency_histogram_buckets = args[:value_frequency_histogram_buckets] if args.key?(:value_frequency_histogram_buckets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Info Type Category description.
 | 
						|
      class GooglePrivacyDlpV2beta1CategoryDescription
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Human readable form of the category name.
 | 
						|
        # Corresponds to the JSON property `displayName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :display_name
 | 
						|
      
 | 
						|
        # Internal name of the category.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @display_name = args[:display_name] if args.key?(:display_name)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Partially mask a string by replacing a given number of characters with a
 | 
						|
      # fixed character. Masking can start from the beginning or end of the string.
 | 
						|
      # This can be used on data of any type (numbers, longs, and so on) and when
 | 
						|
      # de-identifying structured data we'll attempt to preserve the original data's
 | 
						|
      # type. (This allows you to take a long like 123 and modify it to a string like
 | 
						|
      # **3.
 | 
						|
      class GooglePrivacyDlpV2beta1CharacterMaskConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # When masking a string, items in this list will be skipped when replacing.
 | 
						|
        # For example, if your string is 555-555-5555 and you ask us to skip `-` and
 | 
						|
        # mask 5 chars with * we would produce ***-*55-5555.
 | 
						|
        # Corresponds to the JSON property `charactersToIgnore`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CharsToIgnore>]
 | 
						|
        attr_accessor :characters_to_ignore
 | 
						|
      
 | 
						|
        # Character to mask the sensitive values—for example, "*" for an
 | 
						|
        # alphabetic string such as name, or "0" for a numeric string such as ZIP
 | 
						|
        # code or credit card number. String must have length 1. If not supplied, we
 | 
						|
        # will default to "*" for strings, 0 for digits.
 | 
						|
        # Corresponds to the JSON property `maskingCharacter`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :masking_character
 | 
						|
      
 | 
						|
        # Number of characters to mask. If not set, all matching chars will be
 | 
						|
        # masked. Skipped characters do not count towards this tally.
 | 
						|
        # Corresponds to the JSON property `numberToMask`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :number_to_mask
 | 
						|
      
 | 
						|
        # Mask characters in reverse order. For example, if `masking_character` is
 | 
						|
        # '0', number_to_mask is 14, and `reverse_order` is false, then
 | 
						|
        # 1234-5678-9012-3456 -> 00000000000000-3456
 | 
						|
        # If `masking_character` is '*', `number_to_mask` is 3, and `reverse_order`
 | 
						|
        # is true, then 12345 -> 12***
 | 
						|
        # Corresponds to the JSON property `reverseOrder`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :reverse_order
 | 
						|
        alias_method :reverse_order?, :reverse_order
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @characters_to_ignore = args[:characters_to_ignore] if args.key?(:characters_to_ignore)
 | 
						|
          @masking_character = args[:masking_character] if args.key?(:masking_character)
 | 
						|
          @number_to_mask = args[:number_to_mask] if args.key?(:number_to_mask)
 | 
						|
          @reverse_order = args[:reverse_order] if args.key?(:reverse_order)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Characters to skip when doing deidentification of a value. These will be left
 | 
						|
      # alone and skipped.
 | 
						|
      class GooglePrivacyDlpV2beta1CharsToIgnore
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `charactersToSkip`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :characters_to_skip
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `commonCharactersToIgnore`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :common_characters_to_ignore
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @characters_to_skip = args[:characters_to_skip] if args.key?(:characters_to_skip)
 | 
						|
          @common_characters_to_ignore = args[:common_characters_to_ignore] if args.key?(:common_characters_to_ignore)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Record key for a finding in a Cloud Storage file.
 | 
						|
      class GooglePrivacyDlpV2beta1CloudStorageKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Path to the file.
 | 
						|
        # Corresponds to the JSON property `filePath`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :file_path
 | 
						|
      
 | 
						|
        # Byte offset of the referenced data in the file.
 | 
						|
        # Corresponds to the JSON property `startOffset`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start_offset
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @file_path = args[:file_path] if args.key?(:file_path)
 | 
						|
          @start_offset = args[:start_offset] if args.key?(:start_offset)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Options defining a file or a set of files (path ending with *) within
 | 
						|
      # a Google Cloud Storage bucket.
 | 
						|
      class GooglePrivacyDlpV2beta1CloudStorageOptions
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of files to scan.
 | 
						|
        # Corresponds to the JSON property `fileSet`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FileSet]
 | 
						|
        attr_accessor :file_set
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @file_set = args[:file_set] if args.key?(:file_set)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A location in Cloud Storage.
 | 
						|
      class GooglePrivacyDlpV2beta1CloudStoragePath
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The url, in the format of `gs://bucket/<path>`.
 | 
						|
        # Corresponds to the JSON property `path`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :path
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @path = args[:path] if args.key?(:path)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Represents a color in the RGB color space.
 | 
						|
      class GooglePrivacyDlpV2beta1Color
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The amount of blue in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `blue`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :blue
 | 
						|
      
 | 
						|
        # The amount of green in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `green`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :green
 | 
						|
      
 | 
						|
        # The amount of red in the color as a value in the interval [0, 1].
 | 
						|
        # Corresponds to the JSON property `red`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :red
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @blue = args[:blue] if args.key?(:blue)
 | 
						|
          @green = args[:green] if args.key?(:green)
 | 
						|
          @red = args[:red] if args.key?(:red)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The field type of `value` and `field` do not need to match to be
 | 
						|
      # considered equal, but not all comparisons are possible.
 | 
						|
      # A `value` of type:
 | 
						|
      # - `string` can be compared against all other types
 | 
						|
      # - `boolean` can only be compared against other booleans
 | 
						|
      # - `integer` can be compared against doubles or a string if the string value
 | 
						|
      # can be parsed as an integer.
 | 
						|
      # - `double` can be compared against integers or a string if the string can
 | 
						|
      # be parsed as a double.
 | 
						|
      # - `Timestamp` can be compared against strings in RFC 3339 date string
 | 
						|
      # format.
 | 
						|
      # - `TimeOfDay` can be compared against timestamps and strings in the format
 | 
						|
      # of 'HH:mm:ss'.
 | 
						|
      # If we fail to compare do to type mismatch, a warning will be given and
 | 
						|
      # the condition will evaluate to false.
 | 
						|
      class GooglePrivacyDlpV2beta1Condition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        # Operator used to compare the field or info type to the value. [required]
 | 
						|
        # Corresponds to the JSON property `operator`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :operator
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `value`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
          @operator = args[:operator] if args.key?(:operator)
 | 
						|
          @value = args[:value] if args.key?(:value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # 
 | 
						|
      class GooglePrivacyDlpV2beta1Conditions
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `conditions`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Condition>]
 | 
						|
        attr_accessor :conditions
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @conditions = args[:conditions] if args.key?(:conditions)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Container structure for the content to inspect.
 | 
						|
      class GooglePrivacyDlpV2beta1ContentItem
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Content data to inspect or redact.
 | 
						|
        # Corresponds to the JSON property `data`
 | 
						|
        # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :data
 | 
						|
      
 | 
						|
        # Structured content to inspect. Up to 50,000 `Value`s per request allowed.
 | 
						|
        # Corresponds to the JSON property `table`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Table]
 | 
						|
        attr_accessor :table
 | 
						|
      
 | 
						|
        # Type of the content, as defined in Content-Type HTTP header.
 | 
						|
        # Supported types are: all "text" types, octet streams, PNG images,
 | 
						|
        # JPEG images.
 | 
						|
        # Corresponds to the JSON property `type`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :type
 | 
						|
      
 | 
						|
        # String data to inspect or redact.
 | 
						|
        # Corresponds to the JSON property `value`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @data = args[:data] if args.key?(:data)
 | 
						|
          @table = args[:table] if args.key?(:table)
 | 
						|
          @type = args[:type] if args.key?(:type)
 | 
						|
          @value = args[:value] if args.key?(:value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Request for scheduling a scan of a data subset from a Google Platform data
 | 
						|
      # repository.
 | 
						|
      class GooglePrivacyDlpV2beta1CreateInspectOperationRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Configuration description of the scanning process.
 | 
						|
        # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
        # used.
 | 
						|
        # Corresponds to the JSON property `inspectConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectConfig]
 | 
						|
        attr_accessor :inspect_config
 | 
						|
      
 | 
						|
        # Additional configuration for inspect long running operations.
 | 
						|
        # Corresponds to the JSON property `operationConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1OperationConfig]
 | 
						|
        attr_accessor :operation_config
 | 
						|
      
 | 
						|
        # Cloud repository for storing output.
 | 
						|
        # Corresponds to the JSON property `outputConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1OutputStorageConfig]
 | 
						|
        attr_accessor :output_config
 | 
						|
      
 | 
						|
        # Shared message indicating Cloud storage type.
 | 
						|
        # Corresponds to the JSON property `storageConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1StorageConfig]
 | 
						|
        attr_accessor :storage_config
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @inspect_config = args[:inspect_config] if args.key?(:inspect_config)
 | 
						|
          @operation_config = args[:operation_config] if args.key?(:operation_config)
 | 
						|
          @output_config = args[:output_config] if args.key?(:output_config)
 | 
						|
          @storage_config = args[:storage_config] if args.key?(:storage_config)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Pseudonymization method that generates surrogates via cryptographic hashing.
 | 
						|
      # Uses SHA-256.
 | 
						|
      # Outputs a 32 byte digest as an uppercase hex string
 | 
						|
      # (for example, 41D1567F7F99F1DC2A5FAB886DEE5BEE).
 | 
						|
      # Currently, only string and integer values can be hashed.
 | 
						|
      class GooglePrivacyDlpV2beta1CryptoHashConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # This is a data encryption key (DEK) (as opposed to
 | 
						|
        # a key encryption key (KEK) stored by KMS).
 | 
						|
        # When using KMS to wrap/unwrap DEKs, be sure to set an appropriate
 | 
						|
        # IAM policy on the KMS CryptoKey (KEK) to ensure an attacker cannot
 | 
						|
        # unwrap the data crypto key.
 | 
						|
        # Corresponds to the JSON property `cryptoKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CryptoKey]
 | 
						|
        attr_accessor :crypto_key
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @crypto_key = args[:crypto_key] if args.key?(:crypto_key)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # This is a data encryption key (DEK) (as opposed to
 | 
						|
      # a key encryption key (KEK) stored by KMS).
 | 
						|
      # When using KMS to wrap/unwrap DEKs, be sure to set an appropriate
 | 
						|
      # IAM policy on the KMS CryptoKey (KEK) to ensure an attacker cannot
 | 
						|
      # unwrap the data crypto key.
 | 
						|
      class GooglePrivacyDlpV2beta1CryptoKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Include to use an existing data crypto key wrapped by KMS.
 | 
						|
        # Authorization requires the following IAM permissions when sending a request
 | 
						|
        # to perform a crypto transformation using a kms-wrapped crypto key:
 | 
						|
        # dlp.kms.encrypt
 | 
						|
        # Corresponds to the JSON property `kmsWrapped`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KmsWrappedCryptoKey]
 | 
						|
        attr_accessor :kms_wrapped
 | 
						|
      
 | 
						|
        # Use this to have a random data crypto key generated.
 | 
						|
        # It will be discarded after the operation/request finishes.
 | 
						|
        # Corresponds to the JSON property `transient`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1TransientCryptoKey]
 | 
						|
        attr_accessor :transient
 | 
						|
      
 | 
						|
        # Using raw keys is prone to security risks due to accidentally
 | 
						|
        # leaking the key. Choose another type of key if possible.
 | 
						|
        # Corresponds to the JSON property `unwrapped`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1UnwrappedCryptoKey]
 | 
						|
        attr_accessor :unwrapped
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @kms_wrapped = args[:kms_wrapped] if args.key?(:kms_wrapped)
 | 
						|
          @transient = args[:transient] if args.key?(:transient)
 | 
						|
          @unwrapped = args[:unwrapped] if args.key?(:unwrapped)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Replaces an identifier with a surrogate using FPE with the FFX
 | 
						|
      # mode of operation.
 | 
						|
      # The identifier must be representable by the US-ASCII character set.
 | 
						|
      # For a given crypto key and context, the same identifier will be
 | 
						|
      # replaced with the same surrogate.
 | 
						|
      # Identifiers must be at least two characters long.
 | 
						|
      # In the case that the identifier is the empty string, it will be skipped.
 | 
						|
      class GooglePrivacyDlpV2beta1CryptoReplaceFfxFpeConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `commonAlphabet`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :common_alphabet
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `context`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :context
 | 
						|
      
 | 
						|
        # This is a data encryption key (DEK) (as opposed to
 | 
						|
        # a key encryption key (KEK) stored by KMS).
 | 
						|
        # When using KMS to wrap/unwrap DEKs, be sure to set an appropriate
 | 
						|
        # IAM policy on the KMS CryptoKey (KEK) to ensure an attacker cannot
 | 
						|
        # unwrap the data crypto key.
 | 
						|
        # Corresponds to the JSON property `cryptoKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CryptoKey]
 | 
						|
        attr_accessor :crypto_key
 | 
						|
      
 | 
						|
        # This is supported by mapping these to the alphanumeric characters
 | 
						|
        # that the FFX mode natively supports. This happens before/after
 | 
						|
        # encryption/decryption.
 | 
						|
        # Each character listed must appear only once.
 | 
						|
        # Number of characters must be in the range [2, 62].
 | 
						|
        # This must be encoded as ASCII.
 | 
						|
        # The order of characters does not matter.
 | 
						|
        # Corresponds to the JSON property `customAlphabet`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :custom_alphabet
 | 
						|
      
 | 
						|
        # The native way to select the alphabet. Must be in the range [2, 62].
 | 
						|
        # Corresponds to the JSON property `radix`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :radix
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `surrogateInfoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :surrogate_info_type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @common_alphabet = args[:common_alphabet] if args.key?(:common_alphabet)
 | 
						|
          @context = args[:context] if args.key?(:context)
 | 
						|
          @crypto_key = args[:crypto_key] if args.key?(:crypto_key)
 | 
						|
          @custom_alphabet = args[:custom_alphabet] if args.key?(:custom_alphabet)
 | 
						|
          @radix = args[:radix] if args.key?(:radix)
 | 
						|
          @surrogate_info_type = args[:surrogate_info_type] if args.key?(:surrogate_info_type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Custom information type provided by the user. Used to find domain-specific
 | 
						|
      # sensitive information configurable to the data in question.
 | 
						|
      class GooglePrivacyDlpV2beta1CustomInfoType
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Custom information type based on a dictionary of words or phrases. This can
 | 
						|
        # be used to match sensitive information specific to the data, such as a list
 | 
						|
        # of employee IDs or job titles.
 | 
						|
        # Dictionary words are case-insensitive and all characters other than letters
 | 
						|
        # and digits in the unicode [Basic Multilingual
 | 
						|
        # Plane](https://en.wikipedia.org/wiki/Plane_%28Unicode%29#
 | 
						|
        # Basic_Multilingual_Plane)
 | 
						|
        # will be replaced with whitespace when scanning for matches, so the
 | 
						|
        # dictionary phrase "Sam Johnson" will match all three phrases "sam johnson",
 | 
						|
        # "Sam, Johnson", and "Sam (Johnson)". Additionally, the characters
 | 
						|
        # surrounding any match must be of a different type than the adjacent
 | 
						|
        # characters within the word, so letters must be next to non-letters and
 | 
						|
        # digits next to non-digits. For example, the dictionary word "jen" will
 | 
						|
        # match the first three letters of the text "jen123" but will return no
 | 
						|
        # matches for "jennifer".
 | 
						|
        # Dictionary words containing a large number of characters that are not
 | 
						|
        # letters or digits may result in unexpected findings because such characters
 | 
						|
        # are treated as whitespace.
 | 
						|
        # Corresponds to the JSON property `dictionary`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Dictionary]
 | 
						|
        attr_accessor :dictionary
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # Message for detecting output from deidentification transformations
 | 
						|
        # such as
 | 
						|
        # [`CryptoReplaceFfxFpeConfig`](/dlp/docs/reference/rest/v2beta1/content/
 | 
						|
        # deidentify#CryptoReplaceFfxFpeConfig).
 | 
						|
        # These types of transformations are
 | 
						|
        # those that perform pseudonymization, thereby producing a "surrogate" as
 | 
						|
        # output. This should be used in conjunction with a field on the
 | 
						|
        # transformation such as `surrogate_info_type`.
 | 
						|
        # Corresponds to the JSON property `surrogateType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1SurrogateType]
 | 
						|
        attr_accessor :surrogate_type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @dictionary = args[:dictionary] if args.key?(:dictionary)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @surrogate_type = args[:surrogate_type] if args.key?(:surrogate_type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Record key for a finding in Cloud Datastore.
 | 
						|
      class GooglePrivacyDlpV2beta1DatastoreKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A unique identifier for a Datastore entity.
 | 
						|
        # If a key's partition ID or any of its path kinds or names are
 | 
						|
        # reserved/read-only, the key is reserved/read-only.
 | 
						|
        # A reserved/read-only key is forbidden in certain documented contexts.
 | 
						|
        # Corresponds to the JSON property `entityKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Key]
 | 
						|
        attr_accessor :entity_key
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @entity_key = args[:entity_key] if args.key?(:entity_key)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Options defining a data set within Google Cloud Datastore.
 | 
						|
      class GooglePrivacyDlpV2beta1DatastoreOptions
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A representation of a Datastore kind.
 | 
						|
        # Corresponds to the JSON property `kind`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KindExpression]
 | 
						|
        attr_accessor :kind
 | 
						|
      
 | 
						|
        # Datastore partition ID.
 | 
						|
        # A partition ID identifies a grouping of entities. The grouping is always
 | 
						|
        # by project and namespace, however the namespace ID may be empty.
 | 
						|
        # A partition ID contains several dimensions:
 | 
						|
        # project ID and namespace ID.
 | 
						|
        # Corresponds to the JSON property `partitionId`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PartitionId]
 | 
						|
        attr_accessor :partition_id
 | 
						|
      
 | 
						|
        # Properties to scan. If none are specified, all properties will be scanned
 | 
						|
        # by default.
 | 
						|
        # Corresponds to the JSON property `projection`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Projection>]
 | 
						|
        attr_accessor :projection
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @kind = args[:kind] if args.key?(:kind)
 | 
						|
          @partition_id = args[:partition_id] if args.key?(:partition_id)
 | 
						|
          @projection = args[:projection] if args.key?(:projection)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # High level summary of deidentification.
 | 
						|
      class GooglePrivacyDlpV2beta1DeidentificationSummary
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Transformations applied to the dataset.
 | 
						|
        # Corresponds to the JSON property `transformationSummaries`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1TransformationSummary>]
 | 
						|
        attr_accessor :transformation_summaries
 | 
						|
      
 | 
						|
        # Total size in bytes that were transformed in some way.
 | 
						|
        # Corresponds to the JSON property `transformedBytes`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :transformed_bytes
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @transformation_summaries = args[:transformation_summaries] if args.key?(:transformation_summaries)
 | 
						|
          @transformed_bytes = args[:transformed_bytes] if args.key?(:transformed_bytes)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The configuration that controls how the data will change.
 | 
						|
      class GooglePrivacyDlpV2beta1DeidentifyConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A type of transformation that will scan unstructured text and
 | 
						|
        # apply various `PrimitiveTransformation`s to each finding, where the
 | 
						|
        # transformation is applied to only values that were identified as a specific
 | 
						|
        # info_type.
 | 
						|
        # Corresponds to the JSON property `infoTypeTransformations`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeTransformations]
 | 
						|
        attr_accessor :info_type_transformations
 | 
						|
      
 | 
						|
        # A type of transformation that is applied over structured data such as a
 | 
						|
        # table.
 | 
						|
        # Corresponds to the JSON property `recordTransformations`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordTransformations]
 | 
						|
        attr_accessor :record_transformations
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_type_transformations = args[:info_type_transformations] if args.key?(:info_type_transformations)
 | 
						|
          @record_transformations = args[:record_transformations] if args.key?(:record_transformations)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Request to de-identify a list of items.
 | 
						|
      class GooglePrivacyDlpV2beta1DeidentifyContentRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The configuration that controls how the data will change.
 | 
						|
        # Corresponds to the JSON property `deidentifyConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1DeidentifyConfig]
 | 
						|
        attr_accessor :deidentify_config
 | 
						|
      
 | 
						|
        # Configuration description of the scanning process.
 | 
						|
        # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
        # used.
 | 
						|
        # Corresponds to the JSON property `inspectConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectConfig]
 | 
						|
        attr_accessor :inspect_config
 | 
						|
      
 | 
						|
        # The list of items to inspect. Up to 100 are allowed per request.
 | 
						|
        # All items will be treated as text/*.
 | 
						|
        # Corresponds to the JSON property `items`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ContentItem>]
 | 
						|
        attr_accessor :items
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @deidentify_config = args[:deidentify_config] if args.key?(:deidentify_config)
 | 
						|
          @inspect_config = args[:inspect_config] if args.key?(:inspect_config)
 | 
						|
          @items = args[:items] if args.key?(:items)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Results of de-identifying a list of items.
 | 
						|
      class GooglePrivacyDlpV2beta1DeidentifyContentResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `items`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ContentItem>]
 | 
						|
        attr_accessor :items
 | 
						|
      
 | 
						|
        # A review of the transformations that took place for each item.
 | 
						|
        # Corresponds to the JSON property `summaries`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1DeidentificationSummary>]
 | 
						|
        attr_accessor :summaries
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @items = args[:items] if args.key?(:items)
 | 
						|
          @summaries = args[:summaries] if args.key?(:summaries)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Custom information type based on a dictionary of words or phrases. This can
 | 
						|
      # be used to match sensitive information specific to the data, such as a list
 | 
						|
      # of employee IDs or job titles.
 | 
						|
      # Dictionary words are case-insensitive and all characters other than letters
 | 
						|
      # and digits in the unicode [Basic Multilingual
 | 
						|
      # Plane](https://en.wikipedia.org/wiki/Plane_%28Unicode%29#
 | 
						|
      # Basic_Multilingual_Plane)
 | 
						|
      # will be replaced with whitespace when scanning for matches, so the
 | 
						|
      # dictionary phrase "Sam Johnson" will match all three phrases "sam johnson",
 | 
						|
      # "Sam, Johnson", and "Sam (Johnson)". Additionally, the characters
 | 
						|
      # surrounding any match must be of a different type than the adjacent
 | 
						|
      # characters within the word, so letters must be next to non-letters and
 | 
						|
      # digits next to non-digits. For example, the dictionary word "jen" will
 | 
						|
      # match the first three letters of the text "jen123" but will return no
 | 
						|
      # matches for "jennifer".
 | 
						|
      # Dictionary words containing a large number of characters that are not
 | 
						|
      # letters or digits may result in unexpected findings because such characters
 | 
						|
      # are treated as whitespace.
 | 
						|
      class GooglePrivacyDlpV2beta1Dictionary
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Message defining a list of words or phrases to search for in the data.
 | 
						|
        # Corresponds to the JSON property `wordList`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1WordList]
 | 
						|
        attr_accessor :word_list
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @word_list = args[:word_list] if args.key?(:word_list)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # An entity in a dataset is a field or set of fields that correspond to a
 | 
						|
      # single person. For example, in medical records the `EntityId` might be
 | 
						|
      # a patient identifier, or for financial records it might be an account
 | 
						|
      # identifier. This message is used when generalizations or analysis must be
 | 
						|
      # consistent across multiple rows pertaining to the same entity.
 | 
						|
      class GooglePrivacyDlpV2beta1EntityId
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A collection of expressions
 | 
						|
      class GooglePrivacyDlpV2beta1Expressions
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `conditions`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Conditions]
 | 
						|
        attr_accessor :conditions
 | 
						|
      
 | 
						|
        # The operator to apply to the result of conditions. Default and currently
 | 
						|
        # only supported value is `AND`.
 | 
						|
        # Corresponds to the JSON property `logicalOperator`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :logical_operator
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @conditions = args[:conditions] if args.key?(:conditions)
 | 
						|
          @logical_operator = args[:logical_operator] if args.key?(:logical_operator)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # General identifier of a data field in a storage service.
 | 
						|
      class GooglePrivacyDlpV2beta1FieldId
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Name describing the field.
 | 
						|
        # Corresponds to the JSON property `columnName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :column_name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @column_name = args[:column_name] if args.key?(:column_name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The transformation to apply to the field.
 | 
						|
      class GooglePrivacyDlpV2beta1FieldTransformation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A condition for determining whether a transformation should be applied to
 | 
						|
        # a field.
 | 
						|
        # Corresponds to the JSON property `condition`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordCondition]
 | 
						|
        attr_accessor :condition
 | 
						|
      
 | 
						|
        # Input field(s) to apply the transformation to. [required]
 | 
						|
        # Corresponds to the JSON property `fields`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId>]
 | 
						|
        attr_accessor :fields
 | 
						|
      
 | 
						|
        # A type of transformation that will scan unstructured text and
 | 
						|
        # apply various `PrimitiveTransformation`s to each finding, where the
 | 
						|
        # transformation is applied to only values that were identified as a specific
 | 
						|
        # info_type.
 | 
						|
        # Corresponds to the JSON property `infoTypeTransformations`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeTransformations]
 | 
						|
        attr_accessor :info_type_transformations
 | 
						|
      
 | 
						|
        # A rule for transforming a value.
 | 
						|
        # Corresponds to the JSON property `primitiveTransformation`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PrimitiveTransformation]
 | 
						|
        attr_accessor :primitive_transformation
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @condition = args[:condition] if args.key?(:condition)
 | 
						|
          @fields = args[:fields] if args.key?(:fields)
 | 
						|
          @info_type_transformations = args[:info_type_transformations] if args.key?(:info_type_transformations)
 | 
						|
          @primitive_transformation = args[:primitive_transformation] if args.key?(:primitive_transformation)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Set of files to scan.
 | 
						|
      class GooglePrivacyDlpV2beta1FileSet
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The url, in the format `gs://<bucket>/<path>`. Trailing wildcard in the
 | 
						|
        # path is allowed.
 | 
						|
        # Corresponds to the JSON property `url`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :url
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @url = args[:url] if args.key?(:url)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Container structure describing a single finding within a string or image.
 | 
						|
      class GooglePrivacyDlpV2beta1Finding
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Timestamp when finding was detected.
 | 
						|
        # Corresponds to the JSON property `createTime`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :create_time
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # Estimate of how likely it is that the info_type is correct.
 | 
						|
        # Corresponds to the JSON property `likelihood`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :likelihood
 | 
						|
      
 | 
						|
        # Specifies the location of a finding within its source item.
 | 
						|
        # Corresponds to the JSON property `location`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Location]
 | 
						|
        attr_accessor :location
 | 
						|
      
 | 
						|
        # The specific string that may be potentially sensitive info.
 | 
						|
        # Corresponds to the JSON property `quote`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :quote
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @create_time = args[:create_time] if args.key?(:create_time)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @likelihood = args[:likelihood] if args.key?(:likelihood)
 | 
						|
          @location = args[:location] if args.key?(:location)
 | 
						|
          @quote = args[:quote] if args.key?(:quote)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Buckets values based on fixed size ranges. The
 | 
						|
      # Bucketing transformation can provide all of this functionality,
 | 
						|
      # but requires more configuration. This message is provided as a convenience to
 | 
						|
      # the user for simple bucketing strategies.
 | 
						|
      # The resulting value will be a hyphenated string of
 | 
						|
      # lower_bound-upper_bound.
 | 
						|
      # This can be used on data of type: double, long.
 | 
						|
      # If the bound Value type differs from the type of data
 | 
						|
      # being transformed, we will first attempt converting the type of the data to
 | 
						|
      # be transformed to match the type of the bound before comparing.
 | 
						|
      class GooglePrivacyDlpV2beta1FixedSizeBucketingConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Size of each bucket (except for minimum and maximum buckets). So if
 | 
						|
        # `lower_bound` = 10, `upper_bound` = 89, and `bucket_size` = 10, then the
 | 
						|
        # following buckets would be used: -10, 10-20, 20-30, 30-40, 40-50, 50-60,
 | 
						|
        # 60-70, 70-80, 80-89, 89+. Precision up to 2 decimals works. [Required].
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `lowerBound`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :lower_bound
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `upperBound`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :upper_bound
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @lower_bound = args[:lower_bound] if args.key?(:lower_bound)
 | 
						|
          @upper_bound = args[:upper_bound] if args.key?(:upper_bound)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Bounding box encompassing detected text within an image.
 | 
						|
      class GooglePrivacyDlpV2beta1ImageLocation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Height of the bounding box in pixels.
 | 
						|
        # Corresponds to the JSON property `height`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :height
 | 
						|
      
 | 
						|
        # Left coordinate of the bounding box. (0,0) is upper left.
 | 
						|
        # Corresponds to the JSON property `left`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :left
 | 
						|
      
 | 
						|
        # Top coordinate of the bounding box. (0,0) is upper left.
 | 
						|
        # Corresponds to the JSON property `top`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :top
 | 
						|
      
 | 
						|
        # Width of the bounding box in pixels.
 | 
						|
        # Corresponds to the JSON property `width`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :width
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @height = args[:height] if args.key?(:height)
 | 
						|
          @left = args[:left] if args.key?(:left)
 | 
						|
          @top = args[:top] if args.key?(:top)
 | 
						|
          @width = args[:width] if args.key?(:width)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Configuration for determining how redaction of images should occur.
 | 
						|
      class GooglePrivacyDlpV2beta1ImageRedactionConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # If true, all text found in the image, regardless whether it matches an
 | 
						|
        # info_type, is redacted.
 | 
						|
        # Corresponds to the JSON property `redactAllText`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :redact_all_text
 | 
						|
        alias_method :redact_all_text?, :redact_all_text
 | 
						|
      
 | 
						|
        # Represents a color in the RGB color space.
 | 
						|
        # Corresponds to the JSON property `redactionColor`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Color]
 | 
						|
        attr_accessor :redaction_color
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @redact_all_text = args[:redact_all_text] if args.key?(:redact_all_text)
 | 
						|
          @redaction_color = args[:redaction_color] if args.key?(:redaction_color)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Type of information detected by the API.
 | 
						|
      class GooglePrivacyDlpV2beta1InfoType
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Name of the information type.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Description of the information type (infoType).
 | 
						|
      class GooglePrivacyDlpV2beta1InfoTypeDescription
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # List of categories this infoType belongs to.
 | 
						|
        # Corresponds to the JSON property `categories`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CategoryDescription>]
 | 
						|
        attr_accessor :categories
 | 
						|
      
 | 
						|
        # Human readable form of the infoType name.
 | 
						|
        # Corresponds to the JSON property `displayName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :display_name
 | 
						|
      
 | 
						|
        # Internal name of the infoType.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @categories = args[:categories] if args.key?(:categories)
 | 
						|
          @display_name = args[:display_name] if args.key?(:display_name)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Max findings configuration per info type, per content item or long running
 | 
						|
      # operation.
 | 
						|
      class GooglePrivacyDlpV2beta1InfoTypeLimit
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # Max findings limit for the given infoType.
 | 
						|
        # Corresponds to the JSON property `maxFindings`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :max_findings
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @max_findings = args[:max_findings] if args.key?(:max_findings)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Statistics regarding a specific InfoType.
 | 
						|
      class GooglePrivacyDlpV2beta1InfoTypeStatistics
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Number of findings for this info type.
 | 
						|
        # Corresponds to the JSON property `count`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :count
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @count = args[:count] if args.key?(:count)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A transformation to apply to text that is identified as a specific
 | 
						|
      # info_type.
 | 
						|
      class GooglePrivacyDlpV2beta1InfoTypeTransformation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Info types to apply the transformation to. Empty list will match all
 | 
						|
        # available info types for this transformation.
 | 
						|
        # Corresponds to the JSON property `infoTypes`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType>]
 | 
						|
        attr_accessor :info_types
 | 
						|
      
 | 
						|
        # A rule for transforming a value.
 | 
						|
        # Corresponds to the JSON property `primitiveTransformation`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PrimitiveTransformation]
 | 
						|
        attr_accessor :primitive_transformation
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_types = args[:info_types] if args.key?(:info_types)
 | 
						|
          @primitive_transformation = args[:primitive_transformation] if args.key?(:primitive_transformation)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A type of transformation that will scan unstructured text and
 | 
						|
      # apply various `PrimitiveTransformation`s to each finding, where the
 | 
						|
      # transformation is applied to only values that were identified as a specific
 | 
						|
      # info_type.
 | 
						|
      class GooglePrivacyDlpV2beta1InfoTypeTransformations
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Transformation for each info type. Cannot specify more than one
 | 
						|
        # for a given info type. [required]
 | 
						|
        # Corresponds to the JSON property `transformations`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeTransformation>]
 | 
						|
        attr_accessor :transformations
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @transformations = args[:transformations] if args.key?(:transformations)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Configuration description of the scanning process.
 | 
						|
      # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
      # used.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Custom info types provided by the user.
 | 
						|
        # Corresponds to the JSON property `customInfoTypes`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CustomInfoType>]
 | 
						|
        attr_accessor :custom_info_types
 | 
						|
      
 | 
						|
        # When true, excludes type information of the findings.
 | 
						|
        # Corresponds to the JSON property `excludeTypes`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :exclude_types
 | 
						|
        alias_method :exclude_types?, :exclude_types
 | 
						|
      
 | 
						|
        # When true, a contextual quote from the data that triggered a finding is
 | 
						|
        # included in the response; see Finding.quote.
 | 
						|
        # Corresponds to the JSON property `includeQuote`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :include_quote
 | 
						|
        alias_method :include_quote?, :include_quote
 | 
						|
      
 | 
						|
        # Configuration of findings limit given for specified info types.
 | 
						|
        # Corresponds to the JSON property `infoTypeLimits`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeLimit>]
 | 
						|
        attr_accessor :info_type_limits
 | 
						|
      
 | 
						|
        # Restricts what info_types to look for. The values must correspond to
 | 
						|
        # InfoType values returned by ListInfoTypes or found in documentation.
 | 
						|
        # Empty info_types runs all enabled detectors.
 | 
						|
        # Corresponds to the JSON property `infoTypes`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType>]
 | 
						|
        attr_accessor :info_types
 | 
						|
      
 | 
						|
        # Limits the number of findings per content item or long running operation.
 | 
						|
        # Corresponds to the JSON property `maxFindings`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :max_findings
 | 
						|
      
 | 
						|
        # Only returns findings equal or above this threshold.
 | 
						|
        # Corresponds to the JSON property `minLikelihood`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :min_likelihood
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @custom_info_types = args[:custom_info_types] if args.key?(:custom_info_types)
 | 
						|
          @exclude_types = args[:exclude_types] if args.key?(:exclude_types)
 | 
						|
          @include_quote = args[:include_quote] if args.key?(:include_quote)
 | 
						|
          @info_type_limits = args[:info_type_limits] if args.key?(:info_type_limits)
 | 
						|
          @info_types = args[:info_types] if args.key?(:info_types)
 | 
						|
          @max_findings = args[:max_findings] if args.key?(:max_findings)
 | 
						|
          @min_likelihood = args[:min_likelihood] if args.key?(:min_likelihood)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Request to search for potentially sensitive info in a list of items.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectContentRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Configuration description of the scanning process.
 | 
						|
        # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
        # used.
 | 
						|
        # Corresponds to the JSON property `inspectConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectConfig]
 | 
						|
        attr_accessor :inspect_config
 | 
						|
      
 | 
						|
        # The list of items to inspect. Items in a single request are
 | 
						|
        # considered "related" unless inspect_config.independent_inputs is true.
 | 
						|
        # Up to 100 are allowed per request.
 | 
						|
        # Corresponds to the JSON property `items`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ContentItem>]
 | 
						|
        attr_accessor :items
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @inspect_config = args[:inspect_config] if args.key?(:inspect_config)
 | 
						|
          @items = args[:items] if args.key?(:items)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Results of inspecting a list of items.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectContentResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Each content_item from the request has a result in this list, in the
 | 
						|
        # same order as the request.
 | 
						|
        # Corresponds to the JSON property `results`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectResult>]
 | 
						|
        attr_accessor :results
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @results = args[:results] if args.key?(:results)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Metadata returned within GetOperation for an inspect request.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectOperationMetadata
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The time which this request was started.
 | 
						|
        # Corresponds to the JSON property `createTime`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :create_time
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `infoTypeStats`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeStatistics>]
 | 
						|
        attr_accessor :info_type_stats
 | 
						|
      
 | 
						|
        # Total size in bytes that were processed.
 | 
						|
        # Corresponds to the JSON property `processedBytes`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :processed_bytes
 | 
						|
      
 | 
						|
        # Configuration description of the scanning process.
 | 
						|
        # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
        # used.
 | 
						|
        # Corresponds to the JSON property `requestInspectConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectConfig]
 | 
						|
        attr_accessor :request_inspect_config
 | 
						|
      
 | 
						|
        # Cloud repository for storing output.
 | 
						|
        # Corresponds to the JSON property `requestOutputConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1OutputStorageConfig]
 | 
						|
        attr_accessor :request_output_config
 | 
						|
      
 | 
						|
        # Shared message indicating Cloud storage type.
 | 
						|
        # Corresponds to the JSON property `requestStorageConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1StorageConfig]
 | 
						|
        attr_accessor :request_storage_config
 | 
						|
      
 | 
						|
        # Estimate of the number of bytes to process.
 | 
						|
        # Corresponds to the JSON property `totalEstimatedBytes`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :total_estimated_bytes
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @create_time = args[:create_time] if args.key?(:create_time)
 | 
						|
          @info_type_stats = args[:info_type_stats] if args.key?(:info_type_stats)
 | 
						|
          @processed_bytes = args[:processed_bytes] if args.key?(:processed_bytes)
 | 
						|
          @request_inspect_config = args[:request_inspect_config] if args.key?(:request_inspect_config)
 | 
						|
          @request_output_config = args[:request_output_config] if args.key?(:request_output_config)
 | 
						|
          @request_storage_config = args[:request_storage_config] if args.key?(:request_storage_config)
 | 
						|
          @total_estimated_bytes = args[:total_estimated_bytes] if args.key?(:total_estimated_bytes)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The operational data.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectOperationResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The server-assigned name, which is only unique within the same service that
 | 
						|
        # originally returns it. If you use the default HTTP mapping, the
 | 
						|
        # `name` should have the format of `inspect/results/`id``.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # All the findings for a single scanned item.
 | 
						|
      class GooglePrivacyDlpV2beta1InspectResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # List of findings for an item.
 | 
						|
        # Corresponds to the JSON property `findings`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Finding>]
 | 
						|
        attr_accessor :findings
 | 
						|
      
 | 
						|
        # If true, then this item might have more findings than were returned,
 | 
						|
        # and the findings returned are an arbitrary subset of all findings.
 | 
						|
        # The findings list might be truncated because the input items were too
 | 
						|
        # large, or because the server reached the maximum amount of resources
 | 
						|
        # allowed for a single API call. For best results, divide the input into
 | 
						|
        # smaller batches.
 | 
						|
        # Corresponds to the JSON property `findingsTruncated`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :findings_truncated
 | 
						|
        alias_method :findings_truncated?, :findings_truncated
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @findings = args[:findings] if args.key?(:findings)
 | 
						|
          @findings_truncated = args[:findings_truncated] if args.key?(:findings_truncated)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # k-anonymity metric, used for analysis of reidentification risk.
 | 
						|
      class GooglePrivacyDlpV2beta1KAnonymityConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # An entity in a dataset is a field or set of fields that correspond to a
 | 
						|
        # single person. For example, in medical records the `EntityId` might be
 | 
						|
        # a patient identifier, or for financial records it might be an account
 | 
						|
        # identifier. This message is used when generalizations or analysis must be
 | 
						|
        # consistent across multiple rows pertaining to the same entity.
 | 
						|
        # Corresponds to the JSON property `entityId`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1EntityId]
 | 
						|
        attr_accessor :entity_id
 | 
						|
      
 | 
						|
        # Set of fields to compute k-anonymity over. When multiple fields are
 | 
						|
        # specified, they are considered a single composite key. Structs and
 | 
						|
        # repeated data types are not supported; however, nested fields are
 | 
						|
        # supported so long as they are not structs themselves or nested within
 | 
						|
        # a repeated field.
 | 
						|
        # Corresponds to the JSON property `quasiIds`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId>]
 | 
						|
        attr_accessor :quasi_ids
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @entity_id = args[:entity_id] if args.key?(:entity_id)
 | 
						|
          @quasi_ids = args[:quasi_ids] if args.key?(:quasi_ids)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The set of columns' values that share the same k-anonymity value.
 | 
						|
      class GooglePrivacyDlpV2beta1KAnonymityEquivalenceClass
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Size of the equivalence class, for example number of rows with the
 | 
						|
        # above set of values.
 | 
						|
        # Corresponds to the JSON property `equivalenceClassSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :equivalence_class_size
 | 
						|
      
 | 
						|
        # Set of values defining the equivalence class. One value per
 | 
						|
        # quasi-identifier column in the original KAnonymity metric message.
 | 
						|
        # The order is always the same as the original request.
 | 
						|
        # Corresponds to the JSON property `quasiIdsValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value>]
 | 
						|
        attr_accessor :quasi_ids_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @equivalence_class_size = args[:equivalence_class_size] if args.key?(:equivalence_class_size)
 | 
						|
          @quasi_ids_values = args[:quasi_ids_values] if args.key?(:quasi_ids_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Histogram bucket of equivalence class sizes in the table.
 | 
						|
      class GooglePrivacyDlpV2beta1KAnonymityHistogramBucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Total number of records in this bucket.
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # Sample of equivalence classes in this bucket. The total number of
 | 
						|
        # classes returned per bucket is capped at 20.
 | 
						|
        # Corresponds to the JSON property `bucketValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KAnonymityEquivalenceClass>]
 | 
						|
        attr_accessor :bucket_values
 | 
						|
      
 | 
						|
        # Lower bound on the size of the equivalence classes in this bucket.
 | 
						|
        # Corresponds to the JSON property `equivalenceClassSizeLowerBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :equivalence_class_size_lower_bound
 | 
						|
      
 | 
						|
        # Upper bound on the size of the equivalence classes in this bucket.
 | 
						|
        # Corresponds to the JSON property `equivalenceClassSizeUpperBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :equivalence_class_size_upper_bound
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @bucket_values = args[:bucket_values] if args.key?(:bucket_values)
 | 
						|
          @equivalence_class_size_lower_bound = args[:equivalence_class_size_lower_bound] if args.key?(:equivalence_class_size_lower_bound)
 | 
						|
          @equivalence_class_size_upper_bound = args[:equivalence_class_size_upper_bound] if args.key?(:equivalence_class_size_upper_bound)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of the k-anonymity computation.
 | 
						|
      class GooglePrivacyDlpV2beta1KAnonymityResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Histogram of k-anonymity equivalence classes.
 | 
						|
        # Corresponds to the JSON property `equivalenceClassHistogramBuckets`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KAnonymityHistogramBucket>]
 | 
						|
        attr_accessor :equivalence_class_histogram_buckets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @equivalence_class_histogram_buckets = args[:equivalence_class_histogram_buckets] if args.key?(:equivalence_class_histogram_buckets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Reidentifiability metric. This corresponds to a risk model similar to what
 | 
						|
      # is called "journalist risk" in the literature, except the attack dataset is
 | 
						|
      # statistically modeled instead of being perfectly known. This can be done
 | 
						|
      # using publicly available data (like the US Census), or using a custom
 | 
						|
      # statistical model (indicated as one or several BigQuery tables), or by
 | 
						|
      # extrapolating from the distribution of values in the input dataset.
 | 
						|
      class GooglePrivacyDlpV2beta1KMapEstimationConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Several auxiliary tables can be used in the analysis. Each custom_tag
 | 
						|
        # used to tag a quasi-identifiers column must appear in exactly one column
 | 
						|
        # of one auxiliary table.
 | 
						|
        # Corresponds to the JSON property `auxiliaryTables`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1AuxiliaryTable>]
 | 
						|
        attr_accessor :auxiliary_tables
 | 
						|
      
 | 
						|
        # Fields considered to be quasi-identifiers. No two columns can have the
 | 
						|
        # same tag. [required]
 | 
						|
        # Corresponds to the JSON property `quasiIds`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1TaggedField>]
 | 
						|
        attr_accessor :quasi_ids
 | 
						|
      
 | 
						|
        # ISO 3166-1 alpha-2 region code to use in the statistical modeling.
 | 
						|
        # Required if no column is tagged with a region-specific InfoType (like
 | 
						|
        # US_ZIP_5) or a region code.
 | 
						|
        # Corresponds to the JSON property `regionCode`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :region_code
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @auxiliary_tables = args[:auxiliary_tables] if args.key?(:auxiliary_tables)
 | 
						|
          @quasi_ids = args[:quasi_ids] if args.key?(:quasi_ids)
 | 
						|
          @region_code = args[:region_code] if args.key?(:region_code)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A KMapEstimationHistogramBucket message with the following values:
 | 
						|
      # min_anonymity: 3
 | 
						|
      # max_anonymity: 5
 | 
						|
      # frequency: 42
 | 
						|
      # means that there are 42 records whose quasi-identifier values correspond
 | 
						|
      # to 3, 4 or 5 people in the overlying population. An important particular
 | 
						|
      # case is when min_anonymity = max_anonymity = 1: the frequency field then
 | 
						|
      # corresponds to the number of uniquely identifiable records.
 | 
						|
      class GooglePrivacyDlpV2beta1KMapEstimationHistogramBucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Number of records within these anonymity bounds.
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # Sample of quasi-identifier tuple values in this bucket. The total
 | 
						|
        # number of classes returned per bucket is capped at 20.
 | 
						|
        # Corresponds to the JSON property `bucketValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KMapEstimationQuasiIdValues>]
 | 
						|
        attr_accessor :bucket_values
 | 
						|
      
 | 
						|
        # Always greater than or equal to min_anonymity.
 | 
						|
        # Corresponds to the JSON property `maxAnonymity`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :max_anonymity
 | 
						|
      
 | 
						|
        # Always positive.
 | 
						|
        # Corresponds to the JSON property `minAnonymity`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :min_anonymity
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @bucket_values = args[:bucket_values] if args.key?(:bucket_values)
 | 
						|
          @max_anonymity = args[:max_anonymity] if args.key?(:max_anonymity)
 | 
						|
          @min_anonymity = args[:min_anonymity] if args.key?(:min_anonymity)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A tuple of values for the quasi-identifier columns.
 | 
						|
      class GooglePrivacyDlpV2beta1KMapEstimationQuasiIdValues
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The estimated anonymity for these quasi-identifier values.
 | 
						|
        # Corresponds to the JSON property `estimatedAnonymity`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :estimated_anonymity
 | 
						|
      
 | 
						|
        # The quasi-identifier values.
 | 
						|
        # Corresponds to the JSON property `quasiIdsValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value>]
 | 
						|
        attr_accessor :quasi_ids_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @estimated_anonymity = args[:estimated_anonymity] if args.key?(:estimated_anonymity)
 | 
						|
          @quasi_ids_values = args[:quasi_ids_values] if args.key?(:quasi_ids_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of the reidentifiability analysis. Note that these results are an
 | 
						|
      # estimation, not exact values.
 | 
						|
      class GooglePrivacyDlpV2beta1KMapEstimationResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The intervals [min_anonymity, max_anonymity] do not overlap. If a value
 | 
						|
        # doesn't correspond to any such interval, the associated frequency is
 | 
						|
        # zero. For example, the following records:
 | 
						|
        # `min_anonymity: 1, max_anonymity: 1, frequency: 17`
 | 
						|
        # `min_anonymity: 2, max_anonymity: 3, frequency: 42`
 | 
						|
        # `min_anonymity: 5, max_anonymity: 10, frequency: 99`
 | 
						|
        # mean that there are no record with an estimated anonymity of 4, 5, or
 | 
						|
        # larger than 10.
 | 
						|
        # Corresponds to the JSON property `kMapEstimationHistogram`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KMapEstimationHistogramBucket>]
 | 
						|
        attr_accessor :k_map_estimation_histogram
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @k_map_estimation_histogram = args[:k_map_estimation_histogram] if args.key?(:k_map_estimation_histogram)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A unique identifier for a Datastore entity.
 | 
						|
      # If a key's partition ID or any of its path kinds or names are
 | 
						|
      # reserved/read-only, the key is reserved/read-only.
 | 
						|
      # A reserved/read-only key is forbidden in certain documented contexts.
 | 
						|
      class GooglePrivacyDlpV2beta1Key
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Datastore partition ID.
 | 
						|
        # A partition ID identifies a grouping of entities. The grouping is always
 | 
						|
        # by project and namespace, however the namespace ID may be empty.
 | 
						|
        # A partition ID contains several dimensions:
 | 
						|
        # project ID and namespace ID.
 | 
						|
        # Corresponds to the JSON property `partitionId`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PartitionId]
 | 
						|
        attr_accessor :partition_id
 | 
						|
      
 | 
						|
        # The entity path.
 | 
						|
        # An entity path consists of one or more elements composed of a kind and a
 | 
						|
        # string or numerical identifier, which identify entities. The first
 | 
						|
        # element identifies a _root entity_, the second element identifies
 | 
						|
        # a _child_ of the root entity, the third element identifies a child of the
 | 
						|
        # second entity, and so forth. The entities identified by all prefixes of
 | 
						|
        # the path are called the element's _ancestors_.
 | 
						|
        # A path can never be empty, and a path can have at most 100 elements.
 | 
						|
        # Corresponds to the JSON property `path`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PathElement>]
 | 
						|
        attr_accessor :path
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @partition_id = args[:partition_id] if args.key?(:partition_id)
 | 
						|
          @path = args[:path] if args.key?(:path)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A representation of a Datastore kind.
 | 
						|
      class GooglePrivacyDlpV2beta1KindExpression
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The name of the kind.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Include to use an existing data crypto key wrapped by KMS.
 | 
						|
      # Authorization requires the following IAM permissions when sending a request
 | 
						|
      # to perform a crypto transformation using a kms-wrapped crypto key:
 | 
						|
      # dlp.kms.encrypt
 | 
						|
      class GooglePrivacyDlpV2beta1KmsWrappedCryptoKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The resource name of the KMS CryptoKey to use for unwrapping. [required]
 | 
						|
        # Corresponds to the JSON property `cryptoKeyName`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :crypto_key_name
 | 
						|
      
 | 
						|
        # The wrapped data crypto key. [required]
 | 
						|
        # Corresponds to the JSON property `wrappedKey`
 | 
						|
        # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :wrapped_key
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @crypto_key_name = args[:crypto_key_name] if args.key?(:crypto_key_name)
 | 
						|
          @wrapped_key = args[:wrapped_key] if args.key?(:wrapped_key)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # l-diversity metric, used for analysis of reidentification risk.
 | 
						|
      class GooglePrivacyDlpV2beta1LDiversityConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of quasi-identifiers indicating how equivalence classes are
 | 
						|
        # defined for the l-diversity computation. When multiple fields are
 | 
						|
        # specified, they are considered a single composite key.
 | 
						|
        # Corresponds to the JSON property `quasiIds`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId>]
 | 
						|
        attr_accessor :quasi_ids
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `sensitiveAttribute`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :sensitive_attribute
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @quasi_ids = args[:quasi_ids] if args.key?(:quasi_ids)
 | 
						|
          @sensitive_attribute = args[:sensitive_attribute] if args.key?(:sensitive_attribute)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The set of columns' values that share the same l-diversity value.
 | 
						|
      class GooglePrivacyDlpV2beta1LDiversityEquivalenceClass
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Size of the k-anonymity equivalence class.
 | 
						|
        # Corresponds to the JSON property `equivalenceClassSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :equivalence_class_size
 | 
						|
      
 | 
						|
        # Number of distinct sensitive values in this equivalence class.
 | 
						|
        # Corresponds to the JSON property `numDistinctSensitiveValues`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :num_distinct_sensitive_values
 | 
						|
      
 | 
						|
        # Quasi-identifier values defining the k-anonymity equivalence
 | 
						|
        # class. The order is always the same as the original request.
 | 
						|
        # Corresponds to the JSON property `quasiIdsValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value>]
 | 
						|
        attr_accessor :quasi_ids_values
 | 
						|
      
 | 
						|
        # Estimated frequencies of top sensitive values.
 | 
						|
        # Corresponds to the JSON property `topSensitiveValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ValueFrequency>]
 | 
						|
        attr_accessor :top_sensitive_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @equivalence_class_size = args[:equivalence_class_size] if args.key?(:equivalence_class_size)
 | 
						|
          @num_distinct_sensitive_values = args[:num_distinct_sensitive_values] if args.key?(:num_distinct_sensitive_values)
 | 
						|
          @quasi_ids_values = args[:quasi_ids_values] if args.key?(:quasi_ids_values)
 | 
						|
          @top_sensitive_values = args[:top_sensitive_values] if args.key?(:top_sensitive_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Histogram bucket of sensitive value frequencies in the table.
 | 
						|
      class GooglePrivacyDlpV2beta1LDiversityHistogramBucket
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Total number of records in this bucket.
 | 
						|
        # Corresponds to the JSON property `bucketSize`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :bucket_size
 | 
						|
      
 | 
						|
        # Sample of equivalence classes in this bucket. The total number of
 | 
						|
        # classes returned per bucket is capped at 20.
 | 
						|
        # Corresponds to the JSON property `bucketValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1LDiversityEquivalenceClass>]
 | 
						|
        attr_accessor :bucket_values
 | 
						|
      
 | 
						|
        # Lower bound on the sensitive value frequencies of the equivalence
 | 
						|
        # classes in this bucket.
 | 
						|
        # Corresponds to the JSON property `sensitiveValueFrequencyLowerBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sensitive_value_frequency_lower_bound
 | 
						|
      
 | 
						|
        # Upper bound on the sensitive value frequencies of the equivalence
 | 
						|
        # classes in this bucket.
 | 
						|
        # Corresponds to the JSON property `sensitiveValueFrequencyUpperBound`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :sensitive_value_frequency_upper_bound
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucket_size = args[:bucket_size] if args.key?(:bucket_size)
 | 
						|
          @bucket_values = args[:bucket_values] if args.key?(:bucket_values)
 | 
						|
          @sensitive_value_frequency_lower_bound = args[:sensitive_value_frequency_lower_bound] if args.key?(:sensitive_value_frequency_lower_bound)
 | 
						|
          @sensitive_value_frequency_upper_bound = args[:sensitive_value_frequency_upper_bound] if args.key?(:sensitive_value_frequency_upper_bound)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of the l-diversity computation.
 | 
						|
      class GooglePrivacyDlpV2beta1LDiversityResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Histogram of l-diversity equivalence class sensitive value frequencies.
 | 
						|
        # Corresponds to the JSON property `sensitiveValueFrequencyHistogramBuckets`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1LDiversityHistogramBucket>]
 | 
						|
        attr_accessor :sensitive_value_frequency_histogram_buckets
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @sensitive_value_frequency_histogram_buckets = args[:sensitive_value_frequency_histogram_buckets] if args.key?(:sensitive_value_frequency_histogram_buckets)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Response to the ListInfoTypes request.
 | 
						|
      class GooglePrivacyDlpV2beta1ListInfoTypesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of sensitive info types belonging to a category.
 | 
						|
        # Corresponds to the JSON property `infoTypes`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoTypeDescription>]
 | 
						|
        attr_accessor :info_types
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_types = args[:info_types] if args.key?(:info_types)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Response to the ListInspectFindings request.
 | 
						|
      class GooglePrivacyDlpV2beta1ListInspectFindingsResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # If not empty, indicates that there may be more results that match the
 | 
						|
        # request; this value should be passed in a new `ListInspectFindingsRequest`.
 | 
						|
        # Corresponds to the JSON property `nextPageToken`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :next_page_token
 | 
						|
      
 | 
						|
        # All the findings for a single scanned item.
 | 
						|
        # Corresponds to the JSON property `result`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectResult]
 | 
						|
        attr_accessor :result
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @next_page_token = args[:next_page_token] if args.key?(:next_page_token)
 | 
						|
          @result = args[:result] if args.key?(:result)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Response for ListRootCategories request.
 | 
						|
      class GooglePrivacyDlpV2beta1ListRootCategoriesResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # List of all into type categories supported by the API.
 | 
						|
        # Corresponds to the JSON property `categories`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CategoryDescription>]
 | 
						|
        attr_accessor :categories
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @categories = args[:categories] if args.key?(:categories)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Specifies the location of a finding within its source item.
 | 
						|
      class GooglePrivacyDlpV2beta1Location
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Generic half-open interval [start, end)
 | 
						|
        # Corresponds to the JSON property `byteRange`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Range]
 | 
						|
        attr_accessor :byte_range
 | 
						|
      
 | 
						|
        # Generic half-open interval [start, end)
 | 
						|
        # Corresponds to the JSON property `codepointRange`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Range]
 | 
						|
        attr_accessor :codepoint_range
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `fieldId`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field_id
 | 
						|
      
 | 
						|
        # Location within an image's pixels.
 | 
						|
        # Corresponds to the JSON property `imageBoxes`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ImageLocation>]
 | 
						|
        attr_accessor :image_boxes
 | 
						|
      
 | 
						|
        # Message for a unique key indicating a record that contains a finding.
 | 
						|
        # Corresponds to the JSON property `recordKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordKey]
 | 
						|
        attr_accessor :record_key
 | 
						|
      
 | 
						|
        # Location of a finding within a `ContentItem.Table`.
 | 
						|
        # Corresponds to the JSON property `tableLocation`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1TableLocation]
 | 
						|
        attr_accessor :table_location
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @byte_range = args[:byte_range] if args.key?(:byte_range)
 | 
						|
          @codepoint_range = args[:codepoint_range] if args.key?(:codepoint_range)
 | 
						|
          @field_id = args[:field_id] if args.key?(:field_id)
 | 
						|
          @image_boxes = args[:image_boxes] if args.key?(:image_boxes)
 | 
						|
          @record_key = args[:record_key] if args.key?(:record_key)
 | 
						|
          @table_location = args[:table_location] if args.key?(:table_location)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Compute numerical stats over an individual column, including
 | 
						|
      # min, max, and quantiles.
 | 
						|
      class GooglePrivacyDlpV2beta1NumericalStatsConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of the numerical stats computation.
 | 
						|
      class GooglePrivacyDlpV2beta1NumericalStatsResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `maxValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :max_value
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `minValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :min_value
 | 
						|
      
 | 
						|
        # List of 99 values that partition the set of field values into 100 equal
 | 
						|
        # sized buckets.
 | 
						|
        # Corresponds to the JSON property `quantileValues`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value>]
 | 
						|
        attr_accessor :quantile_values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @max_value = args[:max_value] if args.key?(:max_value)
 | 
						|
          @min_value = args[:min_value] if args.key?(:min_value)
 | 
						|
          @quantile_values = args[:quantile_values] if args.key?(:quantile_values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Additional configuration for inspect long running operations.
 | 
						|
      class GooglePrivacyDlpV2beta1OperationConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Max number of findings per file, Datastore entity, or database row.
 | 
						|
        # Corresponds to the JSON property `maxItemFindings`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :max_item_findings
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @max_item_findings = args[:max_item_findings] if args.key?(:max_item_findings)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Cloud repository for storing output.
 | 
						|
      class GooglePrivacyDlpV2beta1OutputStorageConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A location in Cloud Storage.
 | 
						|
        # Corresponds to the JSON property `storagePath`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CloudStoragePath]
 | 
						|
        attr_accessor :storage_path
 | 
						|
      
 | 
						|
        # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
        # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
        # a table is often referenced with a string in the format of:
 | 
						|
        # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
        # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
        # Corresponds to the JSON property `table`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryTable]
 | 
						|
        attr_accessor :table
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @storage_path = args[:storage_path] if args.key?(:storage_path)
 | 
						|
          @table = args[:table] if args.key?(:table)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Datastore partition ID.
 | 
						|
      # A partition ID identifies a grouping of entities. The grouping is always
 | 
						|
      # by project and namespace, however the namespace ID may be empty.
 | 
						|
      # A partition ID contains several dimensions:
 | 
						|
      # project ID and namespace ID.
 | 
						|
      class GooglePrivacyDlpV2beta1PartitionId
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # If not empty, the ID of the namespace to which the entities belong.
 | 
						|
        # Corresponds to the JSON property `namespaceId`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :namespace_id
 | 
						|
      
 | 
						|
        # The ID of the project to which the entities belong.
 | 
						|
        # 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)
 | 
						|
          @namespace_id = args[:namespace_id] if args.key?(:namespace_id)
 | 
						|
          @project_id = args[:project_id] if args.key?(:project_id)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A (kind, ID/name) pair used to construct a key path.
 | 
						|
      # If either name or ID is set, the element is complete.
 | 
						|
      # If neither is set, the element is incomplete.
 | 
						|
      class GooglePrivacyDlpV2beta1PathElement
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The auto-allocated ID of the entity.
 | 
						|
        # Never equal to zero. Values less than zero are discouraged and may not
 | 
						|
        # be supported in the future.
 | 
						|
        # Corresponds to the JSON property `id`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :id
 | 
						|
      
 | 
						|
        # The kind of the entity.
 | 
						|
        # A kind matching regex `__.*__` is reserved/read-only.
 | 
						|
        # A kind must not contain more than 1500 bytes when UTF-8 encoded.
 | 
						|
        # Cannot be `""`.
 | 
						|
        # Corresponds to the JSON property `kind`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :kind
 | 
						|
      
 | 
						|
        # The name of the entity.
 | 
						|
        # A name matching regex `__.*__` is reserved/read-only.
 | 
						|
        # A name must not be more than 1500 bytes when UTF-8 encoded.
 | 
						|
        # Cannot be `""`.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @id = args[:id] if args.key?(:id)
 | 
						|
          @kind = args[:kind] if args.key?(:kind)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A rule for transforming a value.
 | 
						|
      class GooglePrivacyDlpV2beta1PrimitiveTransformation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Generalization function that buckets values based on ranges. The ranges and
 | 
						|
        # replacement values are dynamically provided by the user for custom behavior,
 | 
						|
        # such as 1-30 -> LOW 31-65 -> MEDIUM 66-100 -> HIGH
 | 
						|
        # This can be used on
 | 
						|
        # data of type: number, long, string, timestamp.
 | 
						|
        # If the bound `Value` type differs from the type of data being transformed, we
 | 
						|
        # will first attempt converting the type of the data to be transformed to match
 | 
						|
        # the type of the bound before comparing.
 | 
						|
        # Corresponds to the JSON property `bucketingConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BucketingConfig]
 | 
						|
        attr_accessor :bucketing_config
 | 
						|
      
 | 
						|
        # Partially mask a string by replacing a given number of characters with a
 | 
						|
        # fixed character. Masking can start from the beginning or end of the string.
 | 
						|
        # This can be used on data of any type (numbers, longs, and so on) and when
 | 
						|
        # de-identifying structured data we'll attempt to preserve the original data's
 | 
						|
        # type. (This allows you to take a long like 123 and modify it to a string like
 | 
						|
        # **3.
 | 
						|
        # Corresponds to the JSON property `characterMaskConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CharacterMaskConfig]
 | 
						|
        attr_accessor :character_mask_config
 | 
						|
      
 | 
						|
        # Pseudonymization method that generates surrogates via cryptographic hashing.
 | 
						|
        # Uses SHA-256.
 | 
						|
        # Outputs a 32 byte digest as an uppercase hex string
 | 
						|
        # (for example, 41D1567F7F99F1DC2A5FAB886DEE5BEE).
 | 
						|
        # Currently, only string and integer values can be hashed.
 | 
						|
        # Corresponds to the JSON property `cryptoHashConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CryptoHashConfig]
 | 
						|
        attr_accessor :crypto_hash_config
 | 
						|
      
 | 
						|
        # Replaces an identifier with a surrogate using FPE with the FFX
 | 
						|
        # mode of operation.
 | 
						|
        # The identifier must be representable by the US-ASCII character set.
 | 
						|
        # For a given crypto key and context, the same identifier will be
 | 
						|
        # replaced with the same surrogate.
 | 
						|
        # Identifiers must be at least two characters long.
 | 
						|
        # In the case that the identifier is the empty string, it will be skipped.
 | 
						|
        # Corresponds to the JSON property `cryptoReplaceFfxFpeConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CryptoReplaceFfxFpeConfig]
 | 
						|
        attr_accessor :crypto_replace_ffx_fpe_config
 | 
						|
      
 | 
						|
        # Buckets values based on fixed size ranges. The
 | 
						|
        # Bucketing transformation can provide all of this functionality,
 | 
						|
        # but requires more configuration. This message is provided as a convenience to
 | 
						|
        # the user for simple bucketing strategies.
 | 
						|
        # The resulting value will be a hyphenated string of
 | 
						|
        # lower_bound-upper_bound.
 | 
						|
        # This can be used on data of type: double, long.
 | 
						|
        # If the bound Value type differs from the type of data
 | 
						|
        # being transformed, we will first attempt converting the type of the data to
 | 
						|
        # be transformed to match the type of the bound before comparing.
 | 
						|
        # Corresponds to the JSON property `fixedSizeBucketingConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FixedSizeBucketingConfig]
 | 
						|
        attr_accessor :fixed_size_bucketing_config
 | 
						|
      
 | 
						|
        # Redact a given value. For example, if used with an `InfoTypeTransformation`
 | 
						|
        # transforming PHONE_NUMBER, and input 'My phone number is 206-555-0123', the
 | 
						|
        # output would be 'My phone number is '.
 | 
						|
        # Corresponds to the JSON property `redactConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RedactConfig]
 | 
						|
        attr_accessor :redact_config
 | 
						|
      
 | 
						|
        # Replace each input value with a given `Value`.
 | 
						|
        # Corresponds to the JSON property `replaceConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ReplaceValueConfig]
 | 
						|
        attr_accessor :replace_config
 | 
						|
      
 | 
						|
        # Replace each matching finding with the name of the info_type.
 | 
						|
        # Corresponds to the JSON property `replaceWithInfoTypeConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ReplaceWithInfoTypeConfig]
 | 
						|
        attr_accessor :replace_with_info_type_config
 | 
						|
      
 | 
						|
        # For use with `Date`, `Timestamp`, and `TimeOfDay`, extract or preserve a
 | 
						|
        # portion of the value.
 | 
						|
        # Corresponds to the JSON property `timePartConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1TimePartConfig]
 | 
						|
        attr_accessor :time_part_config
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @bucketing_config = args[:bucketing_config] if args.key?(:bucketing_config)
 | 
						|
          @character_mask_config = args[:character_mask_config] if args.key?(:character_mask_config)
 | 
						|
          @crypto_hash_config = args[:crypto_hash_config] if args.key?(:crypto_hash_config)
 | 
						|
          @crypto_replace_ffx_fpe_config = args[:crypto_replace_ffx_fpe_config] if args.key?(:crypto_replace_ffx_fpe_config)
 | 
						|
          @fixed_size_bucketing_config = args[:fixed_size_bucketing_config] if args.key?(:fixed_size_bucketing_config)
 | 
						|
          @redact_config = args[:redact_config] if args.key?(:redact_config)
 | 
						|
          @replace_config = args[:replace_config] if args.key?(:replace_config)
 | 
						|
          @replace_with_info_type_config = args[:replace_with_info_type_config] if args.key?(:replace_with_info_type_config)
 | 
						|
          @time_part_config = args[:time_part_config] if args.key?(:time_part_config)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Privacy metric to compute for reidentification risk analysis.
 | 
						|
      class GooglePrivacyDlpV2beta1PrivacyMetric
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Compute numerical stats over an individual column, including
 | 
						|
        # number of distinct values and value count distribution.
 | 
						|
        # Corresponds to the JSON property `categoricalStatsConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CategoricalStatsConfig]
 | 
						|
        attr_accessor :categorical_stats_config
 | 
						|
      
 | 
						|
        # k-anonymity metric, used for analysis of reidentification risk.
 | 
						|
        # Corresponds to the JSON property `kAnonymityConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KAnonymityConfig]
 | 
						|
        attr_accessor :k_anonymity_config
 | 
						|
      
 | 
						|
        # Reidentifiability metric. This corresponds to a risk model similar to what
 | 
						|
        # is called "journalist risk" in the literature, except the attack dataset is
 | 
						|
        # statistically modeled instead of being perfectly known. This can be done
 | 
						|
        # using publicly available data (like the US Census), or using a custom
 | 
						|
        # statistical model (indicated as one or several BigQuery tables), or by
 | 
						|
        # extrapolating from the distribution of values in the input dataset.
 | 
						|
        # Corresponds to the JSON property `kMapEstimationConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KMapEstimationConfig]
 | 
						|
        attr_accessor :k_map_estimation_config
 | 
						|
      
 | 
						|
        # l-diversity metric, used for analysis of reidentification risk.
 | 
						|
        # Corresponds to the JSON property `lDiversityConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1LDiversityConfig]
 | 
						|
        attr_accessor :l_diversity_config
 | 
						|
      
 | 
						|
        # Compute numerical stats over an individual column, including
 | 
						|
        # min, max, and quantiles.
 | 
						|
        # Corresponds to the JSON property `numericalStatsConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1NumericalStatsConfig]
 | 
						|
        attr_accessor :numerical_stats_config
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @categorical_stats_config = args[:categorical_stats_config] if args.key?(:categorical_stats_config)
 | 
						|
          @k_anonymity_config = args[:k_anonymity_config] if args.key?(:k_anonymity_config)
 | 
						|
          @k_map_estimation_config = args[:k_map_estimation_config] if args.key?(:k_map_estimation_config)
 | 
						|
          @l_diversity_config = args[:l_diversity_config] if args.key?(:l_diversity_config)
 | 
						|
          @numerical_stats_config = args[:numerical_stats_config] if args.key?(:numerical_stats_config)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A representation of a Datastore property in a projection.
 | 
						|
      class GooglePrivacyDlpV2beta1Projection
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A reference to a property relative to the Datastore kind expressions.
 | 
						|
        # Corresponds to the JSON property `property`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PropertyReference]
 | 
						|
        attr_accessor :property
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @property = args[:property] if args.key?(:property)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A reference to a property relative to the Datastore kind expressions.
 | 
						|
      class GooglePrivacyDlpV2beta1PropertyReference
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The name of the property.
 | 
						|
        # If name includes "."s, it may be interpreted as a property name path.
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A quasi-identifier column has a custom_tag, used to know which column
 | 
						|
      # in the data corresponds to which column in the statistical model.
 | 
						|
      class GooglePrivacyDlpV2beta1QuasiIdField
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `customTag`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :custom_tag
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @custom_tag = args[:custom_tag] if args.key?(:custom_tag)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Generic half-open interval [start, end)
 | 
						|
      class GooglePrivacyDlpV2beta1Range
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Index of the last character of the range (exclusive).
 | 
						|
        # Corresponds to the JSON property `end`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :end
 | 
						|
      
 | 
						|
        # Index of the first character of the range (inclusive).
 | 
						|
        # Corresponds to the JSON property `start`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :start
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @end = args[:end] if args.key?(:end)
 | 
						|
          @start = args[:start] if args.key?(:start)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A condition for determining whether a transformation should be applied to
 | 
						|
      # a field.
 | 
						|
      class GooglePrivacyDlpV2beta1RecordCondition
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A collection of expressions
 | 
						|
        # Corresponds to the JSON property `expressions`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Expressions]
 | 
						|
        attr_accessor :expressions
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @expressions = args[:expressions] if args.key?(:expressions)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Message for a unique key indicating a record that contains a finding.
 | 
						|
      class GooglePrivacyDlpV2beta1RecordKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Record key for a finding in a Cloud Storage file.
 | 
						|
        # Corresponds to the JSON property `cloudStorageKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CloudStorageKey]
 | 
						|
        attr_accessor :cloud_storage_key
 | 
						|
      
 | 
						|
        # Record key for a finding in Cloud Datastore.
 | 
						|
        # Corresponds to the JSON property `datastoreKey`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1DatastoreKey]
 | 
						|
        attr_accessor :datastore_key
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @cloud_storage_key = args[:cloud_storage_key] if args.key?(:cloud_storage_key)
 | 
						|
          @datastore_key = args[:datastore_key] if args.key?(:datastore_key)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Configuration to suppress records whose suppression conditions evaluate to
 | 
						|
      # true.
 | 
						|
      class GooglePrivacyDlpV2beta1RecordSuppression
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A condition for determining whether a transformation should be applied to
 | 
						|
        # a field.
 | 
						|
        # Corresponds to the JSON property `condition`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordCondition]
 | 
						|
        attr_accessor :condition
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @condition = args[:condition] if args.key?(:condition)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A type of transformation that is applied over structured data such as a
 | 
						|
      # table.
 | 
						|
      class GooglePrivacyDlpV2beta1RecordTransformations
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Transform the record by applying various field transformations.
 | 
						|
        # Corresponds to the JSON property `fieldTransformations`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldTransformation>]
 | 
						|
        attr_accessor :field_transformations
 | 
						|
      
 | 
						|
        # Configuration defining which records get suppressed entirely. Records that
 | 
						|
        # match any suppression rule are omitted from the output [optional].
 | 
						|
        # Corresponds to the JSON property `recordSuppressions`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordSuppression>]
 | 
						|
        attr_accessor :record_suppressions
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field_transformations = args[:field_transformations] if args.key?(:field_transformations)
 | 
						|
          @record_suppressions = args[:record_suppressions] if args.key?(:record_suppressions)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Redact a given value. For example, if used with an `InfoTypeTransformation`
 | 
						|
      # transforming PHONE_NUMBER, and input 'My phone number is 206-555-0123', the
 | 
						|
      # output would be 'My phone number is '.
 | 
						|
      class GooglePrivacyDlpV2beta1RedactConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Request to search for potentially sensitive info in a list of items
 | 
						|
      # and replace it with a default or provided content.
 | 
						|
      class GooglePrivacyDlpV2beta1RedactContentRequest
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The configuration for specifying what content to redact from images.
 | 
						|
        # Corresponds to the JSON property `imageRedactionConfigs`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ImageRedactionConfig>]
 | 
						|
        attr_accessor :image_redaction_configs
 | 
						|
      
 | 
						|
        # Configuration description of the scanning process.
 | 
						|
        # When used with redactContent only info_types and min_likelihood are currently
 | 
						|
        # used.
 | 
						|
        # Corresponds to the JSON property `inspectConfig`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InspectConfig]
 | 
						|
        attr_accessor :inspect_config
 | 
						|
      
 | 
						|
        # The list of items to inspect. Up to 100 are allowed per request.
 | 
						|
        # Corresponds to the JSON property `items`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ContentItem>]
 | 
						|
        attr_accessor :items
 | 
						|
      
 | 
						|
        # The strings to replace findings text findings with. Must specify at least
 | 
						|
        # one of these or one ImageRedactionConfig if redacting images.
 | 
						|
        # Corresponds to the JSON property `replaceConfigs`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ReplaceConfig>]
 | 
						|
        attr_accessor :replace_configs
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @image_redaction_configs = args[:image_redaction_configs] if args.key?(:image_redaction_configs)
 | 
						|
          @inspect_config = args[:inspect_config] if args.key?(:inspect_config)
 | 
						|
          @items = args[:items] if args.key?(:items)
 | 
						|
          @replace_configs = args[:replace_configs] if args.key?(:replace_configs)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Results of redacting a list of items.
 | 
						|
      class GooglePrivacyDlpV2beta1RedactContentResponse
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The redacted content.
 | 
						|
        # Corresponds to the JSON property `items`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1ContentItem>]
 | 
						|
        attr_accessor :items
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @items = args[:items] if args.key?(:items)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # 
 | 
						|
      class GooglePrivacyDlpV2beta1ReplaceConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # Content replacing sensitive information of given type. Max 256 chars.
 | 
						|
        # Corresponds to the JSON property `replaceWith`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :replace_with
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @replace_with = args[:replace_with] if args.key?(:replace_with)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Replace each input value with a given `Value`.
 | 
						|
      class GooglePrivacyDlpV2beta1ReplaceValueConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `newValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :new_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @new_value = args[:new_value] if args.key?(:new_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Replace each matching finding with the name of the info_type.
 | 
						|
      class GooglePrivacyDlpV2beta1ReplaceWithInfoTypeConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Metadata returned within the
 | 
						|
      # [`riskAnalysis.operations.get`](/dlp/docs/reference/rest/v2beta1/riskAnalysis.
 | 
						|
      # operations/get)
 | 
						|
      # for risk analysis.
 | 
						|
      class GooglePrivacyDlpV2beta1RiskAnalysisOperationMetadata
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The time which this request was started.
 | 
						|
        # Corresponds to the JSON property `createTime`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :create_time
 | 
						|
      
 | 
						|
        # Privacy metric to compute for reidentification risk analysis.
 | 
						|
        # Corresponds to the JSON property `requestedPrivacyMetric`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PrivacyMetric]
 | 
						|
        attr_accessor :requested_privacy_metric
 | 
						|
      
 | 
						|
        # Message defining the location of a BigQuery table. A table is uniquely
 | 
						|
        # identified  by its project_id, dataset_id, and table_name. Within a query
 | 
						|
        # a table is often referenced with a string in the format of:
 | 
						|
        # `<project_id>:<dataset_id>.<table_id>` or
 | 
						|
        # `<project_id>.<dataset_id>.<table_id>`.
 | 
						|
        # Corresponds to the JSON property `requestedSourceTable`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryTable]
 | 
						|
        attr_accessor :requested_source_table
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @create_time = args[:create_time] if args.key?(:create_time)
 | 
						|
          @requested_privacy_metric = args[:requested_privacy_metric] if args.key?(:requested_privacy_metric)
 | 
						|
          @requested_source_table = args[:requested_source_table] if args.key?(:requested_source_table)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Result of a risk analysis
 | 
						|
      # [`Operation`](/dlp/docs/reference/rest/v2beta1/inspect.operations)
 | 
						|
      # request.
 | 
						|
      class GooglePrivacyDlpV2beta1RiskAnalysisOperationResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Result of the categorical stats computation.
 | 
						|
        # Corresponds to the JSON property `categoricalStatsResult`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CategoricalStatsResult]
 | 
						|
        attr_accessor :categorical_stats_result
 | 
						|
      
 | 
						|
        # Result of the k-anonymity computation.
 | 
						|
        # Corresponds to the JSON property `kAnonymityResult`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KAnonymityResult]
 | 
						|
        attr_accessor :k_anonymity_result
 | 
						|
      
 | 
						|
        # Result of the reidentifiability analysis. Note that these results are an
 | 
						|
        # estimation, not exact values.
 | 
						|
        # Corresponds to the JSON property `kMapEstimationResult`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1KMapEstimationResult]
 | 
						|
        attr_accessor :k_map_estimation_result
 | 
						|
      
 | 
						|
        # Result of the l-diversity computation.
 | 
						|
        # Corresponds to the JSON property `lDiversityResult`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1LDiversityResult]
 | 
						|
        attr_accessor :l_diversity_result
 | 
						|
      
 | 
						|
        # Result of the numerical stats computation.
 | 
						|
        # Corresponds to the JSON property `numericalStatsResult`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1NumericalStatsResult]
 | 
						|
        attr_accessor :numerical_stats_result
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @categorical_stats_result = args[:categorical_stats_result] if args.key?(:categorical_stats_result)
 | 
						|
          @k_anonymity_result = args[:k_anonymity_result] if args.key?(:k_anonymity_result)
 | 
						|
          @k_map_estimation_result = args[:k_map_estimation_result] if args.key?(:k_map_estimation_result)
 | 
						|
          @l_diversity_result = args[:l_diversity_result] if args.key?(:l_diversity_result)
 | 
						|
          @numerical_stats_result = args[:numerical_stats_result] if args.key?(:numerical_stats_result)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # 
 | 
						|
      class GooglePrivacyDlpV2beta1Row
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `values`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value>]
 | 
						|
        attr_accessor :values
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @values = args[:values] if args.key?(:values)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Shared message indicating Cloud storage type.
 | 
						|
      class GooglePrivacyDlpV2beta1StorageConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Options defining BigQuery table and row identifiers.
 | 
						|
        # Corresponds to the JSON property `bigQueryOptions`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1BigQueryOptions]
 | 
						|
        attr_accessor :big_query_options
 | 
						|
      
 | 
						|
        # Options defining a file or a set of files (path ending with *) within
 | 
						|
        # a Google Cloud Storage bucket.
 | 
						|
        # Corresponds to the JSON property `cloudStorageOptions`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1CloudStorageOptions]
 | 
						|
        attr_accessor :cloud_storage_options
 | 
						|
      
 | 
						|
        # Options defining a data set within Google Cloud Datastore.
 | 
						|
        # Corresponds to the JSON property `datastoreOptions`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1DatastoreOptions]
 | 
						|
        attr_accessor :datastore_options
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @big_query_options = args[:big_query_options] if args.key?(:big_query_options)
 | 
						|
          @cloud_storage_options = args[:cloud_storage_options] if args.key?(:cloud_storage_options)
 | 
						|
          @datastore_options = args[:datastore_options] if args.key?(:datastore_options)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A collection that informs the user the number of times a particular
 | 
						|
      # `TransformationResultCode` and error details occurred.
 | 
						|
      class GooglePrivacyDlpV2beta1SummaryResult
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `code`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :code
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `count`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :count
 | 
						|
      
 | 
						|
        # A place for warnings or errors to show up if a transformation didn't
 | 
						|
        # work as expected.
 | 
						|
        # Corresponds to the JSON property `details`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :details
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @code = args[:code] if args.key?(:code)
 | 
						|
          @count = args[:count] if args.key?(:count)
 | 
						|
          @details = args[:details] if args.key?(:details)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Message for detecting output from deidentification transformations
 | 
						|
      # such as
 | 
						|
      # [`CryptoReplaceFfxFpeConfig`](/dlp/docs/reference/rest/v2beta1/content/
 | 
						|
      # deidentify#CryptoReplaceFfxFpeConfig).
 | 
						|
      # These types of transformations are
 | 
						|
      # those that perform pseudonymization, thereby producing a "surrogate" as
 | 
						|
      # output. This should be used in conjunction with a field on the
 | 
						|
      # transformation such as `surrogate_info_type`.
 | 
						|
      class GooglePrivacyDlpV2beta1SurrogateType
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Structured content to inspect. Up to 50,000 `Value`s per request allowed.
 | 
						|
      class GooglePrivacyDlpV2beta1Table
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `headers`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId>]
 | 
						|
        attr_accessor :headers
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `rows`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Row>]
 | 
						|
        attr_accessor :rows
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @headers = args[:headers] if args.key?(:headers)
 | 
						|
          @rows = args[:rows] if args.key?(:rows)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Location of a finding within a `ContentItem.Table`.
 | 
						|
      class GooglePrivacyDlpV2beta1TableLocation
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The zero-based index of the row where the finding is located.
 | 
						|
        # Corresponds to the JSON property `rowIndex`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :row_index
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @row_index = args[:row_index] if args.key?(:row_index)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A column with a semantic tag attached.
 | 
						|
      class GooglePrivacyDlpV2beta1TaggedField
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # A column can be tagged with a custom tag. In this case, the user must
 | 
						|
        # indicate an auxiliary table that contains statistical information on
 | 
						|
        # the possible values of this column (below).
 | 
						|
        # Corresponds to the JSON property `customTag`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :custom_tag
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        # 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 ````.
 | 
						|
        # Corresponds to the JSON property `inferred`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GoogleProtobufEmpty]
 | 
						|
        attr_accessor :inferred
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @custom_tag = args[:custom_tag] if args.key?(:custom_tag)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
          @inferred = args[:inferred] if args.key?(:inferred)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # For use with `Date`, `Timestamp`, and `TimeOfDay`, extract or preserve a
 | 
						|
      # portion of the value.
 | 
						|
      class GooglePrivacyDlpV2beta1TimePartConfig
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `partToExtract`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :part_to_extract
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @part_to_extract = args[:part_to_extract] if args.key?(:part_to_extract)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Summary of a single tranformation.
 | 
						|
      class GooglePrivacyDlpV2beta1TransformationSummary
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # General identifier of a data field in a storage service.
 | 
						|
        # Corresponds to the JSON property `field`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldId]
 | 
						|
        attr_accessor :field
 | 
						|
      
 | 
						|
        # The field transformation that was applied. This list will contain
 | 
						|
        # multiple only in the case of errors.
 | 
						|
        # Corresponds to the JSON property `fieldTransformations`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1FieldTransformation>]
 | 
						|
        attr_accessor :field_transformations
 | 
						|
      
 | 
						|
        # Type of information detected by the API.
 | 
						|
        # Corresponds to the JSON property `infoType`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1InfoType]
 | 
						|
        attr_accessor :info_type
 | 
						|
      
 | 
						|
        # Configuration to suppress records whose suppression conditions evaluate to
 | 
						|
        # true.
 | 
						|
        # Corresponds to the JSON property `recordSuppress`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1RecordSuppression]
 | 
						|
        attr_accessor :record_suppress
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `results`
 | 
						|
        # @return [Array<Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1SummaryResult>]
 | 
						|
        attr_accessor :results
 | 
						|
      
 | 
						|
        # A rule for transforming a value.
 | 
						|
        # Corresponds to the JSON property `transformation`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1PrimitiveTransformation]
 | 
						|
        attr_accessor :transformation
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @field = args[:field] if args.key?(:field)
 | 
						|
          @field_transformations = args[:field_transformations] if args.key?(:field_transformations)
 | 
						|
          @info_type = args[:info_type] if args.key?(:info_type)
 | 
						|
          @record_suppress = args[:record_suppress] if args.key?(:record_suppress)
 | 
						|
          @results = args[:results] if args.key?(:results)
 | 
						|
          @transformation = args[:transformation] if args.key?(:transformation)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Use this to have a random data crypto key generated.
 | 
						|
      # It will be discarded after the operation/request finishes.
 | 
						|
      class GooglePrivacyDlpV2beta1TransientCryptoKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Name of the key. [required]
 | 
						|
        # This is an arbitrary string used to differentiate different keys.
 | 
						|
        # A unique key is generated per name: two separate `TransientCryptoKey`
 | 
						|
        # protos share the same generated key if their names are the same.
 | 
						|
        # When the data crypto key is generated, this name is not used in any way
 | 
						|
        # (repeating the api call will result in a different key being generated).
 | 
						|
        # Corresponds to the JSON property `name`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :name
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @name = args[:name] if args.key?(:name)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Using raw keys is prone to security risks due to accidentally
 | 
						|
      # leaking the key. Choose another type of key if possible.
 | 
						|
      class GooglePrivacyDlpV2beta1UnwrappedCryptoKey
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The AES 128/192/256 bit key. [required]
 | 
						|
        # Corresponds to the JSON property `key`
 | 
						|
        # NOTE: Values are automatically base64 encoded/decoded in the client library.
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :key
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @key = args[:key] if args.key?(:key)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Set of primitive values supported by the system.
 | 
						|
      class GooglePrivacyDlpV2beta1Value
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `booleanValue`
 | 
						|
        # @return [Boolean]
 | 
						|
        attr_accessor :boolean_value
 | 
						|
        alias_method :boolean_value?, :boolean_value
 | 
						|
      
 | 
						|
        # Represents a whole calendar date, e.g. date of birth. The time of day and
 | 
						|
        # time zone are either specified elsewhere or are not significant. The date
 | 
						|
        # is relative to the Proleptic Gregorian Calendar. The day may be 0 to
 | 
						|
        # represent a year and month where the day is not significant, e.g. credit card
 | 
						|
        # expiration date. The year may be 0 to represent a month and day independent
 | 
						|
        # of year, e.g. anniversary date. Related types are google.type.TimeOfDay
 | 
						|
        # and `google.protobuf.Timestamp`.
 | 
						|
        # Corresponds to the JSON property `dateValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GoogleTypeDate]
 | 
						|
        attr_accessor :date_value
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `floatValue`
 | 
						|
        # @return [Float]
 | 
						|
        attr_accessor :float_value
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `integerValue`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :integer_value
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `stringValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :string_value
 | 
						|
      
 | 
						|
        # Represents a time of day. The date and time zone are either not significant
 | 
						|
        # or are specified elsewhere. An API may choose to allow leap seconds. Related
 | 
						|
        # types are google.type.Date and `google.protobuf.Timestamp`.
 | 
						|
        # Corresponds to the JSON property `timeValue`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GoogleTypeTimeOfDay]
 | 
						|
        attr_accessor :time_value
 | 
						|
      
 | 
						|
        # 
 | 
						|
        # Corresponds to the JSON property `timestampValue`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :timestamp_value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @boolean_value = args[:boolean_value] if args.key?(:boolean_value)
 | 
						|
          @date_value = args[:date_value] if args.key?(:date_value)
 | 
						|
          @float_value = args[:float_value] if args.key?(:float_value)
 | 
						|
          @integer_value = args[:integer_value] if args.key?(:integer_value)
 | 
						|
          @string_value = args[:string_value] if args.key?(:string_value)
 | 
						|
          @time_value = args[:time_value] if args.key?(:time_value)
 | 
						|
          @timestamp_value = args[:timestamp_value] if args.key?(:timestamp_value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # A value of a field, including its frequency.
 | 
						|
      class GooglePrivacyDlpV2beta1ValueFrequency
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # How many times the value is contained in the field.
 | 
						|
        # Corresponds to the JSON property `count`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :count
 | 
						|
      
 | 
						|
        # Set of primitive values supported by the system.
 | 
						|
        # Corresponds to the JSON property `value`
 | 
						|
        # @return [Google::Apis::DlpV2beta1::GooglePrivacyDlpV2beta1Value]
 | 
						|
        attr_accessor :value
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @count = args[:count] if args.key?(:count)
 | 
						|
          @value = args[:value] if args.key?(:value)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Message defining a list of words or phrases to search for in the data.
 | 
						|
      class GooglePrivacyDlpV2beta1WordList
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Words or phrases defining the dictionary. The dictionary must contain
 | 
						|
        # at least one phrase and every phrase must contain at least 2 characters
 | 
						|
        # that are letters or digits. [required]
 | 
						|
        # Corresponds to the JSON property `words`
 | 
						|
        # @return [Array<String>]
 | 
						|
        attr_accessor :words
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @words = args[:words] if args.key?(:words)
 | 
						|
        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 GoogleProtobufEmpty
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # The `Status` type defines a logical error model that is suitable for different
 | 
						|
      # programming environments, including REST APIs and RPC APIs. It is used by
 | 
						|
      # [gRPC](https://github.com/grpc). The error model is designed to be:
 | 
						|
      # - Simple to use and understand for most users
 | 
						|
      # - Flexible enough to meet unexpected needs
 | 
						|
      # # Overview
 | 
						|
      # The `Status` message contains three pieces of data: error code, error message,
 | 
						|
      # and error details. The error code should be an enum value of
 | 
						|
      # google.rpc.Code, but it may accept additional error codes if needed.  The
 | 
						|
      # error message should be a developer-facing English message that helps
 | 
						|
      # developers *understand* and *resolve* the error. If a localized user-facing
 | 
						|
      # error message is needed, put the localized message in the error details or
 | 
						|
      # localize it in the client. The optional error details may contain arbitrary
 | 
						|
      # information about the error. There is a predefined set of error detail types
 | 
						|
      # in the package `google.rpc` that can be used for common error conditions.
 | 
						|
      # # Language mapping
 | 
						|
      # The `Status` message is the logical representation of the error model, but it
 | 
						|
      # is not necessarily the actual wire format. When the `Status` message is
 | 
						|
      # exposed in different client libraries and different wire protocols, it can be
 | 
						|
      # mapped differently. For example, it will likely be mapped to some exceptions
 | 
						|
      # in Java, but more likely mapped to some error codes in C.
 | 
						|
      # # Other uses
 | 
						|
      # The error model and the `Status` message can be used in a variety of
 | 
						|
      # environments, either with or without APIs, to provide a
 | 
						|
      # consistent developer experience across different environments.
 | 
						|
      # Example uses of this error model include:
 | 
						|
      # - Partial errors. If a service needs to return partial errors to the client,
 | 
						|
      # it may embed the `Status` in the normal response to indicate the partial
 | 
						|
      # errors.
 | 
						|
      # - Workflow errors. A typical workflow has multiple steps. Each step may
 | 
						|
      # have a `Status` message for error reporting.
 | 
						|
      # - Batch operations. If a client uses batch request and batch response, the
 | 
						|
      # `Status` message should be used directly inside batch response, one for
 | 
						|
      # each error sub-response.
 | 
						|
      # - Asynchronous operations. If an API call embeds asynchronous operation
 | 
						|
      # results in its response, the status of those operations should be
 | 
						|
      # represented directly using the `Status` message.
 | 
						|
      # - Logging. If some API errors are stored in logs, the message `Status` could
 | 
						|
      # be used directly after any stripping needed for security/privacy reasons.
 | 
						|
      class GoogleRpcStatus
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # The status code, which should be an enum value of google.rpc.Code.
 | 
						|
        # Corresponds to the JSON property `code`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :code
 | 
						|
      
 | 
						|
        # A list of messages that carry the error details.  There is a common set of
 | 
						|
        # message types for APIs to use.
 | 
						|
        # Corresponds to the JSON property `details`
 | 
						|
        # @return [Array<Hash<String,Object>>]
 | 
						|
        attr_accessor :details
 | 
						|
      
 | 
						|
        # A developer-facing error message, which should be in English. Any
 | 
						|
        # user-facing error message should be localized and sent in the
 | 
						|
        # google.rpc.Status.details field, or localized by the client.
 | 
						|
        # Corresponds to the JSON property `message`
 | 
						|
        # @return [String]
 | 
						|
        attr_accessor :message
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @code = args[:code] if args.key?(:code)
 | 
						|
          @details = args[:details] if args.key?(:details)
 | 
						|
          @message = args[:message] if args.key?(:message)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Represents a whole calendar date, e.g. date of birth. The time of day and
 | 
						|
      # time zone are either specified elsewhere or are not significant. The date
 | 
						|
      # is relative to the Proleptic Gregorian Calendar. The day may be 0 to
 | 
						|
      # represent a year and month where the day is not significant, e.g. credit card
 | 
						|
      # expiration date. The year may be 0 to represent a month and day independent
 | 
						|
      # of year, e.g. anniversary date. Related types are google.type.TimeOfDay
 | 
						|
      # and `google.protobuf.Timestamp`.
 | 
						|
      class GoogleTypeDate
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Day of month. Must be from 1 to 31 and valid for the year and month, or 0
 | 
						|
        # if specifying a year/month where the day is not significant.
 | 
						|
        # Corresponds to the JSON property `day`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :day
 | 
						|
      
 | 
						|
        # Month of year. Must be from 1 to 12.
 | 
						|
        # Corresponds to the JSON property `month`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :month
 | 
						|
      
 | 
						|
        # Year of date. Must be from 1 to 9999, or 0 if specifying a date without
 | 
						|
        # a year.
 | 
						|
        # Corresponds to the JSON property `year`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :year
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @day = args[:day] if args.key?(:day)
 | 
						|
          @month = args[:month] if args.key?(:month)
 | 
						|
          @year = args[:year] if args.key?(:year)
 | 
						|
        end
 | 
						|
      end
 | 
						|
      
 | 
						|
      # Represents a time of day. The date and time zone are either not significant
 | 
						|
      # or are specified elsewhere. An API may choose to allow leap seconds. Related
 | 
						|
      # types are google.type.Date and `google.protobuf.Timestamp`.
 | 
						|
      class GoogleTypeTimeOfDay
 | 
						|
        include Google::Apis::Core::Hashable
 | 
						|
      
 | 
						|
        # Hours of day in 24 hour format. Should be from 0 to 23. An API may choose
 | 
						|
        # to allow the value "24:00:00" for scenarios like business closing time.
 | 
						|
        # Corresponds to the JSON property `hours`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :hours
 | 
						|
      
 | 
						|
        # Minutes of hour of day. Must be from 0 to 59.
 | 
						|
        # Corresponds to the JSON property `minutes`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :minutes
 | 
						|
      
 | 
						|
        # Fractions of seconds in nanoseconds. Must be from 0 to 999,999,999.
 | 
						|
        # Corresponds to the JSON property `nanos`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :nanos
 | 
						|
      
 | 
						|
        # Seconds of minutes of the time. Must normally be from 0 to 59. An API may
 | 
						|
        # allow the value 60 if it allows leap-seconds.
 | 
						|
        # Corresponds to the JSON property `seconds`
 | 
						|
        # @return [Fixnum]
 | 
						|
        attr_accessor :seconds
 | 
						|
      
 | 
						|
        def initialize(**args)
 | 
						|
           update!(**args)
 | 
						|
        end
 | 
						|
      
 | 
						|
        # Update properties of this object
 | 
						|
        def update!(**args)
 | 
						|
          @hours = args[:hours] if args.key?(:hours)
 | 
						|
          @minutes = args[:minutes] if args.key?(:minutes)
 | 
						|
          @nanos = args[:nanos] if args.key?(:nanos)
 | 
						|
          @seconds = args[:seconds] if args.key?(:seconds)
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |