You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
2.2 KiB
76 lines
2.2 KiB
use crate::network::cbor_request_response::CborCodec;
|
|
use crate::{asb, cli};
|
|
use libp2p::core::ProtocolName;
|
|
use libp2p::request_response::{
|
|
ProtocolSupport, RequestResponse, RequestResponseConfig, RequestResponseEvent,
|
|
RequestResponseMessage,
|
|
};
|
|
use libp2p::PeerId;
|
|
use serde::{Deserialize, Serialize};
|
|
use uuid::Uuid;
|
|
|
|
const PROTOCOL: &str = "/comit/xmr/btc/encrypted_signature/1.0.0";
|
|
type OutEvent = RequestResponseEvent<Request, ()>;
|
|
type Message = RequestResponseMessage<Request, ()>;
|
|
|
|
pub type Behaviour = RequestResponse<CborCodec<EncryptedSignatureProtocol, Request, ()>>;
|
|
|
|
#[derive(Debug, Clone, Copy, Default)]
|
|
pub struct EncryptedSignatureProtocol;
|
|
|
|
impl ProtocolName for EncryptedSignatureProtocol {
|
|
fn protocol_name(&self) -> &[u8] {
|
|
PROTOCOL.as_bytes()
|
|
}
|
|
}
|
|
|
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
pub struct Request {
|
|
pub swap_id: Uuid,
|
|
pub tx_redeem_encsig: crate::bitcoin::EncryptedSignature,
|
|
}
|
|
|
|
pub fn alice() -> Behaviour {
|
|
Behaviour::new(
|
|
CborCodec::default(),
|
|
vec![(EncryptedSignatureProtocol, ProtocolSupport::Inbound)],
|
|
RequestResponseConfig::default(),
|
|
)
|
|
}
|
|
|
|
pub fn bob() -> Behaviour {
|
|
Behaviour::new(
|
|
CborCodec::default(),
|
|
vec![(EncryptedSignatureProtocol, ProtocolSupport::Outbound)],
|
|
RequestResponseConfig::default(),
|
|
)
|
|
}
|
|
|
|
impl From<(PeerId, Message)> for asb::OutEvent {
|
|
fn from((peer, message): (PeerId, Message)) -> Self {
|
|
match message {
|
|
Message::Request {
|
|
request, channel, ..
|
|
} => Self::EncryptedSignatureReceived {
|
|
msg: request,
|
|
channel,
|
|
peer,
|
|
},
|
|
Message::Response { .. } => Self::unexpected_response(peer),
|
|
}
|
|
}
|
|
}
|
|
crate::impl_from_rr_event!(OutEvent, asb::OutEvent, PROTOCOL);
|
|
|
|
impl From<(PeerId, Message)> for cli::OutEvent {
|
|
fn from((peer, message): (PeerId, Message)) -> Self {
|
|
match message {
|
|
Message::Request { .. } => Self::unexpected_request(peer),
|
|
Message::Response { request_id, .. } => {
|
|
Self::EncryptedSignatureAcknowledged { id: request_id }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
crate::impl_from_rr_event!(OutEvent, cli::OutEvent, PROTOCOL);
|