From e613a46382afcf49a614c1ba0d89c6249fa990d5 Mon Sep 17 00:00:00 2001 From: jbesraa Date: Thu, 4 Jul 2024 14:28:45 +0300 Subject: [PATCH] Change `payload` fn signature to return Option ..instead of panicking --- .../src/sv2/criterion_sv2_benchmark.rs | 27 ++++++++++--------- benches/benches/src/sv2/iai_sv2_benchmark.rs | 6 ++--- examples/interop-cpp/src/main.rs | 2 +- examples/ping-pong-with-noise/src/node.rs | 4 +-- examples/ping-pong-without-noise/src/node.rs | 4 +-- protocols/v2/framing-sv2/src/framing.rs | 7 +++-- protocols/v2/sv2-ffi/src/lib.rs | 27 ++++++++++--------- roles/jd-client/src/lib/downstream.rs | 4 +-- roles/jd-client/src/lib/job_declarator/mod.rs | 2 +- .../lib/job_declarator/setup_connection.rs | 2 +- .../src/lib/template_receiver/mod.rs | 2 +- .../lib/template_receiver/setup_connection.rs | 2 +- .../src/lib/upstream_sv2/upstream.rs | 9 +++++-- roles/jd-server/src/lib/job_declarator/mod.rs | 10 ++++++- .../mining-proxy/src/lib/downstream_mining.rs | 4 +-- roles/mining-proxy/src/lib/upstream_mining.rs | 6 ++--- roles/pool/src/lib/mining_pool/mod.rs | 5 +++- .../src/lib/mining_pool/setup_connection.rs | 5 +++- roles/pool/src/lib/template_receiver/mod.rs | 8 +++++- .../lib/template_receiver/setup_connection.rs | 5 +++- roles/test-utils/mining-device/src/main.rs | 4 +-- .../src/lib/upstream_sv2/upstream.rs | 7 +++-- utils/message-generator/src/executor.rs | 1 - utils/message-generator/src/main.rs | 4 +-- 24 files changed, 96 insertions(+), 61 deletions(-) diff --git a/benches/benches/src/sv2/criterion_sv2_benchmark.rs b/benches/benches/src/sv2/criterion_sv2_benchmark.rs index 18fab853d..c39126d3d 100644 --- a/benches/benches/src/sv2/criterion_sv2_benchmark.rs +++ b/benches/benches/src/sv2/criterion_sv2_benchmark.rs @@ -53,10 +53,11 @@ fn client_sv2_setup_connection_serialize_deserialize(c: &mut Criterion) { let mut dst = vec![0; size]; let _serialized = frame.serialize(&mut dst); b.iter(|| { - let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); - let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); - let _ = AnyMessage::try_from((type_, payload)).unwrap(); + if let Ok(mut frame) = StdFrame::from_bytes(black_box(dst.clone().into())) { + let msg_type = frame.header().msg_type().clone(); + let payload = frame.payload().unwrap(); + let _ = AnyMessage::try_from((msg_type, payload)).unwrap(); + } }); }); } @@ -94,10 +95,11 @@ fn client_sv2_open_channel_serialize_deserialize(c: &mut Criterion) { let mut dst = vec![0; size]; frame.serialize(&mut dst); b.iter(|| { - let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); - let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); - black_box(AnyMessage::try_from((type_, payload)).unwrap()); + if let Ok(mut frame) = StdFrame::from_bytes(black_box(dst.clone().into())) { + let msg_type = frame.header().msg_type().clone(); + let payload = frame.payload().unwrap(); + black_box(AnyMessage::try_from((msg_type, payload)).unwrap()); + } }); }); } @@ -150,10 +152,11 @@ fn client_sv2_mining_message_submit_standard_serialize_deserialize(c: &mut Crite "client_sv2_mining_message_submit_standard_serialize_deserialize", |b| { b.iter(|| { - let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); - let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); - black_box(AnyMessage::try_from((type_, payload)).unwrap()); + if let Ok(mut frame) = StdFrame::from_bytes(black_box(dst.clone().into())) { + let msg_type = frame.header().msg_type().clone(); + let payload = frame.payload().unwrap(); + black_box(AnyMessage::try_from((msg_type, payload)).unwrap()); + } }); }, ); diff --git a/benches/benches/src/sv2/iai_sv2_benchmark.rs b/benches/benches/src/sv2/iai_sv2_benchmark.rs index b049b9dc4..9965f9f01 100644 --- a/benches/benches/src/sv2/iai_sv2_benchmark.rs +++ b/benches/benches/src/sv2/iai_sv2_benchmark.rs @@ -47,7 +47,7 @@ fn client_sv2_setup_connection_serialize_deserialize() { frame.serialize(&mut dst); let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); + let payload = frame.payload().unwrap(); black_box(AnyMessage::try_from((type_, payload))); } @@ -78,7 +78,7 @@ fn client_sv2_open_channel_serialize_deserialize() { frame.serialize(&mut dst); let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); + let payload = frame.payload().unwrap(); black_box(AnyMessage::try_from((type_, payload))); } @@ -128,7 +128,7 @@ fn client_sv2_mining_message_submit_standard_serialize_deserialize() { frame.serialize(&mut dst); let mut frame = StdFrame::from_bytes(black_box(dst.clone().into())).unwrap(); let type_ = frame.get_header().unwrap().msg_type().clone(); - let payload = frame.payload(); + let payload = frame.payload().unwrap(); black_box(AnyMessage::try_from((type_, payload))); } diff --git a/examples/interop-cpp/src/main.rs b/examples/interop-cpp/src/main.rs index 09950e94b..90fd0e788 100644 --- a/examples/interop-cpp/src/main.rs +++ b/examples/interop-cpp/src/main.rs @@ -127,7 +127,7 @@ mod main_ { stream.read_exact(buffer).unwrap(); if let Ok(mut f) = decoder.next_frame() { let msg_type = f.get_header().unwrap().msg_type(); - let payload = f.payload(); + let payload = f.payload().unwrap(); let message: Sv2Message = (msg_type, payload).try_into().unwrap(); match message { Sv2Message::SetupConnection(_) => panic!(), diff --git a/examples/ping-pong-with-noise/src/node.rs b/examples/ping-pong-with-noise/src/node.rs index 1ae042aa8..f8d1792fd 100644 --- a/examples/ping-pong-with-noise/src/node.rs +++ b/examples/ping-pong-with-noise/src/node.rs @@ -99,7 +99,7 @@ impl Node { ) -> Message<'static> { match self.expected { Expected::Ping => { - let ping: Result = from_bytes(frame.payload()); + let ping: Result = from_bytes(frame.payload().unwrap()); match ping { Ok(ping) => { println!("Node {} received:", self.name); @@ -118,7 +118,7 @@ impl Node { } } Expected::Pong => { - let pong: Result = from_bytes(frame.payload()); + let pong: Result = from_bytes(frame.payload().unwrap()); match pong { Ok(pong) => { println!("Node {} received:", self.name); diff --git a/examples/ping-pong-without-noise/src/node.rs b/examples/ping-pong-without-noise/src/node.rs index 21edf617e..64c9c7415 100644 --- a/examples/ping-pong-without-noise/src/node.rs +++ b/examples/ping-pong-without-noise/src/node.rs @@ -87,7 +87,7 @@ impl Node { ) -> Message<'static> { match self.expected { Expected::Ping => { - let ping: Result = from_bytes(frame.payload()); + let ping: Result = from_bytes(frame.payload().unwrap()); match ping { Ok(ping) => { println!("Node {} received:", self.name); @@ -107,7 +107,7 @@ impl Node { } } Expected::Pong => { - let pong: Result = from_bytes(frame.payload()); + let pong: Result = from_bytes(frame.payload().unwrap()); match pong { Ok(pong) => { println!("Node {} received:", self.name); diff --git a/protocols/v2/framing-sv2/src/framing.rs b/protocols/v2/framing-sv2/src/framing.rs index b96535a6b..af8a22db5 100644 --- a/protocols/v2/framing-sv2/src/framing.rs +++ b/protocols/v2/framing-sv2/src/framing.rs @@ -82,12 +82,11 @@ impl + AsRef<[u8]>> Sv2Frame { /// This function is only intended as a fast way to get a reference to an /// already serialized payload. If the frame has not yet been /// serialized, this function should never be used (it will panic). - pub fn payload(&mut self) -> &mut [u8] { + pub fn payload(&mut self) -> Option<&mut [u8]> { if let Some(serialized) = self.serialized.as_mut() { - &mut serialized.as_mut()[Header::SIZE..] + Some(&mut serialized.as_mut()[Header::SIZE..]) } else { - // panic here is the expected behaviour - panic!("Sv2Frame is not yet serialized.") + None } } diff --git a/protocols/v2/sv2-ffi/src/lib.rs b/protocols/v2/sv2-ffi/src/lib.rs index 9befa0ca7..02a3a2236 100644 --- a/protocols/v2/sv2-ffi/src/lib.rs +++ b/protocols/v2/sv2-ffi/src/lib.rs @@ -469,7 +469,10 @@ pub extern "C" fn next_frame(decoder: *mut DecoderWrapper) -> CResult header.msg_type(), None => return CResult::Err(Sv2Error::InvalidSv2Frame), }; - let payload = f.payload(); + let payload = match f.payload() { + Some(payload) => payload, + None => return CResult::Err(Sv2Error::InvalidSv2Frame), + }; let len = payload.len(); let ptr = payload.as_mut_ptr(); let payload = unsafe { std::slice::from_raw_parts_mut(ptr, len) }; @@ -761,7 +764,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::CoinbaseOutputDataSize(m) => m, @@ -813,7 +816,7 @@ mod tests { // Extract payload of the frame which is the NewTemplate message let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::NewTemplate(m) => m, @@ -861,7 +864,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::RequestTransactionData(m) => m, @@ -911,7 +914,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::RequestTransactionDataError(m) => m, @@ -961,7 +964,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::RequestTransactionDataSuccess(m) => m, @@ -1006,7 +1009,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::SetNewPrevHash(m) => m, @@ -1051,7 +1054,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::SubmitSolution(m) => m, @@ -1109,7 +1112,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::ChannelEndpointChanged(m) => m, @@ -1145,7 +1148,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::SetupConnection(m) => m, @@ -1194,7 +1197,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::SetupConnectionError(m) => m, @@ -1243,7 +1246,7 @@ mod tests { let mut decoded = decoder.next_frame().unwrap(); let msg_type = decoded.get_header().unwrap().msg_type(); - let payload = decoded.payload(); + let payload = decoded.payload().unwrap(); let decoded_message: Sv2Message = (msg_type, payload).try_into().unwrap(); let decoded_message = match decoded_message { Sv2Message::SetupConnectionSuccess(m) => m, diff --git a/roles/jd-client/src/lib/downstream.rs b/roles/jd-client/src/lib/downstream.rs index 92e5a874a..352abcc1b 100644 --- a/roles/jd-client/src/lib/downstream.rs +++ b/roles/jd-client/src/lib/downstream.rs @@ -253,7 +253,7 @@ impl DownstreamMiningNode { /// Parse the received message and relay it to the right upstream pub async fn next(self_mutex: &Arc>, mut incoming: StdFrame) { let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let routing_logic = roles_logic_sv2::routing_logic::MiningRoutingLogic::None; @@ -708,7 +708,7 @@ pub async fn listen_for_downstream_mining( let mut incoming: StdFrame = node.receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let routing_logic = roles_logic_sv2::routing_logic::CommonRoutingLogic::None; let node = Arc::new(Mutex::new(node)); if let Some(upstream) = upstream { diff --git a/roles/jd-client/src/lib/job_declarator/mod.rs b/roles/jd-client/src/lib/job_declarator/mod.rs index 29fb2e4f2..b76e471ee 100644 --- a/roles/jd-client/src/lib/job_declarator/mod.rs +++ b/roles/jd-client/src/lib/job_declarator/mod.rs @@ -293,7 +293,7 @@ impl JobDeclarator { loop { let mut incoming: StdFrame = receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let next_message_to_send = ParseServerJobDeclarationMessages::handle_message_job_declaration( self_mutex.clone(), diff --git a/roles/jd-client/src/lib/job_declarator/setup_connection.rs b/roles/jd-client/src/lib/job_declarator/setup_connection.rs index 0e7b6fd8a..a1ddc613c 100644 --- a/roles/jd-client/src/lib/job_declarator/setup_connection.rs +++ b/roles/jd-client/src/lib/job_declarator/setup_connection.rs @@ -58,7 +58,7 @@ impl SetupConnectionHandler { let mut incoming: StdFrame = receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); ParseUpstreamCommonMessages::handle_message_common( Arc::new(Mutex::new(SetupConnectionHandler {})), message_type, diff --git a/roles/jd-client/src/lib/template_receiver/mod.rs b/roles/jd-client/src/lib/template_receiver/mod.rs index cfc1eec0a..306137bee 100644 --- a/roles/jd-client/src/lib/template_receiver/mod.rs +++ b/roles/jd-client/src/lib/template_receiver/mod.rs @@ -194,7 +194,7 @@ impl TemplateRx { let mut frame: StdFrame = handle_result!(tx_status.clone(), received.try_into()); let message_type = frame.get_header().unwrap().msg_type(); - let payload = frame.payload(); + let payload = frame.payload().expect("No payload set"); let next_message_to_send = ParseServerTemplateDistributionMessages::handle_message_template_distribution( diff --git a/roles/jd-client/src/lib/template_receiver/setup_connection.rs b/roles/jd-client/src/lib/template_receiver/setup_connection.rs index 505b945c3..81fb0166c 100644 --- a/roles/jd-client/src/lib/template_receiver/setup_connection.rs +++ b/roles/jd-client/src/lib/template_receiver/setup_connection.rs @@ -54,7 +54,7 @@ impl SetupConnectionHandler { .try_into() .expect("Failed to parse incoming SetupConnectionResponse"); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); ParseUpstreamCommonMessages::handle_message_common( Arc::new(Mutex::new(SetupConnectionHandler {})), message_type, diff --git a/roles/jd-client/src/lib/upstream_sv2/upstream.rs b/roles/jd-client/src/lib/upstream_sv2/upstream.rs index b04efa335..2228ae9b0 100644 --- a/roles/jd-client/src/lib/upstream_sv2/upstream.rs +++ b/roles/jd-client/src/lib/upstream_sv2/upstream.rs @@ -237,7 +237,12 @@ impl Upstream { return Err(framing_sv2::Error::ExpectedHandshakeFrame.into()); }; // Gets the message payload - let payload = incoming.payload(); + let payload = match incoming.payload() { + Some(payload) => payload, + None => { + return Err(framing_sv2::Error::ExpectedHandshakeFrame.into()); + } + }; // Handle the incoming message (should be either `SetupConnectionSuccess` or // `SetupConnectionError`) @@ -333,7 +338,7 @@ impl Upstream { let message_type = handle_result!(tx_status, message_type).msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().expect("Payload not found"); // Since this is not communicating with an SV2 proxy, but instead a custom SV1 // proxy where the routing logic is handled via the `Upstream`'s communication diff --git a/roles/jd-server/src/lib/job_declarator/mod.rs b/roles/jd-server/src/lib/job_declarator/mod.rs index d1dfcdf05..bbb742bed 100644 --- a/roles/jd-server/src/lib/job_declarator/mod.rs +++ b/roles/jd-server/src/lib/job_declarator/mod.rs @@ -214,7 +214,15 @@ impl JobDeclaratorDownstream { .ok_or_else(|| JdsError::Custom(String::from("No header set"))); let header = handle_result!(tx_status, header); let message_type = header.msg_type(); - let payload = frame.payload(); + let payload = match frame.payload() { + Some(p) => p, + None => { + handle_result!( + tx_status, + Err(JdsError::Custom("No payload set".to_string())) + ) + } + }; let next_message_to_send = ParseClientJobDeclarationMessages::handle_message_job_declaration( self_mutex.clone(), diff --git a/roles/mining-proxy/src/lib/downstream_mining.rs b/roles/mining-proxy/src/lib/downstream_mining.rs index da8901c49..7416f83db 100644 --- a/roles/mining-proxy/src/lib/downstream_mining.rs +++ b/roles/mining-proxy/src/lib/downstream_mining.rs @@ -191,7 +191,7 @@ impl DownstreamMiningNode { /// Parse the received message and relay it to the right upstream pub async fn next(self_mutex: Arc>, mut incoming: StdFrame) { let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let routing_logic = super::get_routing_logic(); @@ -453,7 +453,7 @@ pub async fn listen_for_downstream_mining( let mut incoming: StdFrame = node.receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let routing_logic = super::get_common_routing_logic(); let node = Arc::new(Mutex::new(node)); diff --git a/roles/mining-proxy/src/lib/upstream_mining.rs b/roles/mining-proxy/src/lib/upstream_mining.rs index 5ad012d10..e5db94eb5 100644 --- a/roles/mining-proxy/src/lib/upstream_mining.rs +++ b/roles/mining-proxy/src/lib/upstream_mining.rs @@ -411,7 +411,7 @@ impl UpstreamMiningNode { .unwrap(); let message_type = response.get_header().unwrap().msg_type(); - let payload = response.payload(); + let payload = response.payload().unwrap(); match (message_type, payload).try_into() { Ok(CommonMessages::SetupConnectionSuccess(_)) => { let receiver = self_mutex @@ -576,7 +576,7 @@ impl UpstreamMiningNode { pub async fn next(self_mutex: Arc>, mut incoming: StdFrame) { let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let routing_logic = super::get_routing_logic(); @@ -614,7 +614,7 @@ impl UpstreamMiningNode { .unwrap(); let message_type = response.get_header().unwrap().msg_type(); - let payload = response.payload(); + let payload = response.payload().unwrap(); match (message_type, payload).try_into() { Ok(CommonMessages::SetupConnectionSuccess(m)) => { let receiver = self_mutex diff --git a/roles/pool/src/lib/mining_pool/mod.rs b/roles/pool/src/lib/mining_pool/mod.rs index 0db3f8a5f..395977798 100644 --- a/roles/pool/src/lib/mining_pool/mod.rs +++ b/roles/pool/src/lib/mining_pool/mod.rs @@ -204,7 +204,10 @@ impl Downstream { .get_header() .ok_or_else(|| PoolError::Custom(String::from("No header set")))? .msg_type(); - let payload = incoming.payload(); + let payload = match incoming.payload() { + Some(p) => p, + None => return Err(PoolError::Custom(String::from("No payload set"))), + }; debug!( "Received downstream message type: {:?}, payload: {:?}", message_type, payload diff --git a/roles/pool/src/lib/mining_pool/setup_connection.rs b/roles/pool/src/lib/mining_pool/setup_connection.rs index f0c47e9a8..80babbd57 100644 --- a/roles/pool/src/lib/mining_pool/setup_connection.rs +++ b/roles/pool/src/lib/mining_pool/setup_connection.rs @@ -62,7 +62,10 @@ impl SetupConnectionHandler { .get_header() .ok_or_else(|| PoolError::Custom(String::from("No header set")))? .msg_type(); - let payload = incoming.payload(); + let payload = match incoming.payload() { + Some(p) => p, + None => return Err(PoolError::Custom(String::from("No payload set"))), + }; let response = ParseDownstreamCommonMessages::handle_message_common( self_.clone(), message_type, diff --git a/roles/pool/src/lib/template_receiver/mod.rs b/roles/pool/src/lib/template_receiver/mod.rs index 2eeaa554f..fb3222a3e 100644 --- a/roles/pool/src/lib/template_receiver/mod.rs +++ b/roles/pool/src/lib/template_receiver/mod.rs @@ -112,7 +112,13 @@ impl TemplateRx { .get_header() .ok_or_else(|| PoolError::Custom(String::from("No header set"))); let message_type = handle_result!(status_tx, message_type_res).msg_type(); - let payload = message_from_tp.payload(); + let payload = match message_from_tp.payload() { + Some(p) => p, + None => { + let err = PoolError::Custom(String::from("No payload set")); + handle_result!(status_tx, Err(err)) + } + }; let msg = handle_result!( status_tx, ParseServerTemplateDistributionMessages::handle_message_template_distribution( diff --git a/roles/pool/src/lib/template_receiver/setup_connection.rs b/roles/pool/src/lib/template_receiver/setup_connection.rs index 6687eadc6..684937d78 100644 --- a/roles/pool/src/lib/template_receiver/setup_connection.rs +++ b/roles/pool/src/lib/template_receiver/setup_connection.rs @@ -57,7 +57,10 @@ impl SetupConnectionHandler { .get_header() .ok_or_else(|| PoolError::Custom(String::from("No header set")))? .msg_type(); - let payload = incoming.payload(); + let payload = match incoming.payload() { + Some(p) => p, + None => return Err(PoolError::Custom(String::from("No payload set"))), + }; ParseUpstreamCommonMessages::handle_message_common( Arc::new(Mutex::new(SetupConnectionHandler {})), diff --git a/roles/test-utils/mining-device/src/main.rs b/roles/test-utils/mining-device/src/main.rs index 35a31d56a..86a6900c7 100644 --- a/roles/test-utils/mining-device/src/main.rs +++ b/roles/test-utils/mining-device/src/main.rs @@ -186,7 +186,7 @@ impl SetupConnectionHandler { let mut incoming: StdFrame = receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); ParseUpstreamCommonMessages::handle_message_common( self_, message_type, @@ -316,7 +316,7 @@ impl Device { loop { let mut incoming: StdFrame = receiver.recv().await.unwrap().try_into().unwrap(); let message_type = incoming.get_header().unwrap().msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().unwrap(); let next = Device::handle_message_mining( self_mutex.clone(), message_type, diff --git a/roles/translator/src/lib/upstream_sv2/upstream.rs b/roles/translator/src/lib/upstream_sv2/upstream.rs index 613517432..75cdeacbb 100644 --- a/roles/translator/src/lib/upstream_sv2/upstream.rs +++ b/roles/translator/src/lib/upstream_sv2/upstream.rs @@ -216,7 +216,10 @@ impl Upstream { return Err(framing_sv2::Error::ExpectedHandshakeFrame.into()); }; // Gets the message payload - let payload = incoming.payload(); + let payload = match incoming.payload() { + Some(payload) => payload, + None => return Err(framing_sv2::Error::ExpectedHandshakeFrame.into()), + }; // Handle the incoming message (should be either `SetupConnectionSuccess` or // `SetupConnectionError`) @@ -320,7 +323,7 @@ impl Upstream { let message_type = handle_result!(tx_status, message_type).msg_type(); - let payload = incoming.payload(); + let payload = incoming.payload().expect("Payload is None"); // Since this is not communicating with an SV2 proxy, but instead a custom SV1 // proxy where the routing logic is handled via the `Upstream`'s communication diff --git a/utils/message-generator/src/executor.rs b/utils/message-generator/src/executor.rs index 22843e03a..2e3e306d1 100644 --- a/utils/message-generator/src/executor.rs +++ b/utils/message-generator/src/executor.rs @@ -198,7 +198,6 @@ impl Executor { action.result.len(), result ); - match result { ActionResult::MatchMessageType(message_type) => { let message = match recv.recv().await { diff --git a/utils/message-generator/src/main.rs b/utils/message-generator/src/main.rs index 327d50cbc..dc0ff2a52 100644 --- a/utils/message-generator/src/main.rs +++ b/utils/message-generator/src/main.rs @@ -661,8 +661,8 @@ mod test { (EitherFrame::Sv2(mut frame1), EitherFrame::Sv2(mut frame2)) => { let mt1 = frame1.get_header().unwrap().msg_type(); let mt2 = frame2.get_header().unwrap().msg_type(); - let p1 = frame1.payload(); - let p2 = frame2.payload(); + let p1 = frame1.payload().unwrap(); + let p2 = frame2.payload().unwrap(); let message1: Mining = (mt1, p1).try_into().unwrap(); let message2: Mining = (mt2, p2).try_into().unwrap(); match (message1, message2) {