Skip to content

Commit

Permalink
Merge pull request #167 from ZhongFuze/upstream/basenames
Browse files Browse the repository at this point in the history
Upstream/basenames
  • Loading branch information
nykma authored Sep 3, 2024
2 parents 182432f + 4d989d8 commit d199cf1
Show file tree
Hide file tree
Showing 10 changed files with 151 additions and 31 deletions.
47 changes: 23 additions & 24 deletions src/config/tdb/migrations/LoadingJob_SocialGraph.gsql
Original file line number Diff line number Diff line change
Expand Up @@ -494,11 +494,11 @@ CREATE OR REPLACE QUERY delete_graph_inner_connection(VERTEX<Identities> p, INT
// DELETE e FROM vertex2delete:s-((Hold_Contract>):e)-Contracts:c;
// DELETE e FROM vertex2delete:s-((Reverse_Resolve_Contract>):e)-Contracts:c;
// DELETE e FROM vertex2delete:s-((<Resolve_Contract):e)-Contracts:c;
DELETE e FROM vertex2delete:s-((<Hold_Identity):e)-Identities:t WHERE s.platform != "ens" AND s.platform != "unstoppabledomains";
DELETE e FROM vertex2delete:s-((<Resolve):e)-Identities:t WHERE t.platform != "ens" AND t.platform != "unstoppabledomains";
DELETE e FROM vertex2delete:s-((<Reverse_Resolve):e)-Identities:t WHERE s.platform != "ens" AND s.platform != "unstoppabledomains";
DELETE e FROM vertex2delete:s-((<Proof_Forward):e)-Identities:t;
DELETE e FROM vertex2delete:s-((<Proof_Backward):e)-Identities:t;
// DELETE e FROM vertex2delete:s-((<Hold_Identity):e)-Identities:t WHERE s.platform != "ens" AND s.platform != "unstoppabledomains";
// DELETE e FROM vertex2delete:s-((<Resolve):e)-Identities:t WHERE t.platform != "ens" AND t.platform != "unstoppabledomains";
// DELETE e FROM vertex2delete:s-((<Reverse_Resolve):e)-Identities:t WHERE s.platform != "ens" AND s.platform != "unstoppabledomains";
// DELETE e FROM vertex2delete:s-((<Proof_Forward):e)-Identities:t;
// DELETE e FROM vertex2delete:s-((<Proof_Backward):e)-Identities:t;
}


