queries.rs 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. use heed3::RoTxn;
  2. use get_routes::handler;
  3. use helix_db::{field_remapping, identifier_remapping, traversal_remapping, exclude_field};
  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},
  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::ResponseRemapping,
  33. protocol::response::Response,
  34. protocol::traversal_value::TraversalValue,
  35. protocol::{
  36. filterable::Filterable, remapping::Remapping, return_values::ReturnValue, value::Value, id::ID,
  37. },
  38. };
  39. use sonic_rs::{Deserialize, Serialize};
  40. use std::collections::{HashMap, HashSet};
  41. use std::sync::Arc;
  42. use std::time::Instant;
  43. use std::cell::RefCell;
  44. use chrono::{DateTime, Utc};
  45. pub struct File5 {
  46. pub name: String,
  47. pub age: i32,
  48. }
  49. pub struct EdgeFile5 {
  50. pub from: File5,
  51. pub to: File5,
  52. }
  53. #[handler]
  54. pub fn file5 (input: &HandlerInput, response: &mut Response) -> Result<(), GraphError> {
  55. let mut remapping_vals: RefCell<HashMap<u128, ResponseRemapping>> = RefCell::new(HashMap::new());
  56. let db = Arc::clone(&input.graph.storage);
  57. let mut txn = db.graph_env.write_txn().unwrap();
  58. let user = G::new_mut(Arc::clone(&db), &mut txn)
  59. .add_n("File5", Some(props! { "age" => 20, "name" => "John" }), None).collect_to::<Vec<_>>();
  60. let user2 = G::new(Arc::clone(&db), &txn)
  61. .n_from_type("File5")
  62. .out("EdgeFile5",&EdgeType::Node).collect_to::<Vec<_>>();
  63. let mut return_vals: HashMap<String, ReturnValue> = HashMap::new();
  64. return_vals.insert("user".to_string(), ReturnValue::from_traversal_value_array_with_mixin(G::new_from(Arc::clone(&db), &txn, user.clone())
  65. .map_traversal(|item, txn| { traversal_remapping!(remapping_vals, item.clone(), "username" => G::new_from(Arc::clone(&db), &txn, vec![item.clone()])
  66. .check_property("name").collect_to::<Vec<_>>())?;
  67. value_remapping!(remapping_vals, item.clone(), "age" => "21")?;
  68. Ok(item) }).collect_to::<Vec<_>>().clone(), remapping_vals.borrow_mut()));
  69. txn.commit().unwrap();
  70. response.body = sonic_rs::to_vec(&return_vals).unwrap();
  71. Ok(())
  72. }