From b55ebcd8f5b5da80e4dffeac1af698c175379c88 Mon Sep 17 00:00:00 2001 From: Sam Andreae Date: Thu, 7 Sep 2023 15:48:46 +0100 Subject: [PATCH] Encode bytes as hex strings in graphql type conversion --- aquadoggo/src/graphql/utils.rs | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/aquadoggo/src/graphql/utils.rs b/aquadoggo/src/graphql/utils.rs index c9231cace..7f6a6fe8a 100644 --- a/aquadoggo/src/graphql/utils.rs +++ b/aquadoggo/src/graphql/utils.rs @@ -61,7 +61,10 @@ pub fn gql_scalar(operation_value: &OperationValue) -> Value { OperationValue::Float(value) => value.to_owned().into(), OperationValue::Integer(value) => value.to_owned().into(), OperationValue::String(value) => value.to_owned().into(), - OperationValue::Bytes(value) => value.to_owned().into(), + OperationValue::Bytes(value) => { + let hex_string = hex::encode(value); + hex_string.into() + } _ => panic!("This method is not used for relation types"), } } @@ -93,6 +96,11 @@ pub fn filter_to_operation_value( FieldType::Integer => filter_value.i64()?.into(), FieldType::Float => filter_value.f64()?.into(), FieldType::String => filter_value.string()?.into(), + FieldType::Bytes => { + let hex_string = filter_value.string()?; + let bytes = hex::decode(hex_string)?; + bytes[..].into() + } // We are only ever dealing with list items here FieldType::Relation(_) | FieldType::RelationList(_) => { DocumentId::new(&filter_value.string()?.parse()?).into() @@ -101,11 +109,6 @@ pub fn filter_to_operation_value( let document_view_id: DocumentViewId = filter_value.string()?.parse()?; document_view_id.into() } - FieldType::Bytes => { - let hex_string = filter_value.string()?; - let bytes = hex::decode(hex_string)?; - bytes[..].into() - } }; Ok(value)