1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- use heed3::RoTxn;
- use get_routes::handler;
- use helix_db::{field_remapping, identifier_remapping, traversal_remapping, exclude_field};
- use helix_db::helix_engine::vector_core::vector::HVector;
- use helix_db::{
- helix_engine::graph_core::ops::{
- g::G,
- in_::{in_::InAdapter, in_e::InEdgesAdapter, to_n::ToNAdapter},
- out::{from_n::FromNAdapter, out::OutAdapter, out_e::OutEdgesAdapter},
- source::{
- add_e::{AddEAdapter, EdgeType},
- add_n::AddNAdapter,
- e_from_id::EFromIdAdapter,
- e_from_type::EFromTypeAdapter,
- n_from_id::NFromIdAdapter,
- n_from_type::NFromTypeAdapter,
- n_from_index::NFromIndexAdapter,
- },
- tr_val::{Traversable, TraversalVal},
- util::{
- dedup::DedupAdapter, filter_mut::FilterMut,
- filter_ref::FilterRefAdapter, range::RangeAdapter, update::UpdateAdapter,
- map::MapAdapter, paths::ShortestPathAdapter, props::PropsAdapter, drop::Drop,
- },
- vectors::{insert::InsertVAdapter, search::SearchVAdapter},
- bm25::search_bm25::SearchBM25Adapter,
- },
- helix_engine::types::GraphError,
- helix_gateway::router::router::HandlerInput,
- node_matches, props,
- protocol::count::Count,
- protocol::remapping::ResponseRemapping,
- protocol::response::Response,
- protocol::traversal_value::TraversalValue,
- protocol::{
- filterable::Filterable, remapping::Remapping, return_values::ReturnValue, value::Value, id::ID,
- },
- };
- use sonic_rs::{Deserialize, Serialize};
- use std::collections::{HashMap, HashSet};
- use std::sync::Arc;
- use std::time::Instant;
- use std::cell::RefCell;
- use chrono::{DateTime, Utc};
-
- pub struct File9 {
- pub name: String,
- pub created_at: DateTime<Utc>,
- }
- pub struct EFile9 {
- pub from: File9,
- pub to: File9,
- pub since: DateTime<Utc>,
- }
- #[derive(Serialize, Deserialize)]
- pub struct file9Input {
- pub date: DateTime<Utc>
- }
- #[handler]
- pub fn file9 (input: &HandlerInput, response: &mut Response) -> Result<(), GraphError> {
- let data: file9Input = match sonic_rs::from_slice(&input.request.body) {
- Ok(data) => data,
- Err(err) => return Err(GraphError::from(err)),
- };
- let mut remapping_vals: RefCell<HashMap<u128, ResponseRemapping>> = RefCell::new(HashMap::new());
- let db = Arc::clone(&input.graph.storage);
- let mut txn = db.graph_env.write_txn().unwrap();
- let user = G::new_mut(Arc::clone(&db), &mut txn)
- .add_n("File9", Some(props! { "created_at" => "2021-01-01T00:00:00+00:00", "name" => "File9" }), None).collect_to::<Vec<_>>();
- let user2 = G::new_mut(Arc::clone(&db), &mut txn)
- .add_n("File9", Some(props! { "created_at" => chrono::Utc::now().to_rfc3339(), "name" => "File9" }), None).collect_to::<Vec<_>>();
- let edge = G::new_mut(Arc::clone(&db), &mut txn)
- .add_e("EFile9", None, data.user.clone(), data.user2, true, EdgeType::Node).collect_to::<Vec<_>>();
- let mut return_vals: HashMap<String, ReturnValue> = HashMap::new();
- return_vals.insert("user".to_string(), ReturnValue::from_traversal_value_array_with_mixin(user.clone(), remapping_vals.borrow_mut()));
- return_vals.insert("edge".to_string(), ReturnValue::from_traversal_value_array_with_mixin(edge.clone(), remapping_vals.borrow_mut()));
- txn.commit().unwrap();
- response.body = sonic_rs::to_vec(&return_vals).unwrap();
- Ok(())
- }
|