reddb_server/application/
ports_impls_schema.rs1use super::*;
2use crate::application::schema::{CreateTablePartitionKind, CreateTablePartitionSpec};
3use crate::storage::query::ast::{PartitionKind, PartitionSpec};
4use crate::storage::query::{
5 CreateColumnDef, CreateTableQuery, CreateTimeSeriesQuery, DropTableQuery, DropTimeSeriesQuery,
6};
7use crate::storage::schema::SqlTypeName;
8
9fn api_query(label: &str, name: &str) -> String {
10 format!("api.{label}({name})")
11}
12
13fn to_create_column_def(
14 column: crate::application::schema::CreateTableColumnInput,
15) -> CreateColumnDef {
16 let sql_type = SqlTypeName::parse_declared(&column.data_type);
17 CreateColumnDef {
18 name: column.name,
19 data_type: column.data_type,
20 sql_type,
21 not_null: column.not_null,
22 default: column.default,
23 compress: column.compress,
24 unique: column.unique,
25 primary_key: column.primary_key,
26 enum_variants: column.enum_variants,
27 array_element: column.array_element,
28 decimal_precision: column.decimal_precision,
29 }
30}
31
32fn to_partition_kind(kind: CreateTablePartitionKind) -> PartitionKind {
33 match kind {
34 CreateTablePartitionKind::Range => PartitionKind::Range,
35 CreateTablePartitionKind::List => PartitionKind::List,
36 CreateTablePartitionKind::Hash => PartitionKind::Hash,
37 }
38}
39
40fn to_partition_spec(spec: CreateTablePartitionSpec) -> PartitionSpec {
41 PartitionSpec {
42 kind: to_partition_kind(spec.kind),
43 column: spec.column,
44 }
45}
46
47impl RuntimeSchemaPort for RedDBRuntime {
48 fn create_table(&self, input: CreateTableInput) -> RedDBResult<RuntimeQueryResult> {
49 let CreateTableInput {
50 name,
51 columns,
52 if_not_exists,
53 default_ttl_ms,
54 context_index_fields,
55 timestamps,
56 partition_by,
57 tenant_by,
58 append_only,
59 } = input;
60 let raw_query = api_query("create_table", &name);
61 let query = CreateTableQuery {
62 collection_model: crate::catalog::CollectionModel::Table,
63 name,
64 columns: columns.into_iter().map(to_create_column_def).collect(),
65 if_not_exists,
66 default_ttl_ms,
67 context_index_fields: context_index_fields.clone(),
68 context_index_enabled: !context_index_fields.is_empty(),
69 timestamps,
70 partition_by: partition_by.map(to_partition_spec),
71 tenant_by,
72 append_only,
73 subscriptions: Vec::new(),
74 vault_own_master_key: false,
75 };
76 RedDBRuntime::execute_create_table(self, &raw_query, &query)
77 }
78
79 fn drop_table(&self, input: DropTableInput) -> RedDBResult<RuntimeQueryResult> {
80 let raw_query = api_query("drop_table", &input.name);
81 let query = DropTableQuery {
82 name: input.name,
83 if_exists: input.if_exists,
84 };
85 RedDBRuntime::execute_drop_table(self, &raw_query, &query)
86 }
87
88 fn create_timeseries(&self, input: CreateTimeSeriesInput) -> RedDBResult<RuntimeQueryResult> {
89 let CreateTimeSeriesInput {
90 name,
91 retention_ms,
92 chunk_size,
93 downsample_policies,
94 if_not_exists,
95 } = input;
96 let raw_query = api_query("create_timeseries", &name);
97 let query = CreateTimeSeriesQuery {
98 name,
99 retention_ms,
100 chunk_size,
101 downsample_policies,
102 if_not_exists,
103 hypertable: None,
104 };
105 RedDBRuntime::execute_create_timeseries(self, &raw_query, &query)
106 }
107
108 fn drop_timeseries(&self, input: DropTimeSeriesInput) -> RedDBResult<RuntimeQueryResult> {
109 let raw_query = api_query("drop_timeseries", &input.name);
110 let query = DropTimeSeriesQuery {
111 name: input.name,
112 if_exists: input.if_exists,
113 };
114 RedDBRuntime::execute_drop_timeseries(self, &raw_query, &query)
115 }
116}