1#[derive(Clone, PartialEq, ::prost::Message)]
4pub struct StreamChatRequest {
5 #[prost(message, repeated, tag = "1")]
6 pub messages: ::prost::alloc::vec::Vec<ModelMessage>,
7 #[prost(string, optional, tag = "2")]
9 pub notebook_as_json: ::core::option::Option<::prost::alloc::string::String>,
10 #[prost(int32, optional, tag = "3")]
12 pub selected_tab_index: ::core::option::Option<i32>,
13 #[prost(message, repeated, tag = "4")]
15 pub images: ::prost::alloc::vec::Vec<ImagePart>,
16}
17#[derive(Clone, PartialEq, ::prost::Message)]
20pub struct ModelMessage {
21 #[prost(oneof = "model_message::Kind", tags = "1, 2")]
22 pub kind: ::core::option::Option<model_message::Kind>,
23}
24pub mod model_message {
26 #[derive(Clone, PartialEq, ::prost::Oneof)]
27 pub enum Kind {
28 #[prost(message, tag = "1")]
29 User(super::UserModelMessage),
30 #[prost(message, tag = "2")]
31 Assistant(super::AssistantModelMessage),
32 }
33}
34#[derive(Clone, PartialEq, ::prost::Message)]
36pub struct UserModelMessage {
37 #[prost(message, repeated, tag = "1")]
38 pub text: ::prost::alloc::vec::Vec<UserContentPart>,
39}
40#[derive(Clone, PartialEq, ::prost::Message)]
42pub struct AssistantModelMessage {
43 #[prost(message, repeated, tag = "1")]
44 pub content_parts: ::prost::alloc::vec::Vec<AssistantContentPart>,
45}
46#[derive(Clone, PartialEq, ::prost::Message)]
47pub struct UserContentPart {
48 #[prost(oneof = "user_content_part::Part", tags = "1")]
49 pub part: ::core::option::Option<user_content_part::Part>,
50}
51pub mod user_content_part {
53 #[derive(Clone, PartialEq, ::prost::Oneof)]
54 pub enum Part {
55 #[prost(message, tag = "1")]
56 Text(super::TextPart),
57 }
58}
59#[derive(Clone, PartialEq, ::prost::Message)]
61pub struct AssistantContentPart {
62 #[prost(oneof = "assistant_content_part::Part", tags = "1, 2")]
63 pub part: ::core::option::Option<assistant_content_part::Part>,
64}
65pub mod assistant_content_part {
67 #[derive(Clone, PartialEq, ::prost::Oneof)]
68 pub enum Part {
69 #[prost(message, tag = "1")]
70 Text(super::TextPart),
71 #[prost(message, tag = "2")]
72 Reasoning(super::ReasoningPart),
73 }
74}
75#[derive(Clone, PartialEq, ::prost::Message)]
77pub struct TextPart {
78 #[prost(string, tag = "1")]
79 pub text: ::prost::alloc::string::String,
80}
81#[derive(Clone, PartialEq, ::prost::Message)]
83pub struct ImagePart {
84 #[prost(bytes = "vec", tag = "1")]
86 pub data: ::prost::alloc::vec::Vec<u8>,
87 #[prost(string, optional, tag = "2")]
89 pub media_type: ::core::option::Option<::prost::alloc::string::String>,
90 #[prost(string, optional, tag = "3")]
92 pub filename: ::core::option::Option<::prost::alloc::string::String>,
93}
94#[derive(Clone, PartialEq, ::prost::Message)]
96pub struct ReasoningPart {
97 #[prost(string, tag = "1")]
98 pub reasoning: ::prost::alloc::string::String,
99}
100#[derive(Clone, PartialEq, ::prost::Message)]
102pub struct StreamChatResponse {
103 #[prost(
104 oneof = "stream_chat_response::Response",
105 tags = "1, 2, 3, 4, 5, 6, 7, 8, 9, 10"
106 )]
107 pub response: ::core::option::Option<stream_chat_response::Response>,
108}
109pub mod stream_chat_response {
111 #[derive(Clone, PartialEq, ::prost::Oneof)]
112 pub enum Response {
113 #[prost(message, tag = "1")]
114 Finish(super::Finish),
115 #[prost(message, tag = "2")]
116 Error(super::Error),
117 #[prost(message, tag = "3")]
118 TextStart(super::TextStart),
119 #[prost(message, tag = "4")]
120 TextDelta(super::TextDelta),
121 #[prost(message, tag = "5")]
122 TextEnd(super::TextEnd),
123 #[prost(message, tag = "6")]
124 ReasoningStart(super::ReasoningStart),
125 #[prost(message, tag = "7")]
126 ReasoningDelta(super::ReasoningDelta),
127 #[prost(message, tag = "8")]
128 ReasoningEnd(super::ReasoningEnd),
129 #[prost(message, tag = "9")]
130 WorkbookMutation(super::WorkbookMutation),
131 #[prost(message, tag = "10")]
132 ToolAction(super::ToolAction),
133 }
134}
135#[derive(Clone, Copy, PartialEq, ::prost::Message)]
137pub struct Finish {}
138#[derive(Clone, PartialEq, ::prost::Message)]
140pub struct Error {
141 #[prost(string, tag = "1")]
142 pub message: ::prost::alloc::string::String,
143}
144#[derive(Clone, PartialEq, ::prost::Message)]
146pub struct TextStart {
147 #[prost(string, tag = "1")]
150 pub id: ::prost::alloc::string::String,
151}
152#[derive(Clone, PartialEq, ::prost::Message)]
154pub struct TextDelta {
155 #[prost(string, tag = "1")]
156 pub id: ::prost::alloc::string::String,
157 #[prost(string, tag = "2")]
159 pub delta: ::prost::alloc::string::String,
160}
161#[derive(Clone, PartialEq, ::prost::Message)]
163pub struct TextEnd {
164 #[prost(string, tag = "1")]
165 pub id: ::prost::alloc::string::String,
166}
167#[derive(Clone, PartialEq, ::prost::Message)]
169pub struct ReasoningStart {
170 #[prost(string, tag = "1")]
171 pub id: ::prost::alloc::string::String,
172}
173#[derive(Clone, PartialEq, ::prost::Message)]
175pub struct ReasoningDelta {
176 #[prost(string, tag = "1")]
177 pub id: ::prost::alloc::string::String,
178 #[prost(string, tag = "2")]
180 pub delta: ::prost::alloc::string::String,
181}
182#[derive(Clone, PartialEq, ::prost::Message)]
184pub struct ReasoningEnd {
185 #[prost(string, tag = "1")]
186 pub id: ::prost::alloc::string::String,
187}
188#[derive(Clone, PartialEq, ::prost::Message)]
190pub struct AddTabMutation {
191 #[prost(string, optional, tag = "1")]
193 pub tab_name: ::core::option::Option<::prost::alloc::string::String>,
194}
195#[derive(Clone, PartialEq, ::prost::Message)]
197pub struct AddOrUpdatePanelMutation {
198 #[prost(string, tag = "1")]
200 pub panel_as_json: ::prost::alloc::string::String,
201 #[prost(string, tag = "2")]
202 pub panel_id: ::prost::alloc::string::String,
203 #[prost(int32, tag = "3")]
204 pub tab_index: i32,
205}
206#[derive(Clone, PartialEq, ::prost::Message)]
207pub struct RemovePanelsMutation {
208 #[prost(string, repeated, tag = "1")]
209 pub panel_ids: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
210}
211#[derive(Clone, PartialEq, ::prost::Message)]
213pub struct AddOrReplaceVariableMutation {
214 #[prost(string, tag = "1")]
218 pub compute_spec_as_json: ::prost::alloc::string::String,
219 #[prost(string, optional, tag = "2")]
221 pub variable_name: ::core::option::Option<::prost::alloc::string::String>,
222 #[prost(string, optional, tag = "3")]
223 pub display_name: ::core::option::Option<::prost::alloc::string::String>,
224}
225#[derive(Clone, PartialEq, ::prost::Message)]
227pub struct DeleteVariablesMutation {
228 #[prost(string, repeated, tag = "1")]
229 pub variable_names: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
230}
231#[derive(Clone, PartialEq, ::prost::Message)]
233pub struct WorkbookMutation {
234 #[prost(string, tag = "1")]
235 pub id: ::prost::alloc::string::String,
236 #[prost(oneof = "workbook_mutation::Mutation", tags = "2, 3, 4, 5, 6")]
237 pub mutation: ::core::option::Option<workbook_mutation::Mutation>,
238}
239pub mod workbook_mutation {
241 #[derive(Clone, PartialEq, ::prost::Oneof)]
242 pub enum Mutation {
243 #[prost(message, tag = "2")]
244 AddTab(super::AddTabMutation),
245 #[prost(message, tag = "3")]
246 AddOrUpdatePanel(super::AddOrUpdatePanelMutation),
247 #[prost(message, tag = "4")]
248 RemovePanels(super::RemovePanelsMutation),
249 #[prost(message, tag = "5")]
250 AddOrReplaceVariable(super::AddOrReplaceVariableMutation),
251 #[prost(message, tag = "6")]
252 DeleteVariables(super::DeleteVariablesMutation),
253 }
254}
255#[derive(Clone, PartialEq, ::prost::Message)]
260pub struct ToolAction {
261 #[prost(string, tag = "1")]
262 pub id: ::prost::alloc::string::String,
263 #[prost(string, tag = "2")]
265 pub tool_action_verb: ::prost::alloc::string::String,
266 #[prost(string, optional, tag = "3")]
268 pub tool_target: ::core::option::Option<::prost::alloc::string::String>,
269}
270pub mod workbook_agent_service_client {
272 #![allow(
273 unused_variables,
274 dead_code,
275 missing_docs,
276 clippy::wildcard_imports,
277 clippy::let_unit_value,
278 )]
279 use tonic::codegen::*;
280 use tonic::codegen::http::Uri;
281 #[derive(Debug, Clone)]
283 pub struct WorkbookAgentServiceClient<T> {
284 inner: tonic::client::Grpc<T>,
285 }
286 impl WorkbookAgentServiceClient<tonic::transport::Channel> {
287 pub async fn connect<D>(dst: D) -> Result<Self, tonic::transport::Error>
289 where
290 D: TryInto<tonic::transport::Endpoint>,
291 D::Error: Into<StdError>,
292 {
293 let conn = tonic::transport::Endpoint::new(dst)?.connect().await?;
294 Ok(Self::new(conn))
295 }
296 }
297 impl<T> WorkbookAgentServiceClient<T>
298 where
299 T: tonic::client::GrpcService<tonic::body::Body>,
300 T::Error: Into<StdError>,
301 T::ResponseBody: Body<Data = Bytes> + std::marker::Send + 'static,
302 <T::ResponseBody as Body>::Error: Into<StdError> + std::marker::Send,
303 {
304 pub fn new(inner: T) -> Self {
305 let inner = tonic::client::Grpc::new(inner);
306 Self { inner }
307 }
308 pub fn with_origin(inner: T, origin: Uri) -> Self {
309 let inner = tonic::client::Grpc::with_origin(inner, origin);
310 Self { inner }
311 }
312 pub fn with_interceptor<F>(
313 inner: T,
314 interceptor: F,
315 ) -> WorkbookAgentServiceClient<InterceptedService<T, F>>
316 where
317 F: tonic::service::Interceptor,
318 T::ResponseBody: Default,
319 T: tonic::codegen::Service<
320 http::Request<tonic::body::Body>,
321 Response = http::Response<
322 <T as tonic::client::GrpcService<tonic::body::Body>>::ResponseBody,
323 >,
324 >,
325 <T as tonic::codegen::Service<
326 http::Request<tonic::body::Body>,
327 >>::Error: Into<StdError> + std::marker::Send + std::marker::Sync,
328 {
329 WorkbookAgentServiceClient::new(InterceptedService::new(inner, interceptor))
330 }
331 #[must_use]
336 pub fn send_compressed(mut self, encoding: CompressionEncoding) -> Self {
337 self.inner = self.inner.send_compressed(encoding);
338 self
339 }
340 #[must_use]
342 pub fn accept_compressed(mut self, encoding: CompressionEncoding) -> Self {
343 self.inner = self.inner.accept_compressed(encoding);
344 self
345 }
346 #[must_use]
350 pub fn max_decoding_message_size(mut self, limit: usize) -> Self {
351 self.inner = self.inner.max_decoding_message_size(limit);
352 self
353 }
354 #[must_use]
358 pub fn max_encoding_message_size(mut self, limit: usize) -> Self {
359 self.inner = self.inner.max_encoding_message_size(limit);
360 self
361 }
362 pub async fn stream_chat(
364 &mut self,
365 request: impl tonic::IntoRequest<super::StreamChatRequest>,
366 ) -> std::result::Result<
367 tonic::Response<tonic::codec::Streaming<super::StreamChatResponse>>,
368 tonic::Status,
369 > {
370 self.inner
371 .ready()
372 .await
373 .map_err(|e| {
374 tonic::Status::unknown(
375 format!("Service was not ready: {}", e.into()),
376 )
377 })?;
378 let codec = tonic::codec::ProstCodec::default();
379 let path = http::uri::PathAndQuery::from_static(
380 "/nominal.ai.v1.WorkbookAgentService/StreamChat",
381 );
382 let mut req = request.into_request();
383 req.extensions_mut()
384 .insert(
385 GrpcMethod::new("nominal.ai.v1.WorkbookAgentService", "StreamChat"),
386 );
387 self.inner.server_streaming(req, path, codec).await
388 }
389 }
390}