From e56b400f09ea83432f5a79e91df1f35e6629e4d9 Mon Sep 17 00:00:00 2001 From: hopeyen Date: Thu, 2 Nov 2023 22:03:31 +0200 Subject: [PATCH] refactor: utilize QueryError for returning subgraph query errors --- service/src/metrics/mod.rs | 4 +--- service/src/server/routes/subgraphs.rs | 20 +++++++++++--------- 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/service/src/metrics/mod.rs b/service/src/metrics/mod.rs index 2b5c3b77..dfc8d562 100644 --- a/service/src/metrics/mod.rs +++ b/service/src/metrics/mod.rs @@ -6,9 +6,7 @@ use axum::http::StatusCode; use axum::routing::get; use axum::Router; use lazy_static::lazy_static; -use prometheus::{ - register_histogram_vec, register_int_counter_vec, HistogramVec, IntCounterVec, -}; +use prometheus::{register_histogram_vec, register_int_counter_vec, HistogramVec, IntCounterVec}; use std::{net::SocketAddr, str::FromStr}; use tracing::info; diff --git a/service/src/server/routes/subgraphs.rs b/service/src/server/routes/subgraphs.rs index ed641665..ec471964 100644 --- a/service/src/server/routes/subgraphs.rs +++ b/service/src/server/routes/subgraphs.rs @@ -116,32 +116,34 @@ pub async fn subgraph_queries( }; match server.query_processor.execute_paid_query(paid_query).await { - Ok(res) if res.status == 200 => { + Ok(res) => { query_duration_timer.observe_duration(); metrics::SUCCESSFUL_QUERIES .with_label_values(&[&deployment_label]) .inc(); (StatusCode::OK, Json(res.result)).into_response() } - _ => { + Err(e) => { metrics::FAILED_QUERIES .with_label_values(&[&deployment_label]) .inc(); - IndexerError::new( - IndexerErrorCode::IE032, - Some(IndexerErrorCause::new( - "Failed to execute a paid subgraph query to graph node", - )), + let err_msg = format!( + "Failed to execute a paid subgraph query to graph node: {}", + e ); - return bad_request_response("Failed to execute paid query"); + IndexerError::new(IndexerErrorCode::IE032, Some(IndexerErrorCause::new(e))); + return bad_request_response(&err_msg); } } } else { - // TODO: emit IndexerErrorCode::IE030 on missing receipt let error_body = "Query request header missing scalar-receipts or incorrect auth token"; metrics::QUERIES_WITHOUT_RECEIPT .with_label_values(&[&deployment_label]) .inc(); + IndexerError::new( + IndexerErrorCode::IE030, + Some(IndexerErrorCause::new(error_body)), + ); query_duration_timer.observe_duration(); bad_request_response(error_body) }