All Downloads are FREE. Search and download functionalities are using the official Maven repository.

deephaven-proto-backplane-grpc.0.26.1.source-code.table.proto Maven / Gradle / Ivy

There is a newer version: 0.37.1
Show newest version
/*
 * Copyright (c) 2016-2022 Deephaven Data Labs and Patent Pending
 */
syntax = "proto3";

package io.deephaven.proto.backplane.grpc;

option java_multiple_files = true;
option optimize_for = SPEED;
option go_package = "github.com/deephaven/deephaven-core/go/internal/proto/table";

import "deephaven/proto/ticket.proto";

service TableService {
  /*
   * Request an ETCR for this ticket. Ticket must reference a Table.
   */
  rpc GetExportedTableCreationResponse(Ticket) returns (ExportedTableCreationResponse) {}

  /*
   * Fetches a Table from an existing source ticket and exports it to the local session result ticket.
   */
  rpc FetchTable(FetchTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Create a table that has preview columns applied to an existing source table.
   */
  rpc ApplyPreviewColumns(ApplyPreviewColumnsRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Create an empty table with the given column names and types.
   */
  rpc EmptyTable(EmptyTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Create a time table with the given start time and period.
   */
  rpc TimeTable(TimeTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Drop columns from the parent table.
   */
  rpc DropColumns(DropColumnsRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Add columns to the given table using the given column specifications and the update table operation.
   */
  rpc Update(SelectOrUpdateRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Add columns to the given table using the given column specifications and the lazyUpdate table operation.
   */
  rpc LazyUpdate(SelectOrUpdateRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Add columns to the given table using the given column specifications and the view table operation.
   */
  rpc View(SelectOrUpdateRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Add columns to the given table using the given column specifications and the updateView table operation.
   */
  rpc UpdateView(SelectOrUpdateRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Select the given columns from the given table.
   */
  rpc Select(SelectOrUpdateRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of an updateBy table operation.
   */
  rpc UpdateBy(UpdateByRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns a new table definition with the unique tuples of the specified columns
   */
  rpc SelectDistinct(SelectDistinctRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Filter parent table with structured filters.
   */
  rpc Filter(FilterTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Filter parent table with unstructured filters.
   */
  rpc UnstructuredFilter(UnstructuredFilterTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Sort parent table via the provide sort descriptors.
   */
  rpc Sort(SortTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Extract rows from the head of the parent table.
   */
  rpc Head(HeadOrTailRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Extract rows from the tail of the parent table.
   */
  rpc Tail(HeadOrTailRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Run the headBy table operation for the given group by columns on the given table.
   */
  rpc HeadBy(HeadOrTailByRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Run the tailBy operation for the given group by columns on the given table.
   */
  rpc TailBy(HeadOrTailByRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Ungroup the given columns (all columns will be ungrouped if columnsToUngroup is empty or unspecified).
   */
  rpc Ungroup(UngroupRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Create a merged table from the given input tables. If a key column is provided (not null), a sorted
   * merged will be performed using that column.
   */
  rpc MergeTables(MergeTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of a cross join operation. Also known as the cartesian product.
   */
  rpc CrossJoinTables(CrossJoinTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of a natural join operation.
   */
  rpc NaturalJoinTables(NaturalJoinTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of an exact join operation.
   */
  rpc ExactJoinTables(ExactJoinTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of a left join operation.
   */
  rpc LeftJoinTables(LeftJoinTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of an as of join operation.
   *
   * Deprecated: Please use AjTables or RajTables.
   */
  rpc AsOfJoinTables(AsOfJoinTablesRequest) returns (ExportedTableCreationResponse) {
    option deprecated = true;
  }

  /*
   * Returns the result of an aj operation.
   */
  rpc AjTables(AjRajTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of an raj operation.
   */
  rpc RajTables(AjRajTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of a range join operation.
   */
  rpc RangeJoinTables(RangeJoinTablesRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns the result of an aggregate table operation.
   *
   * Deprecated: Please use AggregateAll or Aggregate instead
   */
  rpc ComboAggregate(ComboAggregateRequest) returns (ExportedTableCreationResponse) {
    option deprecated = true;
  }

  /*
   * Aggregates all non-grouping columns against a single aggregation specification.
   */
  rpc AggregateAll(AggregateAllRequest) returns (ExportedTableCreationResponse) {};

  /*
   * Produce an aggregated result by grouping the source_id table according to the group_by_columns and applying
   * aggregations to each resulting group of rows. The result table will have one row per group, ordered by
   * the encounter order within the source_id table, thereby ensuring that the row key for a given group never
   * changes.
   */
  rpc Aggregate(AggregateRequest) returns (ExportedTableCreationResponse) {};

  /*
   * Takes a single snapshot of the source_id table.
   */
  rpc Snapshot(SnapshotTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Snapshot base_id, triggered by trigger_id, and export the resulting new table.
   * The trigger_id table's change events cause a new snapshot to be taken. The result table includes a
   * "snapshot key" which is a subset (possibly all) of the base_id table's columns. The
   * remaining columns in the result table come from base_id table, the table being snapshotted.
   */
  rpc SnapshotWhen(SnapshotWhenTableRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Returns a new table with a flattened row set.
   */
  rpc Flatten(FlattenRequest) returns (ExportedTableCreationResponse) {}

  /**
   * Downsamples a table assume its contents will be rendered in a run chart, with each subsequent row holding a later
   * X value (i.e., sorted on that column). Multiple Y columns can be specified, as can a range of values for the X
   * column to support zooming in.
   */
  rpc RunChartDownsample(RunChartDownsampleRequest) returns (ExportedTableCreationResponse) {}

  /**
   * Creates a new Table based on the provided configuration. This can be used as a regular table from the other methods
   * in this interface, or can be interacted with via the InputTableService to modify its contents.
   */
  rpc CreateInputTable(CreateInputTableRequest) returns (ExportedTableCreationResponse) {}

  /**
   * Filters the left table based on the set of values in the right table.
   *
   * Note that when the right table ticks, all of the rows in the left table are going to be re-evaluated,
   * thus the intention is that the right table is fairly slow moving compared with the left table.
   */
  rpc WhereIn(WhereInRequest) returns (ExportedTableCreationResponse) {}

  /*
   * Batch a series of requests and send them all at once. This enables the user to create intermediate tables without
   * requiring them to be exported and managed by the client. The server will automatically release any tables when they
   * are no longer depended upon.
   */
  rpc Batch(BatchTableRequest) returns (stream ExportedTableCreationResponse) {}

  /*
   * Establish a stream of table updates for cheap notifications of table size updates.
   *
   * New streams will flush updates for all existing table exports. An export id of zero will be sent to indicate all
   * exports have sent their refresh update. Table updates may be intermingled with initial refresh updates after their
   * initial update had been sent.
   */
  rpc ExportedTableUpdates(ExportedTableUpdatesRequest) returns (stream ExportedTableUpdateMessage) {}

  /*
   * Seek a row number within a table.
   */
  rpc SeekRow(SeekRowRequest) returns (SeekRowResponse) {}

  /*
   * Returns the meta table of a table.
   */
  rpc MetaTable(MetaTableRequest) returns (ExportedTableCreationResponse) {}

}

message TableReference {
  oneof ref {
    // an exported ticket
    Ticket ticket = 1;
    // an offset into a BatchRequest -- used to reference a result that will not be exported
    sint32 batch_offset = 2;
  }
}

message ExportedTableCreationResponse {
  TableReference result_id = 1;

  // If this is part of a batch, you may receive creation messages that indicate the sub-operation failed.
  bool success = 2;

  // If this is part of a batch, this errorInfo will be the message provided
  string error_info = 3;

  // Schema as described in Arrow Message.fbs::Message.
  bytes schema_header = 4;

  // Whether or not this table might change.
  bool is_static = 5;

  // The current number of rows for this table. If this is negative, the table isn't coalesced, meaning the
  // size isn't known without scanning partitions. Typically, the client should filter the data by the
  // partitioning columns first.
  sint64 size = 6 [jstype=JS_STRING];

  // TODO: attributes
}

message FetchTableRequest {
  TableReference source_id = 1;
  Ticket result_id = 2;
}

message ApplyPreviewColumnsRequest {
  TableReference source_id = 1;
  Ticket result_id = 2;
}

message ExportedTableUpdatesRequest {
  // Intentionally empty and is here for backwards compatibility should this API change.
}

message ExportedTableUpdateMessage {
  Ticket export_id = 1;
  sint64 size = 2 [jstype=JS_STRING];
  string update_failure_message = 3;
}

message EmptyTableRequest {
  Ticket result_id = 1;
  sint64 size = 2 [jstype=JS_STRING];
}

message TimeTableRequest {
  Ticket result_id = 1;
  sint64 start_time_nanos = 2 [jstype=JS_STRING];
  sint64 period_nanos = 3 [jstype=JS_STRING];
}

message SelectOrUpdateRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated string column_specs = 3;
}

message MathContext {
  enum RoundingMode {
    ROUNDING_MODE_NOT_SPECIFIED = 0;
    UP = 1;
    DOWN = 2;
    CEILING = 3;
    FLOOR = 4;
    HALF_UP = 5;
    HALF_DOWN = 6;
    HALF_EVEN = 7;
    UNNECESSARY = 8;
  }
  sint32 precision = 1;
  RoundingMode rounding_mode = 2;
}

// Directives for how to handle {@code null} and {@code NaN} values
enum BadDataBehavior {
  // When not specified will use the server default.
  BAD_DATA_BEHAVIOR_NOT_SPECIFIED = 0;

  // Throw an exception and abort processing when bad data is encountered.
  THROW = 1;

  // Reset the state for the bucket to {@code null} when invalid data is encountered.
  RESET = 2;

  // Skip and do not process the invalid data without changing state.
  SKIP = 3;

  // Allow the bad data to poison the result. This is only valid for use with NaN.
  POISON = 4;
}

// Directives for how to handle {@code null} and {@code NaN} values
enum UpdateByNullBehavior {
  // When not specified will use the server default.
  NULL_BEHAVIOR_NOT_SPECIFIED = 0;

  // In the case of Current - null, the null dominates so Column[i] - null = null
  NULL_DOMINATES = 1;

  // In the case of Current - null, the current value dominates so Column[i] - null = Column[i]
  VALUE_DOMINATES = 2;

  // In the case of Current - null, return zero so Column[i] - null = 0
  ZERO_DOMINATES = 3;
}

// Reusable window scale message for the UpdateBy rolling operations.
message UpdateByWindowScale {
  message UpdateByWindowTicks {
    double ticks = 1;
  }
  message UpdateByWindowTime {
    string column = 1;
    oneof window {
      sint64 nanos = 2 [jstype = JS_STRING];
      string duration_string = 3;
    }
  }
  oneof type {
    UpdateByWindowTicks ticks = 1;
    UpdateByWindowTime time = 2;
  }
}

// Reusable options for the UpdateBy exponential moving operations.
message UpdateByEmOptions {
  BadDataBehavior on_null_value = 1;

  BadDataBehavior on_nan_value = 2;

  BadDataBehavior on_null_time = 3;

  BadDataBehavior on_negative_delta_time = 4;

  BadDataBehavior on_zero_delta_time = 5;

  MathContext big_value_context = 6;
}

// Reusable options for the UpdateBy delta operation.
message UpdateByDeltaOptions {
  UpdateByNullBehavior null_behavior = 1;
}

// Create a table with the same rowset as its parent that will perform the specified set of row
// based operations to it. As opposed to {@link #update(String...)} these operations are more restricted but are
// capable of processing state between rows. This operation will group the table by the specified set of keys if
// provided before applying the operation.
message UpdateByRequest {

  message UpdateByOptions {
    // If redirections should be used for output sources instead of sparse array sources.
    // If unset, defaults to server-provided defaults.
    optional bool use_redirection = 1;

    // The maximum chunk capacity.
    // If unset, defaults to server-provided defaults.
    optional int32 chunk_capacity = 2;

    // The maximum fractional memory overhead allowable for sparse redirections as a fraction (e.g. 1.1 is 10%
    // overhead). Values less than zero disable overhead checking, and result in always using the sparse structure. A
    // value of zero results in never using the sparse structure.
    // If unset, defaults to server-provided defaults.
    optional double max_static_sparse_memory_overhead = 3;

    // The initial hash table size.
    // If unset, defaults to server-provided defaults.
    optional int32 initial_hash_table_size = 4;

    // The maximum load factor for the hash table.
    // If unset, defaults to server-provided defaults.
    optional double maximum_load_factor = 5;

    // The target load factor for the hash table.
    // If unset, defaults to server-provided defaults.
    optional double target_load_factor = 6;

    // The math context.
    MathContext math_context = 7;
  }

  message UpdateByOperation {
    message UpdateByColumn {
      message UpdateBySpec {
        message UpdateByCumulativeSum {

        }

        message UpdateByCumulativeMin {

        }

        message UpdateByCumulativeMax {

        }

        message UpdateByCumulativeProduct {

        }

        message UpdateByFill {

        }

        message UpdateByEma {
          UpdateByEmOptions options = 1;
          UpdateByWindowScale window_scale = 2;
        }

        message UpdateByEms {
          UpdateByEmOptions options = 1;
          UpdateByWindowScale window_scale = 2;
        }

        message UpdateByEmMin {
          UpdateByEmOptions options = 1;
          UpdateByWindowScale window_scale = 2;
        }

        message UpdateByEmMax {
          UpdateByEmOptions options = 1;
          UpdateByWindowScale window_scale = 2;
        }

        message UpdateByEmStd {
          UpdateByEmOptions options = 1;
          UpdateByWindowScale window_scale = 2;
        }

        message UpdateByDelta {
          UpdateByDeltaOptions options = 1;
        }

        message UpdateByRollingSum {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingGroup {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingAvg {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingMin {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingMax {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingProduct {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingCount {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingStd {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
        }

        message UpdateByRollingWAvg {
          UpdateByWindowScale reverse_window_scale = 1;
          UpdateByWindowScale forward_window_scale = 2;
          // Column name for the source of input weights.
          string weight_column = 3;
        }

        oneof type {
          UpdateByCumulativeSum sum = 1;
          UpdateByCumulativeMin min = 2;
          UpdateByCumulativeMax max = 3;
          UpdateByCumulativeProduct product = 4;
          UpdateByFill fill = 5;
          UpdateByEma ema = 6;
          UpdateByRollingSum rolling_sum = 7;
          UpdateByRollingGroup rolling_group = 8;
          UpdateByRollingAvg rolling_avg = 9;
          UpdateByRollingMin rolling_min = 10;
          UpdateByRollingMax rolling_max = 11;
          UpdateByRollingProduct rolling_product = 12;
          UpdateByDelta delta = 13;
          UpdateByEms ems = 14;
          UpdateByEmMin em_min = 15;
          UpdateByEmMax em_max = 16;
          UpdateByEmStd em_std = 17;
          UpdateByRollingCount rolling_count = 18;
          UpdateByRollingStd rolling_std = 19;
          UpdateByRollingWAvg rolling_wavg = 20;
        }
      }

      UpdateBySpec spec = 1;
      repeated string match_pairs = 2;
    }
    oneof type {
      UpdateByColumn column = 1;
    }
  }

  Ticket result_id = 1;
  TableReference source_id = 2;

  UpdateByOptions options = 3;
  repeated UpdateByOperation operations = 4;
  repeated string group_by_columns = 5;
}

message SelectDistinctRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated string column_names = 3;
}

message DropColumnsRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated string column_names = 3;
}

message UnstructuredFilterTableRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated string filters = 3;
}

message HeadOrTailRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  sint64 num_rows = 3 [jstype=JS_STRING];
}

message HeadOrTailByRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  sint64 num_rows = 3 [jstype=JS_STRING];
  repeated string group_by_column_specs = 4;
}

message UngroupRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  bool null_fill = 3;
  repeated string columns_to_ungroup = 4;
}

message MergeTablesRequest {
  Ticket result_id = 1;
  repeated TableReference source_ids = 2;
  string key_column = 3; // if specified, the result will be sorted by this column
}

message SnapshotTableRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
}

message SnapshotWhenTableRequest {
  Ticket result_id = 1;

  // The base table.
  TableReference base_id = 2;

  // The trigger table.
  TableReference trigger_id = 3;

  // Whether the results should contain an initial snapshot.
  bool initial = 4;

  // Whether the results should be incremental.
  bool incremental = 5;

  // Whether the results should keep history.
  bool history = 6;

  // Which columns to stamp from the trigger table. If empty, all columns from the trigger table are stamped. Allows renaming columns.
  repeated string stamp_columns = 7;
}

message CrossJoinTablesRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string columns_to_match = 4;
  repeated string columns_to_add = 5;

  // the number of bits of key-space to initially reserve per group; default is 10
  int32 reserve_bits = 6;
}

message NaturalJoinTablesRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string columns_to_match = 4;
  repeated string columns_to_add = 5;
}

message ExactJoinTablesRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string columns_to_match = 4;
  repeated string columns_to_add = 5;
}

message LeftJoinTablesRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string columns_to_match = 4;
  repeated string columns_to_add = 5;
}

message AsOfJoinTablesRequest {
  option deprecated = true;
  enum MatchRule {
    option deprecated = true;
    LESS_THAN_EQUAL = 0;
    LESS_THAN = 1;
    GREATER_THAN_EQUAL = 2;
    GREATER_THAN = 3;
  }
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string columns_to_match = 4;
  repeated string columns_to_add = 5;
  // Direction to search to find a match. LESS_THAN_EQUAL and LESS_THAN will be used to make a
  // Table.aj() call, and GREATER_THAN_EQUAL and GREATER_THAN will be used to make a Table.raj() call.
  MatchRule as_of_match_rule = 7;
}

message AjRajTablesRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string exact_match_columns = 4;
  // This is a comparison expression for the inexact as-of join match. In the case of an as-of join (aj), the comparison
  // operator can be either ">=" or ">"; for example, "Foo>=Bar" or "Foo>Bar". In the case of a reverse-as-of join (raj),
  // the comparison operator can be either "<=" or "<"; for example, "Foo<=Bar" or "Foo=Foo"; in the raj case, "Foo" is equivalent to "Foo<=Foo".
  string as_of_column = 5;
  repeated string columns_to_add = 6;
}

message RangeJoinTablesRequest {
  enum RangeStartRule {
    START_UNSPECIFIED = 0;
    LESS_THAN = 1;
    LESS_THAN_OR_EQUAL = 2;
    LESS_THAN_OR_EQUAL_ALLOW_PRECEDING = 3;
  }
  enum RangeEndRule {
    END_UNSPECIFIED = 0;
    GREATER_THAN = 1;
    GREATER_THAN_OR_EQUAL = 2;
    GREATER_THAN_OR_EQUAL_ALLOW_FOLLOWING = 3;
  }
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  repeated string exact_match_columns = 4;
  string left_start_column = 5;
  RangeStartRule range_start_rule = 6;
  string right_range_column = 7;
  RangeEndRule range_end_rule = 8;
  string left_end_column = 9;
  repeated Aggregation aggregations = 10;
}

message ComboAggregateRequest {
  option deprecated = true;

  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated Aggregate aggregates = 3;
  repeated string group_by_columns = 4;
  bool force_combo = 5; // don't use direct single-aggregate table operations even if there is only a single aggregate

  message Aggregate {
    AggType type = 1;
    repeated string match_pairs = 2; // used in all aggregates except countBy
    string column_name = 3; // countBy result (output) column OR weighted avg weight (input) column, otherwise unused
    double percentile = 4; // required by percentileBy aggregates, otherwise unused
    bool avg_median = 5; // used in percentileBy only
  }

  enum AggType {
    SUM = 0;
    ABS_SUM = 1;
    GROUP = 2;
    AVG = 3;
    COUNT = 4;
    FIRST = 5;
    LAST = 6;
    MIN = 7;
    MAX = 8;
    MEDIAN = 9;
    PERCENTILE = 10;
    STD = 11;
    VAR = 12;
    WEIGHTED_AVG = 13;
  }
}

message AggregateAllRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  AggSpec spec = 3;
  repeated string group_by_columns = 4;
}

enum NullValue {
  NULL_VALUE = 0;
}

message AggSpec {
  message AggSpecApproximatePercentile {
    // Percentile. Must be in range [0.0, 1.0].
    double percentile = 1;

    // T-Digest compression factor. Must be greater than or equal to 1. 1000 is extremely large.
    // When not specified, the server will choose a compression value.
    optional double compression = 2;
  }

  message AggSpecCountDistinct {
    // Whether null input values should be included when counting the distinct input values.
    bool count_nulls = 1;
  }

  message AggSpecDistinct {
    // Whether null input values should be included in the distinct output values.
    bool include_nulls = 1;
  }

  message AggSpecFormula {
    // The formula to use to calculate output values from grouped input values.
    string formula = 1;

    // The formula parameter token to be replaced with the input column name for evaluation.
    string param_token = 2;
  }

  message AggSpecMedian {
    // Whether to average the highest low-bucket value and lowest high-bucket value, when the low-bucket and high-bucket
    // are of equal size. Only applies to numeric types.
    bool average_evenly_divided = 1;
  }

  message AggSpecPercentile {
    // The percentile to calculate. Must be in the range [0.0, 1.0].
    double percentile = 1;

    // Whether to average the highest low-bucket value and lowest high-bucket value, when the low-bucket and high-bucket
    // are of equal size. Only applies to numeric types.
    bool average_evenly_divided = 2;
  }

  message AggSpecSorted {
    // Using a message instead of string to support backwards-compatibility in the future
    repeated AggSpecSortedColumn columns = 1;
  }

  message AggSpecSortedColumn {
    // TODO(deephaven-core#821): SortedFirst / SortedLast aggregations with sort direction
    string column_name = 1;
  }

  message AggSpecTDigest {
    // T-Digest compression factor. Must be greater than or equal to 1. 1000 is extremely large.
    // When not specified, the server will choose a compression value.
    optional double compression = 1;
  }

  message AggSpecUnique {
    // Whether to include null values as a distinct value for determining if there is only one unique value to output
    bool include_nulls = 1;

    // The output value to use for groups that don't have a single unique input value
    AggSpecNonUniqueSentinel non_unique_sentinel = 2;
  }

  message AggSpecNonUniqueSentinel {
    oneof type {
      NullValue null_value = 1;
      string string_value = 2;
      sint32 int_value = 3;
      sint64 long_value = 4 [jstype=JS_STRING];
      float float_value = 5;
      double double_value = 6;
      bool bool_value = 7;
      // Expected to be in range [Byte.MIN_VALUE, Byte.MAX_VALUE]
      sint32 byte_value = 8;
      // Expected to be in range [Short.MIN_VALUE, Short.MAX_VALUE]
      sint32 short_value = 9;
      // Expected to be in range [0x0000, 0xFFFF]
      sint32 char_value = 10;
      // TODO(deephaven-core#3212): Expand AggSpecNonUniqueSentinel types
    }
  }

  message AggSpecWeighted {
    // Column name for the source of input weights.
    string weight_column = 1;
  }

  message AggSpecAbsSum {

  }

  message AggSpecAvg {

  }

  message AggSpecFirst {

  }

  message AggSpecFreeze {

  }

  message AggSpecGroup {

  }

  message AggSpecLast {

  }

  message AggSpecMax {

  }

  message AggSpecMin {

  }

  message AggSpecStd {

  }

  message AggSpecSum {

  }

  message AggSpecVar {

  }

  oneof type {
    AggSpecAbsSum abs_sum = 1;
    AggSpecApproximatePercentile approximate_percentile = 2;
    AggSpecAvg avg = 3;
    AggSpecCountDistinct count_distinct = 4;
    AggSpecDistinct distinct = 5;
    AggSpecFirst first = 6;
    AggSpecFormula formula = 7;
    AggSpecFreeze freeze = 8;
    AggSpecGroup group = 9;
    AggSpecLast last = 10;
    AggSpecMax max = 11;
    AggSpecMedian median = 12;
    AggSpecMin min = 13;
    AggSpecPercentile percentile = 14;
    AggSpecSorted sorted_first = 15;
    AggSpecSorted sorted_last = 16;
    AggSpecStd std = 17;
    AggSpecSum sum = 18;
    AggSpecTDigest t_digest = 19;
    AggSpecUnique unique = 20;
    AggSpecWeighted weighted_avg = 21;
    AggSpecWeighted weighted_sum = 22;
    AggSpecVar var = 23;
  }
}

message AggregateRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  // A table whose distinct combinations of values for the group_by_columns should be used
  // to create an initial set of aggregation groups. All other columns are ignored. This is useful in
  // combination with preserve_empty == true to ensure that particular groups appear in the result
  // table, or with preserve_empty == false to control the encounter order for a collection of groups
  // and thus their relative order in the result. Changes to initial_group_ids are not expected or handled;
  // if initial_groups_id is a refreshing table, only its contents at instantiation time will be used. If
  // initial_groups_id is not present, the result will be the same as if a table with no rows was supplied.
  TableReference initial_groups_id = 3;
  // Whether to keep result rows for groups that are initially empty or become empty as a result
  // of updates. Each aggregation operator defines its own value for empty groups.
  bool preserve_empty = 4;
  repeated Aggregation aggregations = 5;
  repeated string group_by_columns = 6;
}

message Aggregation {
  message AggregationColumns {
    AggSpec spec = 1;
    repeated string match_pairs = 2;
  }

  message AggregationCount {
    // The output column name
    string column_name = 1;
  }

  message AggregationRowKey {
    string column_name = 1;
  }

  message AggregationPartition {
    string column_name = 1;
    bool include_group_by_columns = 2;
  }

  oneof type {
    AggregationColumns columns = 1;
    AggregationCount count = 2;
    AggregationRowKey first_row_key = 3;
    AggregationRowKey last_row_key = 4;
    AggregationPartition partition = 5;
  }
}

message SortDescriptor {
  string column_name = 1;
  bool is_absolute = 2;
  SortDirection direction = 3;

  enum SortDirection {
    UNKNOWN = 0;
    DESCENDING = -1;
    ASCENDING = 1;
    REVERSE = 2;
  }
}

message SortTableRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
  repeated SortDescriptor sorts = 3;
}

message FilterTableRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;

  repeated Condition filters = 3;
}

message SeekRowRequest {
    Ticket source_id = 1;
    sint64 starting_row = 2 [jstype=JS_STRING];
    string column_name = 3;
    Literal seek_value = 4;
    bool insensitive = 5;
    bool contains = 6;
    bool is_backward = 7;
}

message SeekRowResponse {
    sint64 result_row = 1 [jstype=JS_STRING];
}

message Reference {
  string column_name = 1;
}

message Literal {
  oneof value {
    string string_value = 1;
    double double_value = 2;
    bool bool_value = 3;
    sint64 long_value = 4 [jstype=JS_STRING];
    sint64 nano_time_value = 5 [jstype=JS_STRING]; // nanos since the epoch
  }
}
// could also inline this to each place that uses it
message Value {
  oneof data {
    Reference reference = 1;
    Literal literal = 2;
  }
}

message Condition {
  oneof data {
    AndCondition and = 1;
    OrCondition or = 2;
    NotCondition not = 3;

    CompareCondition compare = 4;

    InCondition in = 5;

    InvokeCondition invoke = 6;

    IsNullCondition is_null = 7;

    MatchesCondition matches = 8;
    ContainsCondition contains = 9;

    SearchCondition search = 10;
  }
}

// merge AND and OR into one and give them an "operation"?
message AndCondition {
  repeated Condition filters = 1;
}
message OrCondition {
  repeated Condition filters = 1;
}
message NotCondition {
  Condition filter = 1;
}

message CompareCondition {
  enum CompareOperation {
    LESS_THAN = 0;
    LESS_THAN_OR_EQUAL = 1;
    GREATER_THAN = 2;
    GREATER_THAN_OR_EQUAL = 3;
    EQUALS = 4;
    NOT_EQUALS = 5;
  }
  CompareOperation operation = 1;
  CaseSensitivity case_sensitivity = 2;
  Value lhs = 3;
  Value rhs = 4;
}

enum CaseSensitivity {
  MATCH_CASE = 0;
  IGNORE_CASE = 1;
}
enum MatchType {
  REGULAR = 0;
  INVERTED = 1;
}

message InCondition {
  Value target = 1;
  repeated Value candidates = 2;

  CaseSensitivity case_sensitivity = 3;
  MatchType match_type = 4;
}

message InvokeCondition {
  string method = 1;
  Value target = 2;
  repeated Value arguments = 3;
}
message IsNullCondition {
  Reference reference = 1;
}

message MatchesCondition {
  Reference reference = 1;
  string regex = 2;

  CaseSensitivity case_sensitivity = 3;
  MatchType match_type = 4;
}

message ContainsCondition {
  Reference reference = 1;
  string search_string = 2;

  CaseSensitivity case_sensitivity = 3;
  MatchType match_type = 4;
}

// search
message SearchCondition {
  string search_string = 1;
  repeated Reference optional_references = 2;
}

message FlattenRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
}

message MetaTableRequest {
  Ticket result_id = 1;
  TableReference source_id = 2;
}

message RunChartDownsampleRequest {
  message ZoomRange {
    optional int64 min_date_nanos = 1 [jstype=JS_STRING];
    optional int64 max_date_nanos = 2 [jstype=JS_STRING];
  }
  Ticket result_id = 1;
  TableReference source_id = 2;

  int32 pixel_count = 3;
  ZoomRange zoom_range = 4;
  string x_column_name = 5;
  repeated string y_column_names = 6;
}

message CreateInputTableRequest {
  message InputTableKind {
    // Creates an in-memory append-only table - rows cannot be modified or deleted.
    message InMemoryAppendOnly {

    }
    // Creates an in-memory table that supports updates and deletes by keys.
    message InMemoryKeyBacked {
      repeated string key_columns = 1;
    }
    oneof kind {
      InMemoryAppendOnly in_memory_append_only = 1;
      InMemoryKeyBacked in_memory_key_backed = 2;
    }
  }

  Ticket result_id = 1;
  oneof definition {
    // Optional, either this or schema must be specified, not both.
    TableReference source_table_id = 2;
    // Schema as described in Arrow Message.fbs::Message. Optional, either this or source_table_id must be specified.
    bytes schema = 3;
  }

  // Specifies what type of input table to create.
  InputTableKind kind = 4;
}

message WhereInRequest {
  Ticket result_id = 1;
  TableReference left_id = 2;
  TableReference right_id = 3;
  // When true, becomes a "where not in" request
  bool inverted = 4;
  repeated string columns_to_match = 5;
}

message BatchTableRequest {
  repeated Operation ops = 1;

  message Operation {
    reserved 20;
    reserved 29;

    oneof op {
      EmptyTableRequest empty_table = 1;
      TimeTableRequest time_table = 2;
      DropColumnsRequest drop_columns = 3;
      SelectOrUpdateRequest update = 4;
      SelectOrUpdateRequest lazy_update = 5;
      SelectOrUpdateRequest view = 6;
      SelectOrUpdateRequest update_view = 7;
      SelectOrUpdateRequest select = 8;
      SelectDistinctRequest select_distinct = 9;
      FilterTableRequest filter = 10;
      UnstructuredFilterTableRequest unstructured_filter = 11;
      SortTableRequest sort = 12;
      HeadOrTailRequest head = 13;
      HeadOrTailRequest tail = 14;
      HeadOrTailByRequest head_by = 15;
      HeadOrTailByRequest tail_by = 16;
      UngroupRequest ungroup = 17;
      MergeTablesRequest merge = 18;
      ComboAggregateRequest combo_aggregate = 19;
      FlattenRequest flatten = 21;
      RunChartDownsampleRequest run_chart_downsample = 22;
      CrossJoinTablesRequest cross_join = 23;
      NaturalJoinTablesRequest natural_join = 24;
      ExactJoinTablesRequest exact_join = 25;
      LeftJoinTablesRequest left_join = 26;
      AsOfJoinTablesRequest as_of_join = 27 [deprecated=true];
      FetchTableRequest fetch_table = 28;
      ApplyPreviewColumnsRequest apply_preview_columns = 30;
      CreateInputTableRequest create_input_table = 31;
      UpdateByRequest update_by = 32;
      WhereInRequest where_in = 33;
      AggregateAllRequest aggregate_all = 34;
      AggregateRequest aggregate = 35;
      SnapshotTableRequest snapshot = 36;
      SnapshotWhenTableRequest snapshot_when = 37;
      MetaTableRequest meta_table = 38;
      RangeJoinTablesRequest range_join = 39;
      AjRajTablesRequest aj = 40;
      AjRajTablesRequest raj = 41;
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy