queries.rs 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. use heed3::RoTxn;
  2. use get_routes::handler;
  3. use helix_db::{field_remapping, identifier_remapping, traversal_remapping, exclude_field, value_remapping};
  4. use helix_db::helix_engine::vector_core::vector::HVector;
  5. use helix_db::{
  6. helix_engine::graph_core::ops::{
  7. g::G,
  8. in_::{in_::InAdapter, in_e::InEdgesAdapter, to_n::ToNAdapter},
  9. out::{from_n::FromNAdapter, out::OutAdapter, out_e::OutEdgesAdapter},
  10. source::{
  11. add_e::{AddEAdapter, EdgeType},
  12. add_n::AddNAdapter,
  13. e_from_id::EFromIdAdapter,
  14. e_from_type::EFromTypeAdapter,
  15. n_from_id::NFromIdAdapter,
  16. n_from_type::NFromTypeAdapter,
  17. n_from_index::NFromIndexAdapter,
  18. },
  19. tr_val::{Traversable, TraversalVal},
  20. util::{
  21. dedup::DedupAdapter, filter_mut::FilterMut,
  22. filter_ref::FilterRefAdapter, range::RangeAdapter, update::UpdateAdapter,
  23. map::MapAdapter, paths::ShortestPathAdapter, props::PropsAdapter, drop::Drop,
  24. },
  25. vectors::{insert::InsertVAdapter, search::SearchVAdapter, brute_force_search::BruteForceSearchVAdapter},
  26. bm25::search_bm25::SearchBM25Adapter,
  27. },
  28. helix_engine::types::GraphError,
  29. helix_gateway::router::router::HandlerInput,
  30. node_matches, props,
  31. protocol::count::Count,
  32. protocol::remapping::{RemappingMap, ResponseRemapping},
  33. protocol::response::Response,
  34. protocol::{
  35. filterable::Filterable, remapping::Remapping, return_values::ReturnValue, value::Value, id::ID,
  36. },
  37. };
  38. use sonic_rs::{Deserialize, Serialize};
  39. use std::collections::{HashMap, HashSet};
  40. use std::sync::Arc;
  41. use std::time::Instant;
  42. use std::cell::RefCell;
  43. use chrono::{DateTime, Utc};
  44. pub struct Chapter {
  45. pub chapter_index: i64,
  46. }
  47. pub struct SubChapter {
  48. pub title: String,
  49. pub content: String,
  50. }
  51. pub struct Contains {
  52. pub from: Chapter,
  53. pub to: SubChapter,
  54. }
  55. pub struct EmbeddingOf {
  56. pub from: SubChapter,
  57. pub to: Embedding,
  58. pub chunk: String,
  59. }
  60. pub struct Embedding {
  61. pub chunk: String,
  62. }
  63. #[derive(Serialize, Deserialize)]
  64. pub struct searchdocs_ragInput {
  65. pub query: Vec<f64>,
  66. pub k: i32
  67. }
  68. #[handler]
  69. pub fn searchdocs_rag (input: &HandlerInput, response: &mut Response) -> Result<(), GraphError> {
  70. let data: searchdocs_ragInput = match sonic_rs::from_slice(&input.request.body) {
  71. Ok(data) => data,
  72. Err(err) => return Err(GraphError::from(err)),
  73. };
  74. let mut remapping_vals = RemappingMap::new();
  75. let db = Arc::clone(&input.graph.storage);
  76. let txn = db.graph_env.read_txn().unwrap();
  77. let vecs = G::new(Arc::clone(&db), &txn)
  78. .search_v::<fn(&HVector, &RoTxn) -> bool>(&data.query, data.k as usize, None).collect_to::<Vec<_>>();
  79. let subchapters = G::new_from(Arc::clone(&db), &txn, vecs.clone())
  80. .in_("EmbeddingOf",&EdgeType::Node).collect_to::<Vec<_>>();
  81. let mut return_vals: HashMap<String, ReturnValue> = HashMap::new();
  82. return_vals.insert("subchapters".to_string(), ReturnValue::from_traversal_value_array_with_mixin(G::new_from(Arc::clone(&db), &txn, subchapters.clone()).collect_to::<Vec<_>>().clone(), remapping_vals.borrow_mut()));
  83. txn.commit().unwrap();
  84. response.body = sonic_rs::to_vec(&return_vals).unwrap();
  85. Ok(())
  86. }
  87. #[derive(Serialize, Deserialize)]
  88. pub struct edge_nodeInput {
  89. pub id: ID
  90. }
  91. #[handler]
  92. pub fn edge_node (input: &HandlerInput, response: &mut Response) -> Result<(), GraphError> {
  93. let data: edge_nodeInput = match sonic_rs::from_slice(&input.request.body) {
  94. Ok(data) => data,
  95. Err(err) => return Err(GraphError::from(err)),
  96. };
  97. let mut remapping_vals = RemappingMap::new();
  98. let db = Arc::clone(&input.graph.storage);
  99. let txn = db.graph_env.read_txn().unwrap();
  100. let e = G::new(Arc::clone(&db), &txn)
  101. .n_from_type("Chapter")
  102. .out_e("Contains").collect_to::<Vec<_>>();
  103. let mut return_vals: HashMap<String, ReturnValue> = HashMap::new();
  104. return_vals.insert("e".to_string(), ReturnValue::from_traversal_value_array_with_mixin(e.clone(), remapping_vals.borrow_mut()));
  105. txn.commit().unwrap();
  106. response.body = sonic_rs::to_vec(&return_vals).unwrap();
  107. Ok(())
  108. }
  109. #[derive(Serialize, Deserialize)]
  110. pub struct chunksData {
  111. pub vector: Vec<f64>,
  112. pub chunk: String,
  113. }
  114. #[derive(Serialize, Deserialize)]
  115. pub struct subchaptersData {
  116. pub content: String,
  117. pub title: String,
  118. pub chunks: Vec<chunksData>,
  119. }
  120. #[derive(Serialize, Deserialize)]
  121. pub struct chaptersData {
  122. pub id: i64,
  123. pub subchapters: Vec<subchaptersData>,
  124. }
  125. #[derive(Serialize, Deserialize)]
  126. pub struct loaddocs_ragInput {
  127. pub chapters: Vec<chaptersData>
  128. }
  129. #[handler]
  130. pub fn loaddocs_rag (input: &HandlerInput, response: &mut Response) -> Result<(), GraphError> {
  131. let data: loaddocs_ragInput = match sonic_rs::from_slice(&input.request.body) {
  132. Ok(data) => data,
  133. Err(err) => return Err(GraphError::from(err)),
  134. };
  135. let mut remapping_vals = RemappingMap::new();
  136. let db = Arc::clone(&input.graph.storage);
  137. let mut txn = db.graph_env.write_txn().unwrap();
  138. for data in data.chapters {
  139. let chapter_node = G::new_mut(Arc::clone(&db), &mut txn)
  140. .add_n("Chapter", Some(props! { "chapter_index" => data.id.clone() }), None).collect_to::<Vec<_>>();
  141. for data in data.subchapters {
  142. let subchapter_node = G::new_mut(Arc::clone(&db), &mut txn)
  143. .add_n("SubChapter", Some(props! { "title" => data.title.clone(), "content" => data.content.clone() }), None).collect_to::<Vec<_>>();
  144. G::new_mut(Arc::clone(&db), &mut txn)
  145. .add_e("Contains", None, chapter_node.id(), subchapter_node.id(), true, EdgeType::Node).collect_to::<Vec<_>>();
  146. for data in data.chunks {
  147. let vec = G::new_mut(Arc::clone(&db), &mut txn)
  148. .insert_v::<fn(&HVector, &RoTxn) -> bool>(&data.vector, "Embedding", None).collect_to::<Vec<_>>();
  149. G::new_mut(Arc::clone(&db), &mut txn)
  150. .add_e("EmbeddingOf", Some(props! { "chunk" => data.chunk.clone() }), subchapter_node.id(), vec.id(), true, EdgeType::Node).collect_to::<Vec<_>>();
  151. }
  152. ;
  153. }
  154. ;
  155. }
  156. ;
  157. let mut return_vals: HashMap<String, ReturnValue> = HashMap::new();
  158. return_vals.insert("Success".to_string(), ReturnValue::from(Value::from("Success")));
  159. txn.commit().unwrap();
  160. response.body = sonic_rs::to_vec(&return_vals).unwrap();
  161. Ok(())
  162. }