lance_namespace_reqwest_client/models/
create_namespace_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#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct CreateNamespaceRequest {
16    #[serde(rename = "id", skip_serializing_if = "Option::is_none")]
17    pub id: Option<Vec<String>>,
18    /// There are three modes when trying to create a namespace, to differentiate the behavior when a namespace of the same name already exists:   * create: the operation fails with 409.   * exist_ok: the operation succeeds and the existing namespace is kept.   * overwrite: the existing namespace is dropped and a new empty namespace with this name is created. 
19    #[serde(rename = "mode", skip_serializing_if = "Option::is_none")]
20    pub mode: Option<Mode>,
21    #[serde(rename = "properties", skip_serializing_if = "Option::is_none")]
22    pub properties: Option<std::collections::HashMap<String, String>>,
23}
24
25impl CreateNamespaceRequest {
26    pub fn new() -> CreateNamespaceRequest {
27        CreateNamespaceRequest {
28            id: None,
29            mode: None,
30            properties: None,
31        }
32    }
33}
34/// There are three modes when trying to create a namespace, to differentiate the behavior when a namespace of the same name already exists:   * create: the operation fails with 409.   * exist_ok: the operation succeeds and the existing namespace is kept.   * overwrite: the existing namespace is dropped and a new empty namespace with this name is created. 
35#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
36pub enum Mode {
37    #[serde(rename = "create")]
38    Create,
39    #[serde(rename = "exist_ok")]
40    ExistOk,
41    #[serde(rename = "overwrite")]
42    Overwrite,
43}
44
45impl Default for Mode {
46    fn default() -> Mode {
47        Self::Create
48    }
49}
50