From 4207c242310753ce77693d51a05e6eebf69be946 Mon Sep 17 00:00:00 2001 From: ZhongFuze Date: Fri, 16 Aug 2024 14:49:27 +0800 Subject: [PATCH 1/2] [!] Fix `expired_at` value overwriting issue --- src/tigergraph/edge/hold.rs | 10 +++++----- src/tigergraph/edge/proof.rs | 2 +- src/tigergraph/mod.rs | 24 ++++++++++++++++++++++++ src/tigergraph/vertex/identity.rs | 12 ++++++------ src/upstream/the_graph/tests.rs | 14 ++++++++++---- src/util/mod.rs | 4 ++++ 6 files changed, 50 insertions(+), 16 deletions(-) diff --git a/src/tigergraph/edge/hold.rs b/src/tigergraph/edge/hold.rs index 14b9fd29..c5de9bb3 100644 --- a/src/tigergraph/edge/hold.rs +++ b/src/tigergraph/edge/hold.rs @@ -210,15 +210,15 @@ impl Transfer for HoldRecord { "expired_at".to_string(), Attribute { value: json!(expired_at), - op: None, + op: Some(OpCode::Max), }, ); } else { attributes_map.insert( "expired_at".to_string(), Attribute { - value: json!("1970-01-01 00:00:00"), // default value - op: None, + value: json!("1970-01-01T00:00:00"), // default value + op: Some(OpCode::Max), }, ); } @@ -237,14 +237,14 @@ impl Transfer for HoldRecord { map.insert( "created_at".to_string(), self.created_at - .map_or(json!("1970-01-01 00:00:00"), |created_at| json!(created_at)), + .map_or(json!("1970-01-01T00:00:00"), |created_at| json!(created_at)), ); map.insert("updated_at".to_string(), json!(self.updated_at)); map.insert("fetcher".to_string(), json!(self.fetcher)); map.insert( "expired_at".to_string(), self.expired_at - .map_or(json!("1970-01-01 00:00:00"), |expired_at| json!(expired_at)), + .map_or(json!("1970-01-01T00:00:00"), |expired_at| json!(expired_at)), ); map } diff --git a/src/tigergraph/edge/proof.rs b/src/tigergraph/edge/proof.rs index bdac6220..0d9db6f8 100644 --- a/src/tigergraph/edge/proof.rs +++ b/src/tigergraph/edge/proof.rs @@ -203,7 +203,7 @@ impl Transfer for ProofRecord { map.insert( "created_at".to_string(), self.created_at - .map_or(json!("1970-01-01 00:00:00"), |created_at| json!(created_at)), + .map_or(json!("1970-01-01T00:00:00"), |created_at| json!(created_at)), ); map.insert("updated_at".to_string(), json!(self.updated_at)); map.insert("fetcher".to_string(), json!(self.fetcher)); diff --git a/src/tigergraph/mod.rs b/src/tigergraph/mod.rs index f06753fa..526d284b 100644 --- a/src/tigergraph/mod.rs +++ b/src/tigergraph/mod.rs @@ -18,6 +18,7 @@ use crate::{ util::{make_client, naive_now, parse_body}, }; +use chrono::NaiveDateTime; use http::uri::InvalidUri; use hyper::Method; use hyper::{client::HttpConnector, Body, Client}; @@ -895,6 +896,29 @@ impl From for UpsertGraph { { for (key, new_attr) in new_attributes { match key.as_str() { + "expired_at" => { + if let Some(existing_attr) = + existing_attributes.get_mut("expired_at") + { + if let (Some(exist_expired_at), Some(new_expired_at)) = ( + existing_attr.value.as_str().and_then(|s| { + NaiveDateTime::parse_from_str(s, "%Y-%m-%dT%H:%M:%S") + .ok() + }), + new_attr.value.as_str().and_then(|s| { + NaiveDateTime::parse_from_str(s, "%Y-%m-%dT%H:%M:%S") + .ok() + }), + ) { + // Compare and update if the new expiration date is later + if new_expired_at > exist_expired_at { + existing_attr.value = new_attr.value; + } + } + } else { + existing_attributes.insert(key, new_attr); + } + } "reverse" => { if let Some(existing_attr) = existing_attributes.get_mut("reverse") { diff --git a/src/tigergraph/vertex/identity.rs b/src/tigergraph/vertex/identity.rs index 97e5c290..80b6bff0 100644 --- a/src/tigergraph/vertex/identity.rs +++ b/src/tigergraph/vertex/identity.rs @@ -233,7 +233,7 @@ impl Transfer for Identity { "added_at".to_string(), Attribute { value: json!(self.added_at), - op: None, + op: Some(OpCode::IgnoreIfExists), }, ); attributes_map.insert( @@ -248,15 +248,15 @@ impl Transfer for Identity { "expired_at".to_string(), Attribute { value: json!(expired_at), - op: None, + op: Some(OpCode::Max), }, ); } else { attributes_map.insert( "expired_at".to_string(), Attribute { - value: json!("1970-01-01 00:00:00"), // default value - op: None, + value: json!("1970-01-01T00:00:00"), // default value + op: Some(OpCode::Max), }, ); } @@ -308,14 +308,14 @@ impl Transfer for Identity { map.insert( "created_at".to_string(), self.created_at - .map_or(json!("1970-01-01 00:00:00"), |created_at| json!(created_at)), + .map_or(json!("1970-01-01T00:00:00"), |created_at| json!(created_at)), ); map.insert("added_at".to_string(), json!(self.added_at)); map.insert("updated_at".to_string(), json!(self.updated_at)); map.insert( "expired_at".to_string(), self.expired_at - .map_or(json!("1970-01-01 00:00:00"), |expired_at| json!(expired_at)), + .map_or(json!("1970-01-01T00:00:00"), |expired_at| json!(expired_at)), ); map.insert( "reverse".to_string(), diff --git a/src/upstream/the_graph/tests.rs b/src/upstream/the_graph/tests.rs index b9eecdb8..3e1ac26b 100644 --- a/src/upstream/the_graph/tests.rs +++ b/src/upstream/the_graph/tests.rs @@ -1,7 +1,7 @@ use crate::{ error::Error, tigergraph::{ - batch_upsert_domains, + batch_upsert, batch_upsert_domains, edge::Hold, vertex::{Contract, Identity}, }, @@ -19,12 +19,18 @@ async fn test_find_ens_by_wallet() -> Result<(), Error> { Platform::Ethereum, "0x934b510d4c9103e6a87aef13b816fb080286d649".into(), ); - let (targets, all_edges) = TheGraph::batch_fetch(&target).await?; - println!("targets {:?}", targets); + // let target = Target::NFT( + // Chain::Ethereum, + // ContractCategory::ENS, + // ContractCategory::ENS.default_contract_address().unwrap(), + // "sujiyan.eth".into(), + // ); + let (_, all_edges) = TheGraph::batch_fetch(&target).await?; + println!("all_edges {:?}", all_edges); let gsql_cli = make_http_client(); if !all_edges.is_empty() { - batch_upsert_domains(&gsql_cli, all_edges).await?; + batch_upsert(&gsql_cli, all_edges).await?; } Ok(()) } diff --git a/src/util/mod.rs b/src/util/mod.rs index 9be4bb8f..fd693b7b 100644 --- a/src/util/mod.rs +++ b/src/util/mod.rs @@ -134,6 +134,10 @@ where // tigergraph DATETIME default value return Ok(None); } + if s == "1970-01-01T00:00:00" { + // tigergraph DATETIME default value + return Ok(None); + } let dt = NaiveDateTime::parse_from_str(&s, "%Y-%m-%d %H:%M:%S") .map_err(serde::de::Error::custom)?; Ok(Some(dt)) From 2fdc52390e7fbb0989e7734a5b0c2ee7ad3abf08 Mon Sep 17 00:00:00 2001 From: ZhongFuze Date: Fri, 16 Aug 2024 15:07:46 +0800 Subject: [PATCH 2/2] [!] Fix `Farcaster` one-to-many --- src/tigergraph/vertex/domain_collection.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/tigergraph/vertex/domain_collection.rs b/src/tigergraph/vertex/domain_collection.rs index 8c6dd3e1..9ec759c2 100644 --- a/src/tigergraph/vertex/domain_collection.rs +++ b/src/tigergraph/vertex/domain_collection.rs @@ -288,7 +288,8 @@ impl DomainCollection { .get(&(Platform::Farcaster, EXT::Eth.to_string())) { available_domains.push(exist_domain.to_owned()); - } else if let Some(exist_domain) = + } + if let Some(exist_domain) = exist_tld_map.get(&(Platform::Farcaster, "".to_string())) { available_domains.push(exist_domain.to_owned());