From 11c175415dce864ea0967665cc7dbc899b3271dd Mon Sep 17 00:00:00 2001 From: Jonathan Hoyland Date: Mon, 16 Dec 2024 14:13:09 +0000 Subject: [PATCH] Rename transition failure to report error. --- crates/daphne-server/src/router/mod.rs | 4 +- crates/daphne/src/error/aborts.rs | 14 +-- crates/daphne/src/error/mod.rs | 12 +- crates/daphne/src/hpke.rs | 10 +- crates/daphne/src/messages/mod.rs | 146 ++++++++++------------ crates/daphne/src/metrics.rs | 4 +- crates/daphne/src/protocol/aggregator.rs | 26 ++-- crates/daphne/src/protocol/mod.rs | 15 ++- crates/daphne/src/protocol/report_init.rs | 11 +- crates/daphne/src/roles/helper.rs | 10 +- crates/daphne/src/roles/mod.rs | 8 +- 11 files changed, 125 insertions(+), 135 deletions(-) diff --git a/crates/daphne-server/src/router/mod.rs b/crates/daphne-server/src/router/mod.rs index 7362d1dae..b7a1ada13 100644 --- a/crates/daphne-server/src/router/mod.rs +++ b/crates/daphne-server/src/router/mod.rs @@ -160,9 +160,9 @@ impl AxumDapResponse { } pub fn new_error>(error: E, metrics: &dyn DaphneServiceMetrics) -> Self { - // trigger abort if transition failures reach this point. + // Trigger abort if report errors reach this point. let error = match error.into() { - DapError::Transition(failure) => DapAbort::report_rejected(failure), + DapError::ReportError(err) => DapAbort::report_rejected(err), DapError::Fatal(e) => Err(e), DapError::Abort(abort) => Ok(abort), }; diff --git a/crates/daphne/src/error/aborts.rs b/crates/daphne/src/error/aborts.rs index f0bcf81b0..6ffede1c6 100644 --- a/crates/daphne/src/error/aborts.rs +++ b/crates/daphne/src/error/aborts.rs @@ -6,7 +6,7 @@ use crate::{ constants::DapMediaType, fatal_error, - messages::{AggregationJobId, ReportId, TaskId, TransitionFailure}, + messages::{AggregationJobId, ReportError, ReportId, TaskId}, DapError, DapRequestMeta, DapVersion, }; use prio::codec::CodecError; @@ -237,18 +237,16 @@ impl DapAbort { } #[inline] - pub fn report_rejected(failure_reason: TransitionFailure) -> Result { + pub fn report_rejected(failure_reason: ReportError) -> Result { let detail = match failure_reason { - TransitionFailure::BatchCollected => { + ReportError::BatchCollected => { "The report pertains to a batch that has already been collected." } - TransitionFailure::ReportReplayed => { - "A report with the same ID was uploaded previously." - } + ReportError::ReportReplayed => "A report with the same ID was uploaded previously.", _ => { let DapError::Fatal(fatal) = fatal_error!( - err = "Attempted to construct a \"reportRejected\" abort with unexpected transition failure", - unexpected_transition_failure = ?failure_reason, + err = "Attempted to construct a \"reportRejected\" abort with unexpected report error", + unexpected_report_error = ?failure_reason, ) else { unreachable!("fatal_error! should always create a DapError::Fatal"); }; diff --git a/crates/daphne/src/error/mod.rs b/crates/daphne/src/error/mod.rs index 7a63ca308..15c72d676 100644 --- a/crates/daphne/src/error/mod.rs +++ b/crates/daphne/src/error/mod.rs @@ -5,7 +5,7 @@ pub mod aborts; use std::fmt::{Debug, Display}; -use crate::{messages::TransitionFailure, vdaf::VdafError}; +use crate::{messages::ReportError, vdaf::VdafError}; pub use aborts::DapAbort; use prio::codec::CodecError; @@ -25,10 +25,10 @@ pub enum DapError { #[error("abort: {0}")] Abort(#[from] DapAbort), - /// Transition failure. This error blocks processing of a paritcular report and may, under + /// Report Error. This error blocks processing of a paritcular report and may, under /// certain conditions, trigger an abort. - #[error("transition error: {0}")] - Transition(#[from] TransitionFailure), + #[error("report error: {0}")] + ReportError(#[from] ReportError), } impl DapError { @@ -43,12 +43,12 @@ impl DapError { match e { VdafError::CodecDraft09(..) | VdafError::VdafDraft09(..) => { tracing::warn!(error = ?e, "rejecting report"); - Self::Transition(TransitionFailure::VdafPrepError) + Self::ReportError(ReportError::VdafPrepError) } VdafError::Dap(e) => e, VdafError::Codec(..) | VdafError::Vdaf(..) => { tracing::warn!(error = ?e, "rejecting report - latest"); - Self::Transition(TransitionFailure::VdafPrepError) + Self::ReportError(ReportError::VdafPrepError) } } } diff --git a/crates/daphne/src/hpke.rs b/crates/daphne/src/hpke.rs index 3c067a9ad..0c550ab7a 100644 --- a/crates/daphne/src/hpke.rs +++ b/crates/daphne/src/hpke.rs @@ -13,7 +13,7 @@ use hpke_rs_rust_crypto::HpkeRustCrypto as ImplHpkeCrypto; use crate::{ fatal_error, - messages::{HpkeCiphertext, TaskId, TransitionFailure}, + messages::{HpkeCiphertext, ReportError, TaskId}, DapError, DapVersion, }; use async_trait::async_trait; @@ -29,13 +29,13 @@ const AEAD_ID_AES128GCM: u16 = 0x0001; impl From for DapError { fn from(_e: HpkeError) -> Self { - Self::Transition(TransitionFailure::HpkeDecryptError) + Self::ReportError(ReportError::HpkeDecryptError) } } impl From for DapError { fn from(_e: Error) -> Self { - Self::Transition(TransitionFailure::HpkeDecryptError) + Self::ReportError(ReportError::HpkeDecryptError) } } @@ -198,7 +198,7 @@ impl HpkeConfig { ciphertext: &HpkeCiphertext, ) -> Result, DapError> { if self.id != ciphertext.config_id { - return Err(DapError::Transition(TransitionFailure::HpkeUnknownConfigId)); + return Err(DapError::ReportError(ReportError::HpkeUnknownConfigId)); } let receiver: Hpke = check_suite(self.kem_id, self.kdf_id, self.aead_id)?; let mut ctx = receiver.setup_receiver( @@ -303,7 +303,7 @@ where self.clone() .map(|c| c.borrow()) .find(|c| c.config.id == ciphertext.config_id) - .ok_or(DapError::Transition(TransitionFailure::HpkeUnknownConfigId))? + .ok_or(DapError::ReportError(ReportError::HpkeUnknownConfigId))? .decrypt(info, ciphertext) } } diff --git a/crates/daphne/src/messages/mod.rs b/crates/daphne/src/messages/mod.rs index 14b07f19a..a0e2abbf7 100644 --- a/crates/daphne/src/messages/mod.rs +++ b/crates/daphne/src/messages/mod.rs @@ -654,7 +654,7 @@ impl ParameterizedDecode for Transition { #[cfg_attr(any(test, feature = "test-utils"), derive(deepsize::DeepSizeOf))] pub enum TransitionVar { Continued(Vec), - Failed(TransitionFailure), + Failed(ReportError), } impl ParameterizedEncode for TransitionVar { @@ -684,7 +684,7 @@ impl ParameterizedDecode for TransitionVar { ) -> Result { match u8::decode(bytes)? { 0 => Ok(Self::Continued(decode_u32_bytes(bytes)?)), - 2 => Ok(Self::Failed(TransitionFailure::decode_with_param( + 2 => Ok(Self::Failed(ReportError::decode_with_param( version, bytes, )?)), _ => Err(CodecError::UnexpectedValue), @@ -696,7 +696,7 @@ impl ParameterizedDecode for TransitionVar { #[derive(Clone, Copy, Debug, Deserialize, Serialize, PartialEq, Eq, thiserror::Error, Hash)] #[serde(rename_all = "snake_case")] #[cfg_attr(any(test, feature = "test-utils"), derive(deepsize::DeepSizeOf))] -pub enum TransitionFailure { +pub enum ReportError { Reserved, BatchCollected, ReportReplayed, @@ -712,7 +712,7 @@ pub enum TransitionFailure { } #[derive(Clone, Copy)] -enum TransitionFailureDraft09 { +enum ReportErrorDraft09 { BatchCollected = 0, ReportReplayed = 1, ReportDropped = 2, @@ -726,7 +726,7 @@ enum TransitionFailureDraft09 { } #[derive(Clone, Copy)] -enum TransitionFailureLatest { +enum ReportErrorLatest { Reserved = 0, BatchCollected = 1, ReportReplayed = 2, @@ -740,7 +740,7 @@ enum TransitionFailureLatest { TaskNotStarted = 10, } -impl TryFrom for TransitionFailureDraft09 { +impl TryFrom for ReportErrorDraft09 { type Error = CodecError; fn try_from(v: u8) -> Result { @@ -760,7 +760,7 @@ impl TryFrom for TransitionFailureDraft09 { } } -impl TryFrom for TransitionFailureLatest { +impl TryFrom for ReportErrorLatest { type Error = CodecError; fn try_from(v: u8) -> Result { @@ -781,108 +781,100 @@ impl TryFrom for TransitionFailureLatest { } } -impl TryFrom for TransitionFailure { +impl TryFrom for ReportError { type Error = CodecError; - fn try_from(v: TransitionFailureDraft09) -> Result { + fn try_from(v: ReportErrorDraft09) -> Result { match v { - TransitionFailureDraft09::BatchCollected => Ok(TransitionFailure::BatchCollected), - TransitionFailureDraft09::ReportReplayed => Ok(TransitionFailure::ReportReplayed), - TransitionFailureDraft09::ReportDropped => Ok(TransitionFailure::ReportDropped), - TransitionFailureDraft09::HpkeUnknownConfigId => { - Ok(TransitionFailure::HpkeUnknownConfigId) - } - TransitionFailureDraft09::HpkeDecryptError => Ok(TransitionFailure::HpkeDecryptError), - TransitionFailureDraft09::VdafPrepError => Ok(TransitionFailure::VdafPrepError), - TransitionFailureDraft09::BatchSaturated => Ok(TransitionFailure::BatchSaturated), - TransitionFailureDraft09::TaskExpired => Ok(TransitionFailure::TaskExpired), - TransitionFailureDraft09::InvalidMessage => Ok(TransitionFailure::InvalidMessage), - TransitionFailureDraft09::ReportTooEarly => Ok(TransitionFailure::ReportTooEarly), + ReportErrorDraft09::BatchCollected => Ok(ReportError::BatchCollected), + ReportErrorDraft09::ReportReplayed => Ok(ReportError::ReportReplayed), + ReportErrorDraft09::ReportDropped => Ok(ReportError::ReportDropped), + ReportErrorDraft09::HpkeUnknownConfigId => Ok(ReportError::HpkeUnknownConfigId), + ReportErrorDraft09::HpkeDecryptError => Ok(ReportError::HpkeDecryptError), + ReportErrorDraft09::VdafPrepError => Ok(ReportError::VdafPrepError), + ReportErrorDraft09::BatchSaturated => Ok(ReportError::BatchSaturated), + ReportErrorDraft09::TaskExpired => Ok(ReportError::TaskExpired), + ReportErrorDraft09::InvalidMessage => Ok(ReportError::InvalidMessage), + ReportErrorDraft09::ReportTooEarly => Ok(ReportError::ReportTooEarly), } } } -impl TryFrom<&TransitionFailure> for TransitionFailureDraft09 { +impl TryFrom<&ReportError> for ReportErrorDraft09 { type Error = CodecError; - fn try_from(v: &TransitionFailure) -> Result { + fn try_from(v: &ReportError) -> Result { match v { - TransitionFailure::BatchCollected => Ok(TransitionFailureDraft09::BatchCollected), - TransitionFailure::ReportReplayed => Ok(TransitionFailureDraft09::ReportReplayed), - TransitionFailure::ReportDropped => Ok(TransitionFailureDraft09::ReportDropped), - TransitionFailure::HpkeUnknownConfigId => { - Ok(TransitionFailureDraft09::HpkeUnknownConfigId) - } - TransitionFailure::HpkeDecryptError => Ok(TransitionFailureDraft09::HpkeDecryptError), - TransitionFailure::VdafPrepError => Ok(TransitionFailureDraft09::VdafPrepError), - TransitionFailure::BatchSaturated => Ok(TransitionFailureDraft09::BatchSaturated), - TransitionFailure::TaskExpired => Ok(TransitionFailureDraft09::TaskExpired), - TransitionFailure::InvalidMessage => Ok(TransitionFailureDraft09::InvalidMessage), - TransitionFailure::ReportTooEarly => Ok(TransitionFailureDraft09::ReportTooEarly), + ReportError::BatchCollected => Ok(ReportErrorDraft09::BatchCollected), + ReportError::ReportReplayed => Ok(ReportErrorDraft09::ReportReplayed), + ReportError::ReportDropped => Ok(ReportErrorDraft09::ReportDropped), + ReportError::HpkeUnknownConfigId => Ok(ReportErrorDraft09::HpkeUnknownConfigId), + ReportError::HpkeDecryptError => Ok(ReportErrorDraft09::HpkeDecryptError), + ReportError::VdafPrepError => Ok(ReportErrorDraft09::VdafPrepError), + ReportError::BatchSaturated => Ok(ReportErrorDraft09::BatchSaturated), + ReportError::TaskExpired => Ok(ReportErrorDraft09::TaskExpired), + ReportError::InvalidMessage => Ok(ReportErrorDraft09::InvalidMessage), + ReportError::ReportTooEarly => Ok(ReportErrorDraft09::ReportTooEarly), _ => Err(CodecError::UnexpectedValue), } } } -impl TryFrom for TransitionFailure { +impl TryFrom for ReportError { type Error = CodecError; - fn try_from(v: TransitionFailureLatest) -> Result { + fn try_from(v: ReportErrorLatest) -> Result { match v { - TransitionFailureLatest::Reserved => Ok(TransitionFailure::Reserved), - TransitionFailureLatest::BatchCollected => Ok(TransitionFailure::BatchCollected), - TransitionFailureLatest::ReportReplayed => Ok(TransitionFailure::ReportReplayed), - TransitionFailureLatest::ReportDropped => Ok(TransitionFailure::ReportDropped), - TransitionFailureLatest::HpkeUnknownConfigId => { - Ok(TransitionFailure::HpkeUnknownConfigId) - } - TransitionFailureLatest::HpkeDecryptError => Ok(TransitionFailure::HpkeDecryptError), - TransitionFailureLatest::VdafPrepError => Ok(TransitionFailure::VdafPrepError), - TransitionFailureLatest::TaskExpired => Ok(TransitionFailure::TaskExpired), - TransitionFailureLatest::InvalidMessage => Ok(TransitionFailure::InvalidMessage), - TransitionFailureLatest::ReportTooEarly => Ok(TransitionFailure::ReportTooEarly), - TransitionFailureLatest::TaskNotStarted => Ok(TransitionFailure::TaskNotStarted), + ReportErrorLatest::Reserved => Ok(ReportError::Reserved), + ReportErrorLatest::BatchCollected => Ok(ReportError::BatchCollected), + ReportErrorLatest::ReportReplayed => Ok(ReportError::ReportReplayed), + ReportErrorLatest::ReportDropped => Ok(ReportError::ReportDropped), + ReportErrorLatest::HpkeUnknownConfigId => Ok(ReportError::HpkeUnknownConfigId), + ReportErrorLatest::HpkeDecryptError => Ok(ReportError::HpkeDecryptError), + ReportErrorLatest::VdafPrepError => Ok(ReportError::VdafPrepError), + ReportErrorLatest::TaskExpired => Ok(ReportError::TaskExpired), + ReportErrorLatest::InvalidMessage => Ok(ReportError::InvalidMessage), + ReportErrorLatest::ReportTooEarly => Ok(ReportError::ReportTooEarly), + ReportErrorLatest::TaskNotStarted => Ok(ReportError::TaskNotStarted), } } } #[expect(clippy::match_wildcard_for_single_variants)] -impl TryFrom<&TransitionFailure> for TransitionFailureLatest { +impl TryFrom<&ReportError> for ReportErrorLatest { type Error = CodecError; - fn try_from(v: &TransitionFailure) -> Result { + fn try_from(v: &ReportError) -> Result { match v { - TransitionFailure::Reserved => Ok(TransitionFailureLatest::Reserved), - TransitionFailure::BatchCollected => Ok(TransitionFailureLatest::BatchCollected), - TransitionFailure::ReportReplayed => Ok(TransitionFailureLatest::ReportReplayed), - TransitionFailure::ReportDropped => Ok(TransitionFailureLatest::ReportDropped), - TransitionFailure::HpkeUnknownConfigId => { - Ok(TransitionFailureLatest::HpkeUnknownConfigId) - } - TransitionFailure::HpkeDecryptError => Ok(TransitionFailureLatest::HpkeDecryptError), - TransitionFailure::VdafPrepError => Ok(TransitionFailureLatest::VdafPrepError), - TransitionFailure::TaskExpired => Ok(TransitionFailureLatest::TaskExpired), - TransitionFailure::InvalidMessage => Ok(TransitionFailureLatest::InvalidMessage), - TransitionFailure::ReportTooEarly => Ok(TransitionFailureLatest::ReportTooEarly), - TransitionFailure::TaskNotStarted => Ok(TransitionFailureLatest::TaskNotStarted), + ReportError::Reserved => Ok(ReportErrorLatest::Reserved), + ReportError::BatchCollected => Ok(ReportErrorLatest::BatchCollected), + ReportError::ReportReplayed => Ok(ReportErrorLatest::ReportReplayed), + ReportError::ReportDropped => Ok(ReportErrorLatest::ReportDropped), + ReportError::HpkeUnknownConfigId => Ok(ReportErrorLatest::HpkeUnknownConfigId), + ReportError::HpkeDecryptError => Ok(ReportErrorLatest::HpkeDecryptError), + ReportError::VdafPrepError => Ok(ReportErrorLatest::VdafPrepError), + ReportError::TaskExpired => Ok(ReportErrorLatest::TaskExpired), + ReportError::InvalidMessage => Ok(ReportErrorLatest::InvalidMessage), + ReportError::ReportTooEarly => Ok(ReportErrorLatest::ReportTooEarly), + ReportError::TaskNotStarted => Ok(ReportErrorLatest::TaskNotStarted), _ => Err(CodecError::UnexpectedValue), } } } -impl Encode for TransitionFailureDraft09 { +impl Encode for ReportErrorDraft09 { fn encode(&self, bytes: &mut Vec) -> Result<(), CodecError> { (*self as u8).encode(bytes) } } -impl Encode for TransitionFailureLatest { +impl Encode for ReportErrorLatest { fn encode(&self, bytes: &mut Vec) -> Result<(), CodecError> { (*self as u8).encode(bytes) } } -impl ParameterizedEncode for TransitionFailure { +impl ParameterizedEncode for ReportError { fn encode_with_param( &self, version: &DapVersion, @@ -890,42 +882,42 @@ impl ParameterizedEncode for TransitionFailure { ) -> Result<(), CodecError> { match version { DapVersion::Draft09 => { - TransitionFailureDraft09::try_from(self)?.encode(bytes)?; + ReportErrorDraft09::try_from(self)?.encode(bytes)?; Ok(()) } DapVersion::Latest => { - TransitionFailureLatest::try_from(self)?.encode(bytes)?; + ReportErrorLatest::try_from(self)?.encode(bytes)?; Ok(()) } } } } -impl Decode for TransitionFailureDraft09 { +impl Decode for ReportErrorDraft09 { fn decode(bytes: &mut Cursor<&[u8]>) -> Result { u8::decode(bytes)?.try_into() } } -impl Decode for TransitionFailureLatest { +impl Decode for ReportErrorLatest { fn decode(bytes: &mut Cursor<&[u8]>) -> Result { u8::decode(bytes)?.try_into() } } -impl ParameterizedDecode for TransitionFailure { +impl ParameterizedDecode for ReportError { fn decode_with_param( version: &DapVersion, bytes: &mut Cursor<&[u8]>, ) -> Result { match version { - DapVersion::Draft09 => TransitionFailureDraft09::decode(bytes)?.try_into(), - DapVersion::Latest => TransitionFailureLatest::decode(bytes)?.try_into(), + DapVersion::Draft09 => ReportErrorDraft09::decode(bytes)?.try_into(), + DapVersion::Latest => ReportErrorLatest::decode(bytes)?.try_into(), } } } -impl std::fmt::Display for TransitionFailure { +impl std::fmt::Display for ReportError { fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result { match self { Self::Reserved => write!(f, "reserved"), @@ -1831,7 +1823,7 @@ mod test { }, Transition { report_id: ReportId([17; 16]), - var: TransitionVar::Failed(TransitionFailure::TaskExpired), + var: TransitionVar::Failed(ReportError::TaskExpired), }, ], }; diff --git a/crates/daphne/src/metrics.rs b/crates/daphne/src/metrics.rs index 5fbb453d5..298724e40 100644 --- a/crates/daphne/src/metrics.rs +++ b/crates/daphne/src/metrics.rs @@ -3,7 +3,7 @@ //! Daphne metrics. -use crate::messages::TransitionFailure; +use crate::messages::ReportError; use core::fmt; use std::borrow::Cow; @@ -18,7 +18,7 @@ pub trait DaphneMetrics: Send + Sync { #[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)] pub enum ReportStatus { - Rejected(TransitionFailure), + Rejected(ReportError), Aggregated, Collected, } diff --git a/crates/daphne/src/protocol/aggregator.rs b/crates/daphne/src/protocol/aggregator.rs index ace88d5d8..dc21fc315 100644 --- a/crates/daphne/src/protocol/aggregator.rs +++ b/crates/daphne/src/protocol/aggregator.rs @@ -14,8 +14,8 @@ use crate::{ hpke::{info_and_aad, HpkeConfig, HpkeDecrypter}, messages::{ self, encode_u32_bytes, AggregationJobInitReq, AggregationJobResp, Base64Encode, - BatchSelector, HpkeCiphertext, PartialBatchSelector, PrepareInit, Report, ReportId, - ReportShare, TaskId, Transition, TransitionFailure, TransitionVar, + BatchSelector, HpkeCiphertext, PartialBatchSelector, PrepareInit, Report, ReportError, + ReportId, ReportShare, TaskId, Transition, TransitionVar, }, metrics::{DaphneMetrics, ReportStatus}, protocol::{decode_ping_pong_framed, PingPongMessageType}, @@ -43,7 +43,7 @@ pub(crate) enum ReportProcessedStatus { Aggregated, /// The report should be marked as rejected, e.g., because a replay was detected. - Rejected(TransitionFailure), + Rejected(ReportError), } #[derive(Default, Debug, Clone, Copy)] @@ -178,7 +178,10 @@ impl DapTaskConfig { }); } - InitializedReport::Rejected { failure, .. } => { + InitializedReport::Rejected { + report_err: failure, + .. + } => { // Skip report that can't be processed any further. metrics.report_inc_by(ReportStatus::Rejected(failure), 1); continue; @@ -291,7 +294,7 @@ impl DapTaskConfig { for initialized_report in initialized_reports { let status = report_status.get(&initialized_report.metadata().id); let var = match status { - Some(ReportProcessedStatus::Rejected(failure)) => TransitionVar::Failed(*failure), + Some(ReportProcessedStatus::Rejected(err)) => TransitionVar::Failed(*err), Some(ReportProcessedStatus::Aggregated) | None => match initialized_report { InitializedReport::Ready { metadata, @@ -372,7 +375,7 @@ impl DapTaskConfig { | VdafError::Vdaf(..)), ) => { tracing::warn!(error = ?e, "rejecting report"); - TransitionVar::Failed(TransitionFailure::VdafPrepError) + TransitionVar::Failed(ReportError::VdafPrepError) } Err(VdafError::Dap(e)) => return Err(e), @@ -381,8 +384,8 @@ impl DapTaskConfig { InitializedReport::Rejected { metadata: _, - failure, - } => TransitionVar::Failed(*failure), + report_err, + } => TransitionVar::Failed(*report_err), }, }; @@ -449,8 +452,8 @@ impl DapTaskConfig { } // Skip report that can't be processed any further. - TransitionVar::Failed(failure) => { - metrics.report_inc_by(ReportStatus::Rejected(*failure), 1); + TransitionVar::Failed(err) => { + metrics.report_inc_by(ReportStatus::Rejected(*err), 1); continue; } }; @@ -488,8 +491,7 @@ impl DapTaskConfig { | VdafError::Vdaf(..)), ) => { tracing::warn!(error = ?e, "rejecting report"); - metrics - .report_inc_by(ReportStatus::Rejected(TransitionFailure::VdafPrepError), 1); + metrics.report_inc_by(ReportStatus::Rejected(ReportError::VdafPrepError), 1); } Err(VdafError::Dap(e)) => return Err(e), } diff --git a/crates/daphne/src/protocol/mod.rs b/crates/daphne/src/protocol/mod.rs index 6befbe1ad..64eadd55d 100644 --- a/crates/daphne/src/protocol/mod.rs +++ b/crates/daphne/src/protocol/mod.rs @@ -68,8 +68,7 @@ mod test { hpke::{HpkeAeadId, HpkeConfig, HpkeKdfId, HpkeKemId}, messages::{ AggregationJobInitReq, BatchSelector, Extension, Interval, PartialBatchSelector, - PrepareInit, Report, ReportId, ReportShare, Transition, TransitionFailure, - TransitionVar, + PrepareInit, Report, ReportError, ReportId, ReportShare, Transition, TransitionVar, }, test_versions, testing::AggregationJobTest, @@ -491,7 +490,7 @@ mod test { assert_eq!(agg_job_resp.transitions.len(), 1); assert_matches!( agg_job_resp.transitions[0].var, - TransitionVar::Failed(TransitionFailure::HpkeDecryptError) + TransitionVar::Failed(ReportError::HpkeDecryptError) ); } @@ -526,7 +525,7 @@ mod test { assert_eq!(agg_job_resp.transitions.len(), 1); assert_matches!( agg_job_resp.transitions[0].var, - TransitionVar::Failed(TransitionFailure::ReportDropped) + TransitionVar::Failed(ReportError::ReportDropped) ); } @@ -561,7 +560,7 @@ mod test { assert_eq!(agg_job_resp.transitions.len(), 1); assert_matches!( agg_job_resp.transitions[0].var, - TransitionVar::Failed(TransitionFailure::ReportTooEarly) + TransitionVar::Failed(ReportError::ReportTooEarly) ); } @@ -581,7 +580,7 @@ mod test { assert_eq!(agg_job_resp.transitions.len(), 1); assert_matches!( agg_job_resp.transitions[0].var, - TransitionVar::Failed(TransitionFailure::HpkeUnknownConfigId) + TransitionVar::Failed(ReportError::HpkeUnknownConfigId) ); } @@ -622,11 +621,11 @@ mod test { assert_eq!(agg_job_resp.transitions.len(), 2); assert_matches!( agg_job_resp.transitions[0].var, - TransitionVar::Failed(TransitionFailure::VdafPrepError) + TransitionVar::Failed(ReportError::VdafPrepError) ); assert_matches!( agg_job_resp.transitions[1].var, - TransitionVar::Failed(TransitionFailure::VdafPrepError) + TransitionVar::Failed(ReportError::VdafPrepError) ); } diff --git a/crates/daphne/src/protocol/report_init.rs b/crates/daphne/src/protocol/report_init.rs index 377298da2..2749840be 100644 --- a/crates/daphne/src/protocol/report_init.rs +++ b/crates/daphne/src/protocol/report_init.rs @@ -7,8 +7,7 @@ use crate::{ constants::DapAggregatorRole, hpke::{info_and_aad, HpkeDecrypter}, messages::{ - self, Extension, PlaintextInputShare, ReportMetadata, ReportShare, TaskId, - TransitionFailure, + self, Extension, PlaintextInputShare, ReportError, ReportMetadata, ReportShare, TaskId, }, protocol::{decode_ping_pong_framed, no_duplicates, PingPongMessageType}, vdaf::{ @@ -38,7 +37,7 @@ pub enum InitializedReport { }, Rejected { metadata: ReportMetadata, - failure: TransitionFailure, + report_err: ReportError, }, } @@ -114,7 +113,7 @@ impl

InitializedReport

{ ($failure:ident) => { return Ok(InitializedReport::Rejected { metadata: report_share.report_metadata, - failure: TransitionFailure::$failure, + report_err: ReportError::$failure, }) }; } @@ -141,10 +140,10 @@ impl

InitializedReport

{ let encoded_input_share = match decrypter.hpke_decrypt(info, &report_share.encrypted_input_share) { Ok(encoded_input_share) => encoded_input_share, - Err(DapError::Transition(failure)) => { + Err(DapError::ReportError(err)) => { return Ok(InitializedReport::Rejected { metadata: report_share.report_metadata, - failure, + report_err: err, }) } Err(e) => return Err(e), diff --git a/crates/daphne/src/roles/helper.rs b/crates/daphne/src/roles/helper.rs index a5e3ef1e5..39f9998f1 100644 --- a/crates/daphne/src/roles/helper.rs +++ b/crates/daphne/src/roles/helper.rs @@ -12,7 +12,7 @@ use crate::{ error::DapAbort, messages::{ constant_time_eq, AggregateShare, AggregateShareReq, AggregationJobInitReq, - AggregationJobResp, PartialBatchSelector, TaskId, TransitionFailure, TransitionVar, + AggregationJobResp, PartialBatchSelector, ReportError, TaskId, TransitionVar, }, metrics::{DaphneMetrics, DaphneRequestType, ReportStatus}, protocol::{ @@ -256,7 +256,7 @@ async fn finish_agg_job_and_aggregate( report_status.extend(replays.into_iter().map(|report_id| { ( report_id, - ReportProcessedStatus::Rejected(TransitionFailure::ReportReplayed), + ReportProcessedStatus::Rejected(ReportError::ReportReplayed), ) })); inc_restart_metric.call_once(|| metrics.agg_job_put_span_retry_inc()); @@ -266,7 +266,7 @@ async fn finish_agg_job_and_aggregate( report_status.extend(reports.into_iter().map(|(report_id, _)| { ( report_id, - ReportProcessedStatus::Rejected(TransitionFailure::BatchCollected), + ReportProcessedStatus::Rejected(ReportError::BatchCollected), ) })); inc_restart_metric.call_once(|| metrics.agg_job_put_span_retry_inc()); @@ -294,8 +294,8 @@ async fn finish_agg_job_and_aggregate( metrics.report_inc_by(ReportStatus::Aggregated, out_shares_count); for transition in &agg_job_resp.transitions { - if let TransitionVar::Failed(failure) = &transition.var { - metrics.report_inc_by(ReportStatus::Rejected(*failure), 1); + if let TransitionVar::Failed(err) = &transition.var { + metrics.report_inc_by(ReportStatus::Rejected(*err), 1); } } diff --git a/crates/daphne/src/roles/mod.rs b/crates/daphne/src/roles/mod.rs index cb165d893..1b038be73 100644 --- a/crates/daphne/src/roles/mod.rs +++ b/crates/daphne/src/roles/mod.rs @@ -138,8 +138,8 @@ mod test { messages::{ request::RequestBody, AggregateShareReq, AggregationJobId, AggregationJobInitReq, AggregationJobResp, BatchId, BatchSelector, Collection, CollectionJobId, CollectionReq, - Extension, HpkeCiphertext, Interval, PartialBatchSelector, Query, Report, TaskId, Time, - TransitionFailure, TransitionVar, + Extension, HpkeCiphertext, Interval, PartialBatchSelector, Query, Report, ReportError, + TaskId, Time, TransitionVar, }, roles::{leader::WorkItem, DapAggregator}, testing::InMemoryAggregator, @@ -622,7 +622,7 @@ mod test { // assert_eq!(agg_job_resp.transitions.len(), 1); // assert_matches!( // agg_job_resp.transitions[0].var, - // TransitionVar::Failed(TransitionFailure::TaskExpired) + // TransitionVar::Failed(ReportError::TaskExpired) // ); // // assert_eq!(t.helper.audit_log.invocations(), 1); @@ -757,7 +757,7 @@ mod test { // Expect failure due to invalid ciphertext. assert_matches!( transition.var, - TransitionVar::Failed(TransitionFailure::HpkeDecryptError) + TransitionVar::Failed(ReportError::HpkeDecryptError) ); }