// Copyright 2025 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

syntax = "proto3";

package google.cloud.bigquery.v2;

import "google/api/field_behavior.proto";
import "google/protobuf/wrappers.proto";

option go_package = "cloud.google.com/go/bigquery/v2/apiv2/bigquerypb;bigquerypb";
option java_outer_classname = "HivePartitioningProto";
option java_package = "com.google.cloud.bigquery.v2";

// Options for configuring hive partitioning detect.
message HivePartitioningOptions {
  // Optional. When set, what mode of hive partitioning to use when reading
  // data.  The following modes are supported:
  //
  // * AUTO: automatically infer partition key name(s) and type(s).
  //
  // * STRINGS: automatically infer partition key name(s).  All types are
  // strings.
  //
  // * CUSTOM: partition key schema is encoded in the source URI prefix.
  //
  // Not all storage formats support hive partitioning. Requesting hive
  // partitioning on an unsupported format will lead to an error.
  // Currently supported formats are: JSON, CSV, ORC, Avro and Parquet.
  string mode = 1 [(google.api.field_behavior) = OPTIONAL];

  // Optional. When hive partition detection is requested, a common prefix for
  // all source uris must be required.  The prefix must end immediately before
  // the partition key encoding begins. For example, consider files following
  // this data layout:
  //
  // gs://bucket/path_to_table/dt=2019-06-01/country=USA/id=7/file.avro
  //
  // gs://bucket/path_to_table/dt=2019-05-31/country=CA/id=3/file.avro
  //
  // When hive partitioning is requested with either AUTO or STRINGS detection,
  // the common prefix can be either of gs://bucket/path_to_table or
  // gs://bucket/path_to_table/.
  //
  // CUSTOM detection requires encoding the partitioning schema immediately
  // after the common prefix.  For CUSTOM, any of
  //
  // * gs://bucket/path_to_table/{dt:DATE}/{country:STRING}/{id:INTEGER}
  //
  // * gs://bucket/path_to_table/{dt:STRING}/{country:STRING}/{id:INTEGER}
  //
  // * gs://bucket/path_to_table/{dt:DATE}/{country:STRING}/{id:STRING}
  //
  // would all be valid source URI prefixes.
  string source_uri_prefix = 2 [(google.api.field_behavior) = OPTIONAL];

  // Optional. If set to true, queries over this table require a partition
  // filter that can be used for partition elimination to be specified.
  //
  // Note that this field should only be true when creating a permanent
  // external table or querying a temporary external table.
  //
  // Hive-partitioned loads with require_partition_filter explicitly set to
  // true will fail.
  google.protobuf.BoolValue require_partition_filter = 3
      [(google.api.field_behavior) = OPTIONAL];

  // Output only. For permanent external tables, this field is populated with
  // the hive partition keys in the order they were inferred. The types of the
  // partition keys can be deduced by checking the table schema (which will
  // include the partition keys). Not every API will populate this field in the
  // output. For example, Tables.Get will populate it, but Tables.List will not
  // contain this field.
  repeated string fields = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
}
