1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
// Copyright 2021 MaidSafe.net limited. // // This SAFE Network Software is licensed to you under the MIT license <LICENSE-MIT // http://opensource.org/licenses/MIT> or the Modified BSD license <LICENSE-BSD // https://opensource.org/licenses/BSD-3-Clause>, at your option. This file may not be copied, // modified, or distributed except according to those terms. Please review the Licences for the // specific language governing permissions and limitations relating to use of the SAFE Network // Software. //! BRB uses Packet and Payload types that are not specific to any network transport //! layer such as tcp/ip. As such, BRB may easily be adapted to work over various //! transports. use serde::{Deserialize, Serialize}; use crate::deterministic_brb; use crate::{Actor, Sig}; /// Represents a logical message packet with a BRB specific payload. #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] pub struct Packet<A: Actor<S>, S: Sig, Op> { /// source actor pub source: A, /// destination actor pub dest: A, /// payload data pub payload: Payload<A, S, Op>, /// signature of payload data by source actor pub sig: S, } /// Enumerates types of BRB data that may be included in a Packet. #[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)] pub enum Payload<A: Actor<S>, S: Sig, DataTypeOp> { /// Represents an AntiEntropy request AntiEntropy { /// last-seen generation generation: brb_membership::Generation, /// delivered clock delivered: crdts::VClock<A>, }, /// Represents a BRB operation BRB(deterministic_brb::Op<A, S, DataTypeOp>), // Box to avoid https://rust-lang.github.io/rust-clippy/master/index.html#large_enum_variant /// Represents a brb_membership Vote Membership(Box<brb_membership::Vote<A, S>>), }