langfuse_client_base/models/
create_blob_storage_integration_request.rs1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize, bon::Builder)]
15pub struct CreateBlobStorageIntegrationRequest {
16 #[serde(rename = "projectId")]
18 pub project_id: String,
19 #[serde(rename = "type")]
20 pub r#type: models::BlobStorageIntegrationType,
21 #[serde(rename = "bucketName")]
23 pub bucket_name: String,
24 #[serde(
26 rename = "endpoint",
27 default,
28 with = "::serde_with::rust::double_option",
29 skip_serializing_if = "Option::is_none"
30 )]
31 pub endpoint: Option<Option<String>>,
32 #[serde(rename = "region")]
34 pub region: String,
35 #[serde(
37 rename = "accessKeyId",
38 default,
39 with = "::serde_with::rust::double_option",
40 skip_serializing_if = "Option::is_none"
41 )]
42 pub access_key_id: Option<Option<String>>,
43 #[serde(
45 rename = "secretAccessKey",
46 default,
47 with = "::serde_with::rust::double_option",
48 skip_serializing_if = "Option::is_none"
49 )]
50 pub secret_access_key: Option<Option<String>>,
51 #[serde(
53 rename = "prefix",
54 default,
55 with = "::serde_with::rust::double_option",
56 skip_serializing_if = "Option::is_none"
57 )]
58 pub prefix: Option<Option<String>>,
59 #[serde(rename = "exportFrequency")]
60 pub export_frequency: models::BlobStorageExportFrequency,
61 #[serde(rename = "enabled")]
63 pub enabled: bool,
64 #[serde(rename = "forcePathStyle")]
66 pub force_path_style: bool,
67 #[serde(rename = "fileType")]
68 pub file_type: models::BlobStorageIntegrationFileType,
69 #[serde(rename = "exportMode")]
70 pub export_mode: models::BlobStorageExportMode,
71 #[serde(
73 rename = "exportStartDate",
74 default,
75 with = "::serde_with::rust::double_option",
76 skip_serializing_if = "Option::is_none"
77 )]
78 pub export_start_date: Option<Option<chrono::DateTime<chrono::FixedOffset>>>,
79 #[serde(
81 rename = "compressed",
82 default,
83 with = "::serde_with::rust::double_option",
84 skip_serializing_if = "Option::is_none"
85 )]
86 pub compressed: Option<Option<bool>>,
87 #[serde(rename = "exportSource", skip_serializing_if = "Option::is_none")]
88 pub export_source: Option<models::BlobStorageExportSource>,
89 #[serde(
91 rename = "exportFieldGroups",
92 default,
93 with = "::serde_with::rust::double_option",
94 skip_serializing_if = "Option::is_none"
95 )]
96 pub export_field_groups: Option<Option<Vec<models::BlobStorageExportFieldGroup>>>,
97}
98
99impl CreateBlobStorageIntegrationRequest {
100 pub fn new(
101 project_id: String,
102 r#type: models::BlobStorageIntegrationType,
103 bucket_name: String,
104 region: String,
105 export_frequency: models::BlobStorageExportFrequency,
106 enabled: bool,
107 force_path_style: bool,
108 file_type: models::BlobStorageIntegrationFileType,
109 export_mode: models::BlobStorageExportMode,
110 ) -> CreateBlobStorageIntegrationRequest {
111 CreateBlobStorageIntegrationRequest {
112 project_id,
113 r#type,
114 bucket_name,
115 endpoint: None,
116 region,
117 access_key_id: None,
118 secret_access_key: None,
119 prefix: None,
120 export_frequency,
121 enabled,
122 force_path_style,
123 file_type,
124 export_mode,
125 export_start_date: None,
126 compressed: None,
127 export_source: None,
128 export_field_groups: None,
129 }
130 }
131}