Expand All @@ -514,8 +514,7 @@ CREATE OR REPLACE QUERY delete_graph_inner_connection_test(VERTEX<Identities> p,

CREATE OR REPLACE QUERY delete_domain_collection(VERTEX<DomainCollection> p) FOR GRAPH SocialGraph {
vertex2delete (DomainCollection) = {p};
DELETE e FROM vertex2delete:s-((PartOfCollection>):e)-Identities:tgt;
DELETE s FROM vertex2delete:s;
DELETE e FROM vertex2delete:s-((PartOfCollection>):e)-Identities:tgt WHERE tgt.platform != "basenames";
}

CREATE OR REPLACE QUERY clear_domain_search_cache() FOR GRAPH SocialGraph {
Expand All @@ -541,7 +540,7 @@ CREATE OR REPLACE QUERY domain_available_search(STRING id) FOR GRAPH SocialGraph

CREATE OR REPLACE QUERY domain_available_search_draft(SET<STRING> names, SET<STRING> ens_names) FOR GRAPH SocialGraph {
TYPEDEF TUPLE< STRING system, STRING name, DATETIME expired_at > DomainResult;
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ens", "sns", "genome", "clusters"];
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ens", "sns", "genome", "clusters", "basenames"];

SetAccum<DomainResult> @@domain_result;
owner = SELECT s FROM Identities:s-((Hold_Identity>):e)-Identities:v
Expand Down Expand Up @@ -579,7 +578,7 @@ CREATE OR REPLACE QUERY find_identity_graph_resolve(STRING platform, STRING iden
PRINT seed;
graph_id = @@minUpdateTime.id;

ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters"];
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters", "basenames"];
ListAccum<STRING> @@edge_type = ["Proof_Forward", "Proof_Backward", "Hold_Identity", "Resolve", "Reverse_Resolve"];

vset = SELECT v FROM Identities:v-((PartOfIdentitiesGraph>):e)-identities_graph LIMIT 500;
Expand Down Expand Up @@ -625,7 +624,7 @@ CREATE OR REPLACE QUERY find_expand_identity(STRING platform, STRING identity) F
SetAccum<Address> @owner_address;
SetAccum<Address> @resolve_address;

ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters"];
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters", "basenames"];
IF @@domainSystems.contains(platform) == TRUE THEN
tmp = SELECT domain FROM seed:domain-((<Hold_Identity):e)-Identities:owner
ACCUM domain.@owner_address += Address(owner.platform, owner.identity);
Expand Down Expand Up @@ -663,7 +662,7 @@ CREATE OR REPLACE QUERY find_identity_graph(STRING p, INT reverse_flag=0) FOR GR
POST-ACCUM s.@degree += 1;
graph_id = @@minUpdateTime.id;

ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters"];
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters", "basenames"];
ListAccum<STRING> @@edge_type = ["Proof_Forward", "Proof_Backward", "Hold_Identity", "Resolve", "Reverse_Resolve"];

IF reverse_flag == 1 THEN
Expand All @@ -675,21 +674,21 @@ CREATE OR REPLACE QUERY find_identity_graph(STRING p, INT reverse_flag=0) FOR GR
tmp2 = SELECT v1 FROM vset:v1-((<Proof_Forward|<Proof_Backward):e2)-vset:v2
ACCUM @@edges += IdentityConnection(v2, v1, e2.source, "Proof"), v1.@degree += 1, v2.@degree += 1;
tmp4 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:i-((Resolve>):e2)-vset:v2
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns"
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns" AND i.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, i, e1.source, "Hold"),
i.@owner_address += Address(v1.platform, v1.identity),
i.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp5 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns"
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns" AND v2.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, v2, e1.source, "Hold"),
v2.@owner_address += Address(v1.platform, v1.identity), v1.@degree += 1, v2.@degree += 1;
tmp3 = SELECT v1 FROM vset:v1-((Resolve>):r)-vset:v2
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns"
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns" OR v1.platform == "basenames"
ACCUM
@@edges += IdentityConnection(v1, v2, r.source, "Resolve"),
v1.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp3_1 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns"
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns" OR v2.platform == "basenames"
ACCUM v2.@owner_address += Address(v1.platform, v1.identity);

tmp6 = SELECT v1 FROM vset:v1-((Reverse_Resolve>):e1)-vset:v2
Expand All @@ -706,21 +705,21 @@ CREATE OR REPLACE QUERY find_identity_graph(STRING p, INT reverse_flag=0) FOR GR
tmp2 = SELECT v1 FROM vset:v1-((<Proof_Forward|<Proof_Backward):e2)-vset:v2
ACCUM @@edges += IdentityConnection(v2, v1, e2.source, "Proof"), v1.@degree += 1, v2.@degree += 1;
tmp4 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:i-((Resolve>):e2)-vset:v2
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns"
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns" AND i.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, i, e1.source, "Hold"),
i.@owner_address += Address(v1.platform, v1.identity),
i.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp5 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns"
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns" AND v2.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, v2, e1.source, "Hold"),
v2.@owner_address += Address(v1.platform, v1.identity), v1.@degree += 1, v2.@degree += 1;
tmp3 = SELECT v1 FROM vset:v1-((Resolve>):r)-vset:v2
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns"
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns" OR v1.platform == "basenames"
ACCUM
@@edges += IdentityConnection(v1, v2, r.source, "Resolve"),
v1.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp3_1 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns"
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns" OR v2.platform == "basenames"
ACCUM v2.@owner_address += Address(v1.platform, v1.identity);
tmp6 = SELECT v1 FROM vset:v1-((Reverse_Resolve>):e1)-vset:v2
ACCUM @@edges += IdentityConnection(v1, v2, e1.source, "Reverse_Resolve"), v1.@degree += 1, v2.@degree += 1;
Expand All @@ -735,21 +734,21 @@ CREATE OR REPLACE QUERY find_identity_graph(STRING p, INT reverse_flag=0) FOR GR
tmp2 = SELECT v1 FROM vset:v1-((<Proof_Forward|<Proof_Backward):e2)-vset:v2
ACCUM @@edges += IdentityConnection(v2, v1, e2.source, "Proof"), v1.@degree += 1, v2.@degree += 1;
tmp4 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:i-((Resolve>):e2)-vset:v2
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns"
WHERE i.platform != "genome" AND i.platform != "ens" AND i.platform != "sns" AND i.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, i, e1.source, "Hold"),
i.@owner_address += Address(v1.platform, v1.identity),
i.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp5 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns"
WHERE v2.platform != "genome" AND v2.platform != "ens" AND v2.platform != "sns" AND v2.platform != "basenames"
ACCUM @@edges += IdentityConnection(v1, v2, e1.source, "Hold"),
v2.@owner_address += Address(v1.platform, v1.identity), v1.@degree += 1, v2.@degree += 1;
tmp3 = SELECT v1 FROM vset:v1-((Resolve>):r)-vset:v2
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns"
WHERE v1.platform == "genome" OR v1.platform == "ens" OR v1.platform == "sns" OR v1.platform == "basenames"
ACCUM
@@edges += IdentityConnection(v1, v2, r.source, "Resolve"),
v1.@resolve_address += Address(v2.platform, v2.identity), v1.@degree += 1, v2.@degree += 1;
tmp3_1 = SELECT v1 FROM vset:v1-((Hold_Identity>):e1)-vset:v2
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns"
WHERE v2.platform == "genome" OR v2.platform == "ens" OR v2.platform == "sns" OR v2.platform == "basenames"
ACCUM v2.@owner_address += Address(v1.platform, v1.identity);

tmp6 = SELECT v1 FROM vset:v1-((Reverse_Resolve>):e1)-vset:v2
Expand Down Expand Up @@ -791,7 +790,7 @@ CREATE OR REPLACE QUERY neighbors_with_source_reverse(VERTEX<Identities> p, INT
SetAccum<STRING> @source_list;
SetAccum<EDGE> @@edge_set;
SetAccum<VERTEX<Identities>> @@vertices;
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters"];
ListAccum<STRING> @@domainSystems = ["dotbit", "lens", "unstoppabledomains", "space_id", "crossbell", "ENS", "ens", "sns", "genome", "clusters", "basenames"];

##### Initialization #####
seed (Identities) = {p};
Expand Down
35 changes: 35 additions & 0 deletions src/config/tdb/migrations/run_loading_jobs.gsql
Original file line number Diff line number Diff line change
@@ -1,3 +1,38 @@
CREATE LOADING JOB Load_Basenames FOR GRAPH SocialGraph {
LOAD "/home/tigergraph/shared_data/basenames/ethereum.Identities.csv"
TO VERTEX Identities VALUES ($"primary_id", $"id", REDUCE(ignore_if_exists($"uuid")), $"platform", $"identity", _, _, _, REDUCE(min($"created_at")), REDUCE(min($"added_at")), REDUCE(max($"updated_at")), _, _, REDUCE(or($"reverse"))) USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/basenames.Identities.csv"
TO VERTEX Identities VALUES ($"primary_id", $"id", REDUCE(ignore_if_exists($"uuid")), $"platform", $"identity", $"display_name", _, _, REDUCE(min($"created_at")), REDUCE(min($"added_at")), REDUCE(max($"updated_at")), _, REDUCE(max($"expired_at")), REDUCE(or($"reverse"))) USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/IdentitiesGraph.csv"
TO VERTEX IdentitiesGraph VALUES ($"primary_id", $"id", $"updated_nanosecond") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/DomainCollection.csv"
TO VERTEX DomainCollection VALUES ($"primary_id", $"id", REDUCE(max($"updated_at"))) USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/Hold_Identity.csv"
TO EDGE Hold_Identity VALUES ($"from", $"to", $"source", REDUCE(ignore_if_exists($"uuid")), _, $"id", REDUCE(min($"created_at")), REDUCE(max($"updated_at")), $"fetcher", REDUCE(max($"expired_at"))) USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/Hold_Contract.csv"
TO EDGE Hold_Contract VALUES ($"from", $"to", $"source", "", $"id", REDUCE(ignore_if_exists($"uuid")), REDUCE(min($"created_at")), REDUCE(max($"updated_at")), $"fetcher", REDUCE(max($"expired_at"))) USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/Resolve.csv"
TO EDGE Resolve VALUES ($"from", $"to", $"source", $"system", $"name", REDUCE(ignore_if_exists($"uuid")), REDUCE(max($"updated_at")), $"fetcher") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/Reverse_Resolve.csv"
TO EDGE Reverse_Resolve VALUES ($"from", $"to", $"source", $"system", $"name", REDUCE(ignore_if_exists($"uuid")), REDUCE(max($"updated_at")), $"fetcher") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/PartOfIdentitiesGraph_Reverse.csv"
TO EDGE PartOfIdentitiesGraph_Reverse VALUES ($"from", $"to") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";

LOAD "/home/tigergraph/shared_data/basenames/PartOfCollection.csv"
TO EDGE PartOfCollection VALUES ($"from", $"to", $"platform", $"name", $"tld", $"status") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";
}

RUN LOADING JOB Load_Basenames


CREATE LOADING JOB Load_DBExport_SocialGraph FOR GRAPH SocialGraph {
LOAD "/home/tigergraph/shared_data/export_graphs/GlobalTypes/Identities.csv"
TO VERTEX Identities VALUES ($"primary_id", $"id", $"uuid", $"platform", $"identity", $"display_name", $"profile_url", $"avatar_url", $"created_at", $"added_at", $"updated_at", $"uid", $"expired_at", $"reverse") USING SEPARATOR = "\t", EOL = "\n", HEADER = "true";
Expand Down
11 changes: 10 additions & 1 deletion src/controller/tigergraphql/identity.rs
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,14 @@ impl IdentityRecord {

/// The expiry date for the domain, from either the registration, or the wrapped domain if PCC is burned
async fn expired_at(&self) -> Option<i64> {
if !vec![Platform::Dotbit, Platform::ENS, Platform::Genome].contains(&self.platform) {
if !vec![
Platform::Dotbit,
Platform::ENS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
return None;
}
self.expired_at.map(|dt| dt.and_utc().timestamp())
Expand All @@ -255,6 +262,7 @@ impl IdentityRecord {
Platform::Solana,
Platform::SNS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
Expand All @@ -275,6 +283,7 @@ impl IdentityRecord {
Platform::ENS,
Platform::SNS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
Expand Down
11 changes: 10 additions & 1 deletion src/controller/tigergraphql/identity_graph.rs
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,14 @@ impl ExpandIdentityRecord {

/// The expiry date for the domain, from either the registration, or the wrapped domain if PCC is burned
async fn expired_at(&self) -> Option<i64> {
if !vec![Platform::Dotbit, Platform::ENS, Platform::Genome].contains(&self.platform) {
if !vec![
Platform::Dotbit,
Platform::ENS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
return None;
}
self.expired_at.map(|dt| dt.and_utc().timestamp())
Expand All @@ -162,6 +169,7 @@ impl ExpandIdentityRecord {
Platform::Solana,
Platform::SNS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
Expand All @@ -182,6 +190,7 @@ impl ExpandIdentityRecord {
Platform::ENS,
Platform::SNS,
Platform::Genome,
Platform::Basenames,
]
.contains(&self.platform)
{
Expand Down
3 changes: 2 additions & 1 deletion src/tigergraph/vertex/domain_collection.rs
Original file line number Diff line number Diff line change
Expand Up @@ -244,9 +244,10 @@ impl DomainCollection {
Platform::ENS,
Platform::Farcaster,
Platform::Lens,
Platform::SNS,
Platform::Clusters,
Platform::Basenames,
Platform::UnstoppableDomains,
Platform::SNS,
Platform::SpaceId,
Platform::Dotbit,
Platform::Crossbell,
Expand Down
Loading

0 comments on commit d199cf1

Please sign in to comment.