# frozen_string_literal: true
# Copyright 2023 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://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.
# Auto-generated by gapic-generator-ruby. DO NOT EDIT!
module Google
module Cloud
module Bigquery
module DataPolicies
module V1
# Request message for the CreateDataPolicy method.
# @!attribute [rw] parent
# @return [::String]
# Required. Resource name of the project that the data policy will belong to.
# The format is `projects/{project_number}/locations/{location_id}`.
# @!attribute [rw] data_policy
# @return [::Google::Cloud::Bigquery::DataPolicies::V1::DataPolicy]
# Required. The data policy to create. The `name` field does not need to be
# provided for the data policy creation.
class CreateDataPolicyRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Response message for the UpdateDataPolicy method.
# @!attribute [rw] data_policy
# @return [::Google::Cloud::Bigquery::DataPolicies::V1::DataPolicy]
# Required. Update the data policy's metadata.
#
# The target data policy is determined by the `name` field.
# Other fields are updated to the specified values based on the field masks.
# @!attribute [rw] update_mask
# @return [::Google::Protobuf::FieldMask]
# The update mask applies to the resource. For the `FieldMask` definition,
# see
# https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#fieldmask
# If not set, defaults to all of the fields that are allowed to update.
#
# Updates to the `name` and `dataPolicyId` fields are not allowed.
class UpdateDataPolicyRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Request message for the RenameDataPolicy method.
# @!attribute [rw] name
# @return [::String]
# Required. Resource name of the data policy to rename. The format is
# `projects/{project_number}/locations/{location_id}/dataPolicies/{data_policy_id}`
# @!attribute [rw] new_data_policy_id
# @return [::String]
# Required. The new data policy id.
class RenameDataPolicyRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Request message for the DeleteDataPolicy method.
# @!attribute [rw] name
# @return [::String]
# Required. Resource name of the data policy to delete. Format is
# `projects/{project_number}/locations/{location_id}/dataPolicies/{data_policy_id}`.
class DeleteDataPolicyRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Request message for the GetDataPolicy method.
# @!attribute [rw] name
# @return [::String]
# Required. Resource name of the requested data policy. Format is
# `projects/{project_number}/locations/{location_id}/dataPolicies/{data_policy_id}`.
class GetDataPolicyRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Request message for the ListDataPolicies method.
# @!attribute [rw] parent
# @return [::String]
# Required. Resource name of the project for which to list data policies.
# Format is `projects/{project_number}/locations/{location_id}`.
# @!attribute [rw] page_size
# @return [::Integer]
# The maximum number of data policies to return. Must be a value between 1
# and 1000.
# If not set, defaults to 50.
# @!attribute [rw] page_token
# @return [::String]
# The `nextPageToken` value returned from a previous list request, if any. If
# not set, defaults to an empty string.
# @!attribute [rw] filter
# @return [::String]
# Filters the data policies by policy tags that they
# are associated with. Currently filter only supports
# "policy_tag" based filtering and OR based predicates. Sample
# filter can be "policy_tag:
# projects/1/locations/us/taxonomies/2/policyTags/3".
# You may also use wildcard such as "policy_tag:
# projects/1/locations/us/taxonomies/2*". Please note that OR predicates
# cannot be used with wildcard filters.
class ListDataPoliciesRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Response message for the ListDataPolicies method.
# @!attribute [rw] data_policies
# @return [::Array<::Google::Cloud::Bigquery::DataPolicies::V1::DataPolicy>]
# Data policies that belong to the requested project.
# @!attribute [rw] next_page_token
# @return [::String]
# Token used to retrieve the next page of results, or empty if there are no
# more results.
class ListDataPoliciesResponse
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Represents the label-policy binding.
# @!attribute [rw] policy_tag
# @return [::String]
# Policy tag resource name, in the format of
# `projects/{project_number}/locations/{location_id}/taxonomies/{taxonomy_id}/policyTags/{policyTag_id}`.
# @!attribute [rw] data_masking_policy
# @return [::Google::Cloud::Bigquery::DataPolicies::V1::DataMaskingPolicy]
# The data masking policy that specifies the data masking rule to use.
# @!attribute [r] name
# @return [::String]
# Output only. Resource name of this data policy, in the format of
# `projects/{project_number}/locations/{location_id}/dataPolicies/{data_policy_id}`.
# @!attribute [rw] data_policy_type
# @return [::Google::Cloud::Bigquery::DataPolicies::V1::DataPolicy::DataPolicyType]
# Type of data policy.
# @!attribute [rw] data_policy_id
# @return [::String]
# User-assigned (human readable) ID of the data policy that needs to be
# unique within a project. Used as \\{data_policy_id} in part of the resource
# name.
class DataPolicy
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# A list of supported data policy types.
module DataPolicyType
# Default value for the data policy type. This should not be used.
DATA_POLICY_TYPE_UNSPECIFIED = 0
# Used to create a data policy for column-level security, without data
# masking.
COLUMN_LEVEL_SECURITY_POLICY = 3
# Used to create a data policy for data masking.
DATA_MASKING_POLICY = 2
end
end
# The data masking policy that is used to specify data masking rule.
# @!attribute [rw] predefined_expression
# @return [::Google::Cloud::Bigquery::DataPolicies::V1::DataMaskingPolicy::PredefinedExpression]
# A predefined masking expression.
# @!attribute [rw] routine
# @return [::String]
# The name of the BigQuery routine that contains the custom masking
# routine, in the format of
# `projects/{project_number}/datasets/{dataset_id}/routines/{routine_id}`.
class DataMaskingPolicy
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# The available masking rules. Learn more here:
# https://cloud.google.com/bigquery/docs/column-data-masking-intro#masking_options.
module PredefinedExpression
# Default, unspecified predefined expression. No masking will take place
# since no expression is specified.
PREDEFINED_EXPRESSION_UNSPECIFIED = 0
# Masking expression to replace data with SHA-256 hash.
SHA256 = 3
# Masking expression to replace data with NULLs.
ALWAYS_NULL = 5
# Masking expression to replace data with their default masking values.
# The default masking values for each type listed as below:
#
# * STRING: ""
# * BYTES: b''
# * INTEGER: 0
# * FLOAT: 0.0
# * NUMERIC: 0
# * BOOLEAN: FALSE
# * TIMESTAMP: 1970-01-01 00:00:00 UTC
# * DATE: 1970-01-01
# * TIME: 00:00:00
# * DATETIME: 1970-01-01T00:00:00
# * GEOGRAPHY: POINT(0 0)
# * BIGNUMERIC: 0
# * ARRAY: []
# * STRUCT: NOT_APPLICABLE
# * JSON: NULL
DEFAULT_MASKING_VALUE = 7
# Masking expression shows the last four characters of text.
# The masking behavior is as follows:
#
# * If text length > 4 characters: Replace text with XXXXX, append last
# four characters of original text.
# * If text length <= 4 characters: Apply SHA-256 hash.
LAST_FOUR_CHARACTERS = 9
# Masking expression shows the first four characters of text.
# The masking behavior is as follows:
#
# * If text length > 4 characters: Replace text with XXXXX, prepend first
# four characters of original text.
# * If text length <= 4 characters: Apply SHA-256 hash.
FIRST_FOUR_CHARACTERS = 10
# Masking expression for email addresses.
# The masking behavior is as follows:
#
# * Syntax-valid email address: Replace username with XXXXX. For example,
# cloudysanfrancisco@gmail.com becomes XXXXX@gmail.com.
# * Syntax-invalid email address: Apply SHA-256 hash.
#
# For more information, see [Email
# mask](https://cloud.google.com/bigquery/docs/column-data-masking-intro#masking_options).
EMAIL_MASK = 12
# Masking expression to only show the year of `Date`,
# `DateTime` and `TimeStamp`. For example, with the
# year 2076:
#
# * DATE : 2076-01-01
# * DATETIME : 2076-01-01T00:00:00
# * TIMESTAMP : 2076-01-01 00:00:00 UTC
#
# Truncation occurs according to the UTC time zone. To change this, adjust
# the default time zone using the `time_zone` system variable.
# For more information, see the System
# variables reference.
DATE_YEAR_MASK = 13
end
end
end
end
end
end
end