From 2b48cf5e3cbfc45d83a68494b688e083e7f413fc Mon Sep 17 00:00:00 2001 From: Thomas Marchand Date: Wed, 11 Oct 2023 14:44:57 +0700 Subject: [PATCH] feat: add support for multiple verifiers, use the most recent --- src/config.rs | 2 +- src/endpoints/domain_to_data.rs | 36 ++++++++++++++++++++++++++------- src/endpoints/id_to_data.rs | 35 +++++++++++++++++++++++++------- 3 files changed, 58 insertions(+), 15 deletions(-) diff --git a/src/config.rs b/src/config.rs index f92a9a7..b77d7f7 100644 --- a/src/config.rs +++ b/src/config.rs @@ -28,7 +28,7 @@ pub_struct!(Clone, Deserialize; Database { pub_struct!(Clone, Deserialize; Contracts { starknetid: FieldElement, naming: FieldElement, - verifier: FieldElement, + verifiers: Vec, old_verifier: FieldElement, pop_verifier: FieldElement, }); diff --git a/src/endpoints/domain_to_data.rs b/src/endpoints/domain_to_data.rs index 7390db5..086d280 100644 --- a/src/endpoints/domain_to_data.rs +++ b/src/endpoints/domain_to_data.rs @@ -26,7 +26,9 @@ pub async fn handler( let mut headers = HeaderMap::new(); headers.insert("Cache-Control", HeaderValue::from_static("max-age=30")); - let domains = state.starknetid_db.collection::("domains"); + let domains = state + .starknetid_db + .collection::("domains"); match get_custom_resolver(&domains, &query.domain).await { None => {} Some(res) => { @@ -35,7 +37,9 @@ pub async fn handler( } } - let starknet_ids = state.starknetid_db.collection::("id_owners"); + let starknet_ids = state + .starknetid_db + .collection::("id_owners"); let domain_document = domains .find_one( @@ -71,6 +75,17 @@ pub async fn handler( Ok(Some(doc)) => doc.get_str("owner").ok().map(String::from).unwrap(), _ => return get_error("Error while fetching starknet-id from database".to_string()), }; + let current_social_verifiers = state + .conf + .contracts + .verifiers + .clone() + .into_iter() + .map(|x| to_hex(&x)) + .collect::>(); + let mut all_social_verifiers = current_social_verifiers.clone(); + all_social_verifiers.extend(vec![to_hex(&state.conf.contracts.old_verifier)]); + let pipeline = vec![ doc! { "$match": { @@ -79,7 +94,7 @@ pub async fn handler( "field": { "$in": ["0x0000000000000000000000000000000000000000000000000000676974687562", "0x0000000000000000000000000000000000000000000000000074776974746572", "0x00000000000000000000000000000000000000000000000000646973636f7264"] }, - "verifier": { "$in": [ to_hex(&state.conf.contracts.verifier), to_hex(&state.conf.contracts.old_verifier)] } // modified this to accommodate both verifiers + "verifier": { "$in": all_social_verifiers } // modified this to accommodate all social verifiers }, { "field": "0x0000000000000000000000000070726f6f665f6f665f706572736f6e686f6f64", @@ -90,6 +105,11 @@ pub async fn handler( "_cursor.to": null, } }, + doc! { + "$sort": doc! { + "_cursor.from": 1 + } + }, doc! { "$group": { "_id": { "field": "$field", "verifier": "$verifier" }, // group by both field and verifier @@ -98,7 +118,9 @@ pub async fn handler( }, ]; - let starknet_ids_data = state.starknetid_db.collection::("id_verifier_data"); + let starknet_ids_data = state + .starknetid_db + .collection::("id_verifier_data"); let results = starknet_ids_data.aggregate(pipeline, None).await; let mut github = None; @@ -124,7 +146,7 @@ pub async fn handler( ( "0x0000000000000000000000000000000000000000000000000000676974687562", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { github = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string()) @@ -145,7 +167,7 @@ pub async fn handler( ( "0x0000000000000000000000000000000000000000000000000074776974746572", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { twitter = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string()) @@ -166,7 +188,7 @@ pub async fn handler( ( "0x00000000000000000000000000000000000000000000000000646973636f7264", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { discord = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string()) diff --git a/src/endpoints/id_to_data.rs b/src/endpoints/id_to_data.rs index 900c3a3..fe5f1a0 100644 --- a/src/endpoints/id_to_data.rs +++ b/src/endpoints/id_to_data.rs @@ -26,8 +26,12 @@ pub async fn handler( let mut headers = HeaderMap::new(); headers.insert("Cache-Control", HeaderValue::from_static("max-age=30")); - let domains = state.starknetid_db.collection::("domains"); - let starknet_ids = state.starknetid_db.collection::("id_owners"); + let domains = state + .starknetid_db + .collection::("domains"); + let starknet_ids = state + .starknetid_db + .collection::("id_owners"); let hex_id = to_hex(&query.id); @@ -79,6 +83,16 @@ pub async fn handler( return get_error("starknet id not found".to_string()); } + let current_social_verifiers = state + .conf + .contracts + .verifiers + .clone() + .into_iter() + .map(|x| to_hex(&x)) + .collect::>(); + let mut all_social_verifiers = current_social_verifiers.clone(); + all_social_verifiers.extend(vec![to_hex(&state.conf.contracts.old_verifier)]); let owner = owner.unwrap(); let pipeline = vec![ doc! { @@ -88,7 +102,7 @@ pub async fn handler( "field": { "$in": ["0x0000000000000000000000000000000000000000000000000000676974687562", "0x0000000000000000000000000000000000000000000000000074776974746572", "0x00000000000000000000000000000000000000000000000000646973636f7264"] }, - "verifier": { "$in": [ to_hex(&state.conf.contracts.verifier), to_hex(&state.conf.contracts.old_verifier)] } // modified this to accommodate both verifiers + "verifier": { "$in": all_social_verifiers } // modified this to accommodate both verifiers }, { "field": "0x0000000000000000000000000070726f6f665f6f665f706572736f6e686f6f64", @@ -99,6 +113,11 @@ pub async fn handler( "_cursor.to": null, } }, + doc! { + "$sort": doc! { + "_cursor.from": 1 + } + }, doc! { "$group": { "_id": { "field": "$field", "verifier": "$verifier" }, // group by both field and verifier @@ -107,7 +126,9 @@ pub async fn handler( }, ]; - let starknet_ids_data = state.starknetid_db.collection::("id_verifier_data"); + let starknet_ids_data = state + .starknetid_db + .collection::("id_verifier_data"); let results = starknet_ids_data.aggregate(pipeline, None).await; let mut github = None; @@ -137,7 +158,7 @@ pub async fn handler( ( "0x0000000000000000000000000000000000000000000000000000676974687562", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { github = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string()) @@ -158,7 +179,7 @@ pub async fn handler( ( "0x0000000000000000000000000000000000000000000000000074776974746572", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { twitter = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string()) @@ -179,7 +200,7 @@ pub async fn handler( ( "0x00000000000000000000000000000000000000000000000000646973636f7264", verifier, - ) if verifier == to_hex(&state.conf.contracts.verifier) => { + ) if current_social_verifiers.contains(&verifier.to_string()) => { discord = doc.get_str("data").ok().and_then(|data| { FieldElement::from_hex_be(data) .map(|fe| fe.to_string())