lance_namespace_reqwest_client/models/create_table_request.rs
1/*
2 * Lance Namespace Specification
3 *
4 * This OpenAPI specification is a part of the Lance namespace specification. It contains 2 parts: The `components/schemas`, `components/responses`, `components/examples`, `tags` sections define the request and response shape for each operation in a Lance Namespace across all implementations. See https://lancedb.github.io/lance-namespace/spec/operations for more details. The `servers`, `security`, `paths`, `components/parameters` sections are for the Lance REST Namespace implementation, which defines a complete REST server that can work with Lance datasets. See https://lancedb.github.io/lance-namespace/spec/impls/rest for more details.
5 *
6 * The version of the OpenAPI document: 1.0.0
7 *
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// CreateTableRequest : Request for creating a table, excluding the Arrow IPC stream.
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct CreateTableRequest {
17 #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
18 pub id: Option<Vec<String>>,
19 #[serde(rename = "location", skip_serializing_if = "Option::is_none")]
20 pub location: Option<String>,
21 /// There are three modes when trying to create a table, to differentiate the behavior when a table of the same name already exists: * create: the operation fails with 409. * exist_ok: the operation succeeds and the existing table is kept. * overwrite: the existing table is dropped and a new table with this name is created.
22 #[serde(rename = "mode", skip_serializing_if = "Option::is_none")]
23 pub mode: Option<Mode>,
24 #[serde(rename = "properties", skip_serializing_if = "Option::is_none")]
25 pub properties: Option<std::collections::HashMap<String, String>>,
26}
27
28impl CreateTableRequest {
29 /// Request for creating a table, excluding the Arrow IPC stream.
30 pub fn new() -> CreateTableRequest {
31 CreateTableRequest {
32 id: None,
33 location: None,
34 mode: None,
35 properties: None,
36 }
37 }
38}
39/// There are three modes when trying to create a table, to differentiate the behavior when a table of the same name already exists: * create: the operation fails with 409. * exist_ok: the operation succeeds and the existing table is kept. * overwrite: the existing table is dropped and a new table with this name is created.
40#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
41pub enum Mode {
42 #[serde(rename = "create")]
43 Create,
44 #[serde(rename = "exist_ok")]
45 ExistOk,
46 #[serde(rename = "overwrite")]
47 Overwrite,
48}
49
50impl Default for Mode {
51 fn default() -> Mode {
52 Self::Create
53 }
54}
55