#![allow(unknown_lints)]
#![allow(clippy::all)]
#![cfg_attr(rustfmt, rustfmt_skip)]
#![allow(box_pointers)]
#![allow(dead_code)]
#![allow(missing_docs)]
#![allow(non_camel_case_types)]
#![allow(non_snake_case)]
#![allow(non_upper_case_globals)]
#![allow(trivial_casts)]
#![allow(unsafe_code)]
#![allow(unused_imports)]
#![allow(unused_results)]
use protobuf::Message as Message_imported_for_functions;
use protobuf::ProtobufEnum as ProtobufEnum_imported_for_functions;
const _PROTOBUF_VERSION_CHECK: () = ::protobuf::VERSION_2_8_1;
#[derive(PartialEq,Clone,Default)]
pub struct ProtocolErrorMessage {
    
    pub signature: ::protobuf::SingularPtrField<super::Cryptography::Signature>,
    pub peer_id: ::protobuf::SingularPtrField<super::Peer::PeerId>,
    pub correlation_id: ::std::vec::Vec<u8>,
    pub code: i32,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a ProtocolErrorMessage {
    fn default() -> &'a ProtocolErrorMessage {
        <ProtocolErrorMessage as ::protobuf::Message>::default_instance()
    }
}
impl ProtocolErrorMessage {
    pub fn new() -> ProtocolErrorMessage {
        ::std::default::Default::default()
    }
    
    pub fn get_signature(&self) -> &super::Cryptography::Signature {
        self.signature.as_ref().unwrap_or_else(|| super::Cryptography::Signature::default_instance())
    }
    pub fn clear_signature(&mut self) {
        self.signature.clear();
    }
    pub fn has_signature(&self) -> bool {
        self.signature.is_some()
    }
    
    pub fn set_signature(&mut self, v: super::Cryptography::Signature) {
        self.signature = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_signature(&mut self) -> &mut super::Cryptography::Signature {
        if self.signature.is_none() {
            self.signature.set_default();
        }
        self.signature.as_mut().unwrap()
    }
    
    pub fn take_signature(&mut self) -> super::Cryptography::Signature {
        self.signature.take().unwrap_or_else(|| super::Cryptography::Signature::new())
    }
    
    pub fn get_peer_id(&self) -> &super::Peer::PeerId {
        self.peer_id.as_ref().unwrap_or_else(|| super::Peer::PeerId::default_instance())
    }
    pub fn clear_peer_id(&mut self) {
        self.peer_id.clear();
    }
    pub fn has_peer_id(&self) -> bool {
        self.peer_id.is_some()
    }
    
    pub fn set_peer_id(&mut self, v: super::Peer::PeerId) {
        self.peer_id = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_peer_id(&mut self) -> &mut super::Peer::PeerId {
        if self.peer_id.is_none() {
            self.peer_id.set_default();
        }
        self.peer_id.as_mut().unwrap()
    }
    
    pub fn take_peer_id(&mut self) -> super::Peer::PeerId {
        self.peer_id.take().unwrap_or_else(|| super::Peer::PeerId::new())
    }
    
    pub fn get_correlation_id(&self) -> &[u8] {
        &self.correlation_id
    }
    pub fn clear_correlation_id(&mut self) {
        self.correlation_id.clear();
    }
    
    pub fn set_correlation_id(&mut self, v: ::std::vec::Vec<u8>) {
        self.correlation_id = v;
    }
    
    
    pub fn mut_correlation_id(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.correlation_id
    }
    
    pub fn take_correlation_id(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.correlation_id, ::std::vec::Vec::new())
    }
    
    pub fn get_code(&self) -> i32 {
        self.code
    }
    pub fn clear_code(&mut self) {
        self.code = 0;
    }
    
    pub fn set_code(&mut self, v: i32) {
        self.code = v;
    }
}
impl ::protobuf::Message for ProtocolErrorMessage {
    fn is_initialized(&self) -> bool {
        for v in &self.signature {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.peer_id {
            if !v.is_initialized() {
                return false;
            }
        };
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.signature)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.peer_id)?;
                },
                3 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.correlation_id)?;
                },
                4 => {
                    if wire_type != ::protobuf::wire_format::WireTypeVarint {
                        return ::std::result::Result::Err(::protobuf::rt::unexpected_wire_type(wire_type));
                    }
                    let tmp = is.read_int32()?;
                    self.code = tmp;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if let Some(ref v) = self.signature.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if let Some(ref v) = self.peer_id.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if !self.correlation_id.is_empty() {
            my_size += ::protobuf::rt::bytes_size(3, &self.correlation_id);
        }
        if self.code != 0 {
            my_size += ::protobuf::rt::value_size(4, self.code, ::protobuf::wire_format::WireTypeVarint);
        }
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if let Some(ref v) = self.signature.as_ref() {
            os.write_tag(1, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if let Some(ref v) = self.peer_id.as_ref() {
            os.write_tag(2, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if !self.correlation_id.is_empty() {
            os.write_bytes(3, &self.correlation_id)?;
        }
        if self.code != 0 {
            os.write_int32(4, self.code)?;
        }
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> ProtocolErrorMessage {
        ProtocolErrorMessage::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Cryptography::Signature>>(
                    "signature",
                    |m: &ProtocolErrorMessage| { &m.signature },
                    |m: &mut ProtocolErrorMessage| { &mut m.signature },
                ));
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Peer::PeerId>>(
                    "peer_id",
                    |m: &ProtocolErrorMessage| { &m.peer_id },
                    |m: &mut ProtocolErrorMessage| { &mut m.peer_id },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "correlation_id",
                    |m: &ProtocolErrorMessage| { &m.correlation_id },
                    |m: &mut ProtocolErrorMessage| { &mut m.correlation_id },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeInt32>(
                    "code",
                    |m: &ProtocolErrorMessage| { &m.code },
                    |m: &mut ProtocolErrorMessage| { &mut m.code },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<ProtocolErrorMessage>(
                    "ProtocolErrorMessage",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static ProtocolErrorMessage {
        static mut instance: ::protobuf::lazy::Lazy<ProtocolErrorMessage> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ProtocolErrorMessage,
        };
        unsafe {
            instance.get(ProtocolErrorMessage::new)
        }
    }
}
impl ::protobuf::Clear for ProtocolErrorMessage {
    fn clear(&mut self) {
        self.signature.clear();
        self.peer_id.clear();
        self.correlation_id.clear();
        self.code = 0;
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for ProtocolErrorMessage {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for ProtocolErrorMessage {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
#[derive(PartialEq,Clone,Default)]
pub struct ProtocolMessage {
    
    pub peer_id: ::protobuf::SingularPtrField<super::Peer::PeerId>,
    pub correlation_id: ::std::vec::Vec<u8>,
    pub type_url: ::std::string::String,
    pub value: ::std::vec::Vec<u8>,
    pub signature: ::protobuf::SingularPtrField<super::Cryptography::Signature>,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a ProtocolMessage {
    fn default() -> &'a ProtocolMessage {
        <ProtocolMessage as ::protobuf::Message>::default_instance()
    }
}
impl ProtocolMessage {
    pub fn new() -> ProtocolMessage {
        ::std::default::Default::default()
    }
    
    pub fn get_peer_id(&self) -> &super::Peer::PeerId {
        self.peer_id.as_ref().unwrap_or_else(|| super::Peer::PeerId::default_instance())
    }
    pub fn clear_peer_id(&mut self) {
        self.peer_id.clear();
    }
    pub fn has_peer_id(&self) -> bool {
        self.peer_id.is_some()
    }
    
    pub fn set_peer_id(&mut self, v: super::Peer::PeerId) {
        self.peer_id = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_peer_id(&mut self) -> &mut super::Peer::PeerId {
        if self.peer_id.is_none() {
            self.peer_id.set_default();
        }
        self.peer_id.as_mut().unwrap()
    }
    
    pub fn take_peer_id(&mut self) -> super::Peer::PeerId {
        self.peer_id.take().unwrap_or_else(|| super::Peer::PeerId::new())
    }
    
    pub fn get_correlation_id(&self) -> &[u8] {
        &self.correlation_id
    }
    pub fn clear_correlation_id(&mut self) {
        self.correlation_id.clear();
    }
    
    pub fn set_correlation_id(&mut self, v: ::std::vec::Vec<u8>) {
        self.correlation_id = v;
    }
    
    
    pub fn mut_correlation_id(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.correlation_id
    }
    
    pub fn take_correlation_id(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.correlation_id, ::std::vec::Vec::new())
    }
    
    pub fn get_type_url(&self) -> &str {
        &self.type_url
    }
    pub fn clear_type_url(&mut self) {
        self.type_url.clear();
    }
    
    pub fn set_type_url(&mut self, v: ::std::string::String) {
        self.type_url = v;
    }
    
    
    pub fn mut_type_url(&mut self) -> &mut ::std::string::String {
        &mut self.type_url
    }
    
    pub fn take_type_url(&mut self) -> ::std::string::String {
        ::std::mem::replace(&mut self.type_url, ::std::string::String::new())
    }
    
    pub fn get_value(&self) -> &[u8] {
        &self.value
    }
    pub fn clear_value(&mut self) {
        self.value.clear();
    }
    
    pub fn set_value(&mut self, v: ::std::vec::Vec<u8>) {
        self.value = v;
    }
    
    
    pub fn mut_value(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.value
    }
    
    pub fn take_value(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.value, ::std::vec::Vec::new())
    }
    
    pub fn get_signature(&self) -> &super::Cryptography::Signature {
        self.signature.as_ref().unwrap_or_else(|| super::Cryptography::Signature::default_instance())
    }
    pub fn clear_signature(&mut self) {
        self.signature.clear();
    }
    pub fn has_signature(&self) -> bool {
        self.signature.is_some()
    }
    
    pub fn set_signature(&mut self, v: super::Cryptography::Signature) {
        self.signature = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_signature(&mut self) -> &mut super::Cryptography::Signature {
        if self.signature.is_none() {
            self.signature.set_default();
        }
        self.signature.as_mut().unwrap()
    }
    
    pub fn take_signature(&mut self) -> super::Cryptography::Signature {
        self.signature.take().unwrap_or_else(|| super::Cryptography::Signature::new())
    }
}
impl ::protobuf::Message for ProtocolMessage {
    fn is_initialized(&self) -> bool {
        for v in &self.peer_id {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.signature {
            if !v.is_initialized() {
                return false;
            }
        };
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.peer_id)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.correlation_id)?;
                },
                3 => {
                    ::protobuf::rt::read_singular_proto3_string_into(wire_type, is, &mut self.type_url)?;
                },
                4 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.value)?;
                },
                5 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.signature)?;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if let Some(ref v) = self.peer_id.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if !self.correlation_id.is_empty() {
            my_size += ::protobuf::rt::bytes_size(2, &self.correlation_id);
        }
        if !self.type_url.is_empty() {
            my_size += ::protobuf::rt::string_size(3, &self.type_url);
        }
        if !self.value.is_empty() {
            my_size += ::protobuf::rt::bytes_size(4, &self.value);
        }
        if let Some(ref v) = self.signature.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if let Some(ref v) = self.peer_id.as_ref() {
            os.write_tag(1, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if !self.correlation_id.is_empty() {
            os.write_bytes(2, &self.correlation_id)?;
        }
        if !self.type_url.is_empty() {
            os.write_string(3, &self.type_url)?;
        }
        if !self.value.is_empty() {
            os.write_bytes(4, &self.value)?;
        }
        if let Some(ref v) = self.signature.as_ref() {
            os.write_tag(5, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> ProtocolMessage {
        ProtocolMessage::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Peer::PeerId>>(
                    "peer_id",
                    |m: &ProtocolMessage| { &m.peer_id },
                    |m: &mut ProtocolMessage| { &mut m.peer_id },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "correlation_id",
                    |m: &ProtocolMessage| { &m.correlation_id },
                    |m: &mut ProtocolMessage| { &mut m.correlation_id },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeString>(
                    "type_url",
                    |m: &ProtocolMessage| { &m.type_url },
                    |m: &mut ProtocolMessage| { &mut m.type_url },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "value",
                    |m: &ProtocolMessage| { &m.value },
                    |m: &mut ProtocolMessage| { &mut m.value },
                ));
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Cryptography::Signature>>(
                    "signature",
                    |m: &ProtocolMessage| { &m.signature },
                    |m: &mut ProtocolMessage| { &mut m.signature },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<ProtocolMessage>(
                    "ProtocolMessage",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static ProtocolMessage {
        static mut instance: ::protobuf::lazy::Lazy<ProtocolMessage> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ProtocolMessage,
        };
        unsafe {
            instance.get(ProtocolMessage::new)
        }
    }
}
impl ::protobuf::Clear for ProtocolMessage {
    fn clear(&mut self) {
        self.peer_id.clear();
        self.correlation_id.clear();
        self.type_url.clear();
        self.value.clear();
        self.signature.clear();
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for ProtocolMessage {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for ProtocolMessage {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
#[derive(PartialEq,Clone,Default)]
pub struct TransactionBroadcast {
    
    pub signature: ::protobuf::SingularPtrField<super::Cryptography::Signature>,
    pub timestamp: ::protobuf::SingularPtrField<::protobuf::well_known_types::Timestamp>,
    pub public_entries: ::protobuf::RepeatedField<super::Transaction::PublicEntry>,
    pub confidential_entries: ::protobuf::RepeatedField<super::Transaction::ConfidentialEntry>,
    pub contract_entries: ::protobuf::RepeatedField<super::Transaction::ContractEntry>,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a TransactionBroadcast {
    fn default() -> &'a TransactionBroadcast {
        <TransactionBroadcast as ::protobuf::Message>::default_instance()
    }
}
impl TransactionBroadcast {
    pub fn new() -> TransactionBroadcast {
        ::std::default::Default::default()
    }
    
    pub fn get_signature(&self) -> &super::Cryptography::Signature {
        self.signature.as_ref().unwrap_or_else(|| super::Cryptography::Signature::default_instance())
    }
    pub fn clear_signature(&mut self) {
        self.signature.clear();
    }
    pub fn has_signature(&self) -> bool {
        self.signature.is_some()
    }
    
    pub fn set_signature(&mut self, v: super::Cryptography::Signature) {
        self.signature = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_signature(&mut self) -> &mut super::Cryptography::Signature {
        if self.signature.is_none() {
            self.signature.set_default();
        }
        self.signature.as_mut().unwrap()
    }
    
    pub fn take_signature(&mut self) -> super::Cryptography::Signature {
        self.signature.take().unwrap_or_else(|| super::Cryptography::Signature::new())
    }
    
    pub fn get_timestamp(&self) -> &::protobuf::well_known_types::Timestamp {
        self.timestamp.as_ref().unwrap_or_else(|| ::protobuf::well_known_types::Timestamp::default_instance())
    }
    pub fn clear_timestamp(&mut self) {
        self.timestamp.clear();
    }
    pub fn has_timestamp(&self) -> bool {
        self.timestamp.is_some()
    }
    
    pub fn set_timestamp(&mut self, v: ::protobuf::well_known_types::Timestamp) {
        self.timestamp = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_timestamp(&mut self) -> &mut ::protobuf::well_known_types::Timestamp {
        if self.timestamp.is_none() {
            self.timestamp.set_default();
        }
        self.timestamp.as_mut().unwrap()
    }
    
    pub fn take_timestamp(&mut self) -> ::protobuf::well_known_types::Timestamp {
        self.timestamp.take().unwrap_or_else(|| ::protobuf::well_known_types::Timestamp::new())
    }
    
    pub fn get_public_entries(&self) -> &[super::Transaction::PublicEntry] {
        &self.public_entries
    }
    pub fn clear_public_entries(&mut self) {
        self.public_entries.clear();
    }
    
    pub fn set_public_entries(&mut self, v: ::protobuf::RepeatedField<super::Transaction::PublicEntry>) {
        self.public_entries = v;
    }
    
    pub fn mut_public_entries(&mut self) -> &mut ::protobuf::RepeatedField<super::Transaction::PublicEntry> {
        &mut self.public_entries
    }
    
    pub fn take_public_entries(&mut self) -> ::protobuf::RepeatedField<super::Transaction::PublicEntry> {
        ::std::mem::replace(&mut self.public_entries, ::protobuf::RepeatedField::new())
    }
    
    pub fn get_confidential_entries(&self) -> &[super::Transaction::ConfidentialEntry] {
        &self.confidential_entries
    }
    pub fn clear_confidential_entries(&mut self) {
        self.confidential_entries.clear();
    }
    
    pub fn set_confidential_entries(&mut self, v: ::protobuf::RepeatedField<super::Transaction::ConfidentialEntry>) {
        self.confidential_entries = v;
    }
    
    pub fn mut_confidential_entries(&mut self) -> &mut ::protobuf::RepeatedField<super::Transaction::ConfidentialEntry> {
        &mut self.confidential_entries
    }
    
    pub fn take_confidential_entries(&mut self) -> ::protobuf::RepeatedField<super::Transaction::ConfidentialEntry> {
        ::std::mem::replace(&mut self.confidential_entries, ::protobuf::RepeatedField::new())
    }
    
    pub fn get_contract_entries(&self) -> &[super::Transaction::ContractEntry] {
        &self.contract_entries
    }
    pub fn clear_contract_entries(&mut self) {
        self.contract_entries.clear();
    }
    
    pub fn set_contract_entries(&mut self, v: ::protobuf::RepeatedField<super::Transaction::ContractEntry>) {
        self.contract_entries = v;
    }
    
    pub fn mut_contract_entries(&mut self) -> &mut ::protobuf::RepeatedField<super::Transaction::ContractEntry> {
        &mut self.contract_entries
    }
    
    pub fn take_contract_entries(&mut self) -> ::protobuf::RepeatedField<super::Transaction::ContractEntry> {
        ::std::mem::replace(&mut self.contract_entries, ::protobuf::RepeatedField::new())
    }
}
impl ::protobuf::Message for TransactionBroadcast {
    fn is_initialized(&self) -> bool {
        for v in &self.signature {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.timestamp {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.public_entries {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.confidential_entries {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.contract_entries {
            if !v.is_initialized() {
                return false;
            }
        };
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.signature)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.timestamp)?;
                },
                3 => {
                    ::protobuf::rt::read_repeated_message_into(wire_type, is, &mut self.public_entries)?;
                },
                4 => {
                    ::protobuf::rt::read_repeated_message_into(wire_type, is, &mut self.confidential_entries)?;
                },
                5 => {
                    ::protobuf::rt::read_repeated_message_into(wire_type, is, &mut self.contract_entries)?;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if let Some(ref v) = self.signature.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if let Some(ref v) = self.timestamp.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        for value in &self.public_entries {
            let len = value.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        };
        for value in &self.confidential_entries {
            let len = value.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        };
        for value in &self.contract_entries {
            let len = value.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        };
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if let Some(ref v) = self.signature.as_ref() {
            os.write_tag(1, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if let Some(ref v) = self.timestamp.as_ref() {
            os.write_tag(2, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        for v in &self.public_entries {
            os.write_tag(3, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        };
        for v in &self.confidential_entries {
            os.write_tag(4, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        };
        for v in &self.contract_entries {
            os.write_tag(5, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        };
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> TransactionBroadcast {
        TransactionBroadcast::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Cryptography::Signature>>(
                    "signature",
                    |m: &TransactionBroadcast| { &m.signature },
                    |m: &mut TransactionBroadcast| { &mut m.signature },
                ));
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<::protobuf::well_known_types::Timestamp>>(
                    "timestamp",
                    |m: &TransactionBroadcast| { &m.timestamp },
                    |m: &mut TransactionBroadcast| { &mut m.timestamp },
                ));
                fields.push(::protobuf::reflect::accessor::make_repeated_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Transaction::PublicEntry>>(
                    "public_entries",
                    |m: &TransactionBroadcast| { &m.public_entries },
                    |m: &mut TransactionBroadcast| { &mut m.public_entries },
                ));
                fields.push(::protobuf::reflect::accessor::make_repeated_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Transaction::ConfidentialEntry>>(
                    "confidential_entries",
                    |m: &TransactionBroadcast| { &m.confidential_entries },
                    |m: &mut TransactionBroadcast| { &mut m.confidential_entries },
                ));
                fields.push(::protobuf::reflect::accessor::make_repeated_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Transaction::ContractEntry>>(
                    "contract_entries",
                    |m: &TransactionBroadcast| { &m.contract_entries },
                    |m: &mut TransactionBroadcast| { &mut m.contract_entries },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<TransactionBroadcast>(
                    "TransactionBroadcast",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static TransactionBroadcast {
        static mut instance: ::protobuf::lazy::Lazy<TransactionBroadcast> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const TransactionBroadcast,
        };
        unsafe {
            instance.get(TransactionBroadcast::new)
        }
    }
}
impl ::protobuf::Clear for TransactionBroadcast {
    fn clear(&mut self) {
        self.signature.clear();
        self.timestamp.clear();
        self.public_entries.clear();
        self.confidential_entries.clear();
        self.contract_entries.clear();
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for TransactionBroadcast {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for TransactionBroadcast {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
#[derive(PartialEq,Clone,Default)]
pub struct CandidateDeltaBroadcast {
    
    pub hash: ::std::vec::Vec<u8>,
    pub producer_id: ::protobuf::SingularPtrField<super::Peer::PeerId>,
    pub previous_delta_dfs_hash: ::std::vec::Vec<u8>,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a CandidateDeltaBroadcast {
    fn default() -> &'a CandidateDeltaBroadcast {
        <CandidateDeltaBroadcast as ::protobuf::Message>::default_instance()
    }
}
impl CandidateDeltaBroadcast {
    pub fn new() -> CandidateDeltaBroadcast {
        ::std::default::Default::default()
    }
    
    pub fn get_hash(&self) -> &[u8] {
        &self.hash
    }
    pub fn clear_hash(&mut self) {
        self.hash.clear();
    }
    
    pub fn set_hash(&mut self, v: ::std::vec::Vec<u8>) {
        self.hash = v;
    }
    
    
    pub fn mut_hash(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.hash
    }
    
    pub fn take_hash(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.hash, ::std::vec::Vec::new())
    }
    
    pub fn get_producer_id(&self) -> &super::Peer::PeerId {
        self.producer_id.as_ref().unwrap_or_else(|| super::Peer::PeerId::default_instance())
    }
    pub fn clear_producer_id(&mut self) {
        self.producer_id.clear();
    }
    pub fn has_producer_id(&self) -> bool {
        self.producer_id.is_some()
    }
    
    pub fn set_producer_id(&mut self, v: super::Peer::PeerId) {
        self.producer_id = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_producer_id(&mut self) -> &mut super::Peer::PeerId {
        if self.producer_id.is_none() {
            self.producer_id.set_default();
        }
        self.producer_id.as_mut().unwrap()
    }
    
    pub fn take_producer_id(&mut self) -> super::Peer::PeerId {
        self.producer_id.take().unwrap_or_else(|| super::Peer::PeerId::new())
    }
    
    pub fn get_previous_delta_dfs_hash(&self) -> &[u8] {
        &self.previous_delta_dfs_hash
    }
    pub fn clear_previous_delta_dfs_hash(&mut self) {
        self.previous_delta_dfs_hash.clear();
    }
    
    pub fn set_previous_delta_dfs_hash(&mut self, v: ::std::vec::Vec<u8>) {
        self.previous_delta_dfs_hash = v;
    }
    
    
    pub fn mut_previous_delta_dfs_hash(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.previous_delta_dfs_hash
    }
    
    pub fn take_previous_delta_dfs_hash(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.previous_delta_dfs_hash, ::std::vec::Vec::new())
    }
}
impl ::protobuf::Message for CandidateDeltaBroadcast {
    fn is_initialized(&self) -> bool {
        for v in &self.producer_id {
            if !v.is_initialized() {
                return false;
            }
        };
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.hash)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.producer_id)?;
                },
                3 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.previous_delta_dfs_hash)?;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if !self.hash.is_empty() {
            my_size += ::protobuf::rt::bytes_size(1, &self.hash);
        }
        if let Some(ref v) = self.producer_id.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if !self.previous_delta_dfs_hash.is_empty() {
            my_size += ::protobuf::rt::bytes_size(3, &self.previous_delta_dfs_hash);
        }
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if !self.hash.is_empty() {
            os.write_bytes(1, &self.hash)?;
        }
        if let Some(ref v) = self.producer_id.as_ref() {
            os.write_tag(2, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if !self.previous_delta_dfs_hash.is_empty() {
            os.write_bytes(3, &self.previous_delta_dfs_hash)?;
        }
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> CandidateDeltaBroadcast {
        CandidateDeltaBroadcast::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "hash",
                    |m: &CandidateDeltaBroadcast| { &m.hash },
                    |m: &mut CandidateDeltaBroadcast| { &mut m.hash },
                ));
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Peer::PeerId>>(
                    "producer_id",
                    |m: &CandidateDeltaBroadcast| { &m.producer_id },
                    |m: &mut CandidateDeltaBroadcast| { &mut m.producer_id },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "previous_delta_dfs_hash",
                    |m: &CandidateDeltaBroadcast| { &m.previous_delta_dfs_hash },
                    |m: &mut CandidateDeltaBroadcast| { &mut m.previous_delta_dfs_hash },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<CandidateDeltaBroadcast>(
                    "CandidateDeltaBroadcast",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static CandidateDeltaBroadcast {
        static mut instance: ::protobuf::lazy::Lazy<CandidateDeltaBroadcast> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const CandidateDeltaBroadcast,
        };
        unsafe {
            instance.get(CandidateDeltaBroadcast::new)
        }
    }
}
impl ::protobuf::Clear for CandidateDeltaBroadcast {
    fn clear(&mut self) {
        self.hash.clear();
        self.producer_id.clear();
        self.previous_delta_dfs_hash.clear();
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for CandidateDeltaBroadcast {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for CandidateDeltaBroadcast {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
#[derive(PartialEq,Clone,Default)]
pub struct FavouriteDeltaBroadcast {
    
    pub candidate: ::protobuf::SingularPtrField<CandidateDeltaBroadcast>,
    pub voter_id: ::protobuf::SingularPtrField<super::Peer::PeerId>,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a FavouriteDeltaBroadcast {
    fn default() -> &'a FavouriteDeltaBroadcast {
        <FavouriteDeltaBroadcast as ::protobuf::Message>::default_instance()
    }
}
impl FavouriteDeltaBroadcast {
    pub fn new() -> FavouriteDeltaBroadcast {
        ::std::default::Default::default()
    }
    
    pub fn get_candidate(&self) -> &CandidateDeltaBroadcast {
        self.candidate.as_ref().unwrap_or_else(|| CandidateDeltaBroadcast::default_instance())
    }
    pub fn clear_candidate(&mut self) {
        self.candidate.clear();
    }
    pub fn has_candidate(&self) -> bool {
        self.candidate.is_some()
    }
    
    pub fn set_candidate(&mut self, v: CandidateDeltaBroadcast) {
        self.candidate = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_candidate(&mut self) -> &mut CandidateDeltaBroadcast {
        if self.candidate.is_none() {
            self.candidate.set_default();
        }
        self.candidate.as_mut().unwrap()
    }
    
    pub fn take_candidate(&mut self) -> CandidateDeltaBroadcast {
        self.candidate.take().unwrap_or_else(|| CandidateDeltaBroadcast::new())
    }
    
    pub fn get_voter_id(&self) -> &super::Peer::PeerId {
        self.voter_id.as_ref().unwrap_or_else(|| super::Peer::PeerId::default_instance())
    }
    pub fn clear_voter_id(&mut self) {
        self.voter_id.clear();
    }
    pub fn has_voter_id(&self) -> bool {
        self.voter_id.is_some()
    }
    
    pub fn set_voter_id(&mut self, v: super::Peer::PeerId) {
        self.voter_id = ::protobuf::SingularPtrField::some(v);
    }
    
    
    pub fn mut_voter_id(&mut self) -> &mut super::Peer::PeerId {
        if self.voter_id.is_none() {
            self.voter_id.set_default();
        }
        self.voter_id.as_mut().unwrap()
    }
    
    pub fn take_voter_id(&mut self) -> super::Peer::PeerId {
        self.voter_id.take().unwrap_or_else(|| super::Peer::PeerId::new())
    }
}
impl ::protobuf::Message for FavouriteDeltaBroadcast {
    fn is_initialized(&self) -> bool {
        for v in &self.candidate {
            if !v.is_initialized() {
                return false;
            }
        };
        for v in &self.voter_id {
            if !v.is_initialized() {
                return false;
            }
        };
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.candidate)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_message_into(wire_type, is, &mut self.voter_id)?;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if let Some(ref v) = self.candidate.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        if let Some(ref v) = self.voter_id.as_ref() {
            let len = v.compute_size();
            my_size += 1 + ::protobuf::rt::compute_raw_varint32_size(len) + len;
        }
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if let Some(ref v) = self.candidate.as_ref() {
            os.write_tag(1, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        if let Some(ref v) = self.voter_id.as_ref() {
            os.write_tag(2, ::protobuf::wire_format::WireTypeLengthDelimited)?;
            os.write_raw_varint32(v.get_cached_size())?;
            v.write_to_with_cached_sizes(os)?;
        }
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> FavouriteDeltaBroadcast {
        FavouriteDeltaBroadcast::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<CandidateDeltaBroadcast>>(
                    "candidate",
                    |m: &FavouriteDeltaBroadcast| { &m.candidate },
                    |m: &mut FavouriteDeltaBroadcast| { &mut m.candidate },
                ));
                fields.push(::protobuf::reflect::accessor::make_singular_ptr_field_accessor::<_, ::protobuf::types::ProtobufTypeMessage<super::Peer::PeerId>>(
                    "voter_id",
                    |m: &FavouriteDeltaBroadcast| { &m.voter_id },
                    |m: &mut FavouriteDeltaBroadcast| { &mut m.voter_id },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<FavouriteDeltaBroadcast>(
                    "FavouriteDeltaBroadcast",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static FavouriteDeltaBroadcast {
        static mut instance: ::protobuf::lazy::Lazy<FavouriteDeltaBroadcast> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const FavouriteDeltaBroadcast,
        };
        unsafe {
            instance.get(FavouriteDeltaBroadcast::new)
        }
    }
}
impl ::protobuf::Clear for FavouriteDeltaBroadcast {
    fn clear(&mut self) {
        self.candidate.clear();
        self.voter_id.clear();
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for FavouriteDeltaBroadcast {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for FavouriteDeltaBroadcast {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
#[derive(PartialEq,Clone,Default)]
pub struct DeltaDfsHashBroadcast {
    
    pub delta_dfs_hash: ::std::vec::Vec<u8>,
    pub previous_delta_dfs_hash: ::std::vec::Vec<u8>,
    
    pub unknown_fields: ::protobuf::UnknownFields,
    pub cached_size: ::protobuf::CachedSize,
}
impl<'a> ::std::default::Default for &'a DeltaDfsHashBroadcast {
    fn default() -> &'a DeltaDfsHashBroadcast {
        <DeltaDfsHashBroadcast as ::protobuf::Message>::default_instance()
    }
}
impl DeltaDfsHashBroadcast {
    pub fn new() -> DeltaDfsHashBroadcast {
        ::std::default::Default::default()
    }
    
    pub fn get_delta_dfs_hash(&self) -> &[u8] {
        &self.delta_dfs_hash
    }
    pub fn clear_delta_dfs_hash(&mut self) {
        self.delta_dfs_hash.clear();
    }
    
    pub fn set_delta_dfs_hash(&mut self, v: ::std::vec::Vec<u8>) {
        self.delta_dfs_hash = v;
    }
    
    
    pub fn mut_delta_dfs_hash(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.delta_dfs_hash
    }
    
    pub fn take_delta_dfs_hash(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.delta_dfs_hash, ::std::vec::Vec::new())
    }
    
    pub fn get_previous_delta_dfs_hash(&self) -> &[u8] {
        &self.previous_delta_dfs_hash
    }
    pub fn clear_previous_delta_dfs_hash(&mut self) {
        self.previous_delta_dfs_hash.clear();
    }
    
    pub fn set_previous_delta_dfs_hash(&mut self, v: ::std::vec::Vec<u8>) {
        self.previous_delta_dfs_hash = v;
    }
    
    
    pub fn mut_previous_delta_dfs_hash(&mut self) -> &mut ::std::vec::Vec<u8> {
        &mut self.previous_delta_dfs_hash
    }
    
    pub fn take_previous_delta_dfs_hash(&mut self) -> ::std::vec::Vec<u8> {
        ::std::mem::replace(&mut self.previous_delta_dfs_hash, ::std::vec::Vec::new())
    }
}
impl ::protobuf::Message for DeltaDfsHashBroadcast {
    fn is_initialized(&self) -> bool {
        true
    }
    fn merge_from(&mut self, is: &mut ::protobuf::CodedInputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        while !is.eof()? {
            let (field_number, wire_type) = is.read_tag_unpack()?;
            match field_number {
                1 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.delta_dfs_hash)?;
                },
                2 => {
                    ::protobuf::rt::read_singular_proto3_bytes_into(wire_type, is, &mut self.previous_delta_dfs_hash)?;
                },
                _ => {
                    ::protobuf::rt::read_unknown_or_skip_group(field_number, wire_type, is, self.mut_unknown_fields())?;
                },
            };
        }
        ::std::result::Result::Ok(())
    }
    
    #[allow(unused_variables)]
    fn compute_size(&self) -> u32 {
        let mut my_size = 0;
        if !self.delta_dfs_hash.is_empty() {
            my_size += ::protobuf::rt::bytes_size(1, &self.delta_dfs_hash);
        }
        if !self.previous_delta_dfs_hash.is_empty() {
            my_size += ::protobuf::rt::bytes_size(2, &self.previous_delta_dfs_hash);
        }
        my_size += ::protobuf::rt::unknown_fields_size(self.get_unknown_fields());
        self.cached_size.set(my_size);
        my_size
    }
    fn write_to_with_cached_sizes(&self, os: &mut ::protobuf::CodedOutputStream<'_>) -> ::protobuf::ProtobufResult<()> {
        if !self.delta_dfs_hash.is_empty() {
            os.write_bytes(1, &self.delta_dfs_hash)?;
        }
        if !self.previous_delta_dfs_hash.is_empty() {
            os.write_bytes(2, &self.previous_delta_dfs_hash)?;
        }
        os.write_unknown_fields(self.get_unknown_fields())?;
        ::std::result::Result::Ok(())
    }
    fn get_cached_size(&self) -> u32 {
        self.cached_size.get()
    }
    fn get_unknown_fields(&self) -> &::protobuf::UnknownFields {
        &self.unknown_fields
    }
    fn mut_unknown_fields(&mut self) -> &mut ::protobuf::UnknownFields {
        &mut self.unknown_fields
    }
    fn as_any(&self) -> &dyn (::std::any::Any) {
        self as &dyn (::std::any::Any)
    }
    fn as_any_mut(&mut self) -> &mut dyn (::std::any::Any) {
        self as &mut dyn (::std::any::Any)
    }
    fn into_any(self: Box<Self>) -> ::std::boxed::Box<dyn (::std::any::Any)> {
        self
    }
    fn descriptor(&self) -> &'static ::protobuf::reflect::MessageDescriptor {
        Self::descriptor_static()
    }
    fn new() -> DeltaDfsHashBroadcast {
        DeltaDfsHashBroadcast::new()
    }
    fn descriptor_static() -> &'static ::protobuf::reflect::MessageDescriptor {
        static mut descriptor: ::protobuf::lazy::Lazy<::protobuf::reflect::MessageDescriptor> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const ::protobuf::reflect::MessageDescriptor,
        };
        unsafe {
            descriptor.get(|| {
                let mut fields = ::std::vec::Vec::new();
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "delta_dfs_hash",
                    |m: &DeltaDfsHashBroadcast| { &m.delta_dfs_hash },
                    |m: &mut DeltaDfsHashBroadcast| { &mut m.delta_dfs_hash },
                ));
                fields.push(::protobuf::reflect::accessor::make_simple_field_accessor::<_, ::protobuf::types::ProtobufTypeBytes>(
                    "previous_delta_dfs_hash",
                    |m: &DeltaDfsHashBroadcast| { &m.previous_delta_dfs_hash },
                    |m: &mut DeltaDfsHashBroadcast| { &mut m.previous_delta_dfs_hash },
                ));
                ::protobuf::reflect::MessageDescriptor::new::<DeltaDfsHashBroadcast>(
                    "DeltaDfsHashBroadcast",
                    fields,
                    file_descriptor_proto()
                )
            })
        }
    }
    fn default_instance() -> &'static DeltaDfsHashBroadcast {
        static mut instance: ::protobuf::lazy::Lazy<DeltaDfsHashBroadcast> = ::protobuf::lazy::Lazy {
            lock: ::protobuf::lazy::ONCE_INIT,
            ptr: 0 as *const DeltaDfsHashBroadcast,
        };
        unsafe {
            instance.get(DeltaDfsHashBroadcast::new)
        }
    }
}
impl ::protobuf::Clear for DeltaDfsHashBroadcast {
    fn clear(&mut self) {
        self.delta_dfs_hash.clear();
        self.previous_delta_dfs_hash.clear();
        self.unknown_fields.clear();
    }
}
impl ::std::fmt::Debug for DeltaDfsHashBroadcast {
    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
        ::protobuf::text_format::fmt(self, f)
    }
}
impl ::protobuf::reflect::ProtobufValue for DeltaDfsHashBroadcast {
    fn as_ref(&self) -> ::protobuf::reflect::ProtobufValueRef {
        ::protobuf::reflect::ProtobufValueRef::Message(self)
    }
}
static file_descriptor_proto_data: &'static [u8] = b"\
    \n\nWire.proto\x12\x16Catalyst.Protocol.Wire\x1a\x12Cryptography.proto\
    \x1a\nPeer.proto\x1a\x11Transaction.proto\x1a\x1fgoogle/protobuf/timesta\
    mp.proto\"\xd3\x01\n\x14ProtocolErrorMessage\x12G\n\tsignature\x18\x01\
    \x20\x01(\x0b2).Catalyst.Protocol.Cryptography.SignatureR\tsignature\x12\
    7\n\x07peer_id\x18\x02\x20\x01(\x0b2\x1e.Catalyst.Protocol.Peer.PeerIdR\
    \x06peerId\x12%\n\x0ecorrelation_id\x18\x03\x20\x01(\x0cR\rcorrelationId\
    \x12\x12\n\x04code\x18\x04\x20\x01(\x05R\x04code\"\xeb\x01\n\x0fProtocol\
    Message\x127\n\x07peer_id\x18\x01\x20\x01(\x0b2\x1e.Catalyst.Protocol.Pe\
    er.PeerIdR\x06peerId\x12%\n\x0ecorrelation_id\x18\x02\x20\x01(\x0cR\rcor\
    relationId\x12\x19\n\x08type_url\x18\x03\x20\x01(\tR\x07typeUrl\x12\x14\
    \n\x05value\x18\x04\x20\x01(\x0cR\x05value\x12G\n\tsignature\x18\x05\x20\
    \x01(\x0b2).Catalyst.Protocol.Cryptography.SignatureR\tsignature\"\xaa\
    \x03\n\x14TransactionBroadcast\x12G\n\tsignature\x18\x01\x20\x01(\x0b2).\
    Catalyst.Protocol.Cryptography.SignatureR\tsignature\x128\n\ttimestamp\
    \x18\x02\x20\x01(\x0b2\x1a.google.protobuf.TimestampR\ttimestamp\x12Q\n\
    \x0epublic_entries\x18\x03\x20\x03(\x0b2*.Catalyst.Protocol.Transaction.\
    PublicEntryR\rpublicEntries\x12c\n\x14confidential_entries\x18\x04\x20\
    \x03(\x0b20.Catalyst.Protocol.Transaction.ConfidentialEntryR\x13confiden\
    tialEntries\x12W\n\x10contract_entries\x18\x05\x20\x03(\x0b2,.Catalyst.P\
    rotocol.Transaction.ContractEntryR\x0fcontractEntries\"\xa5\x01\n\x17Can\
    didateDeltaBroadcast\x12\x12\n\x04hash\x18\x01\x20\x01(\x0cR\x04hash\x12\
    ?\n\x0bproducer_id\x18\x02\x20\x01(\x0b2\x1e.Catalyst.Protocol.Peer.Peer\
    IdR\nproducerId\x125\n\x17previous_delta_dfs_hash\x18\x03\x20\x01(\x0cR\
    \x14previousDeltaDfsHash\"\xa3\x01\n\x17FavouriteDeltaBroadcast\x12M\n\t\
    candidate\x18\x01\x20\x01(\x0b2/.Catalyst.Protocol.Wire.CandidateDeltaBr\
    oadcastR\tcandidate\x129\n\x08voter_id\x18\x02\x20\x01(\x0b2\x1e.Catalys\
    t.Protocol.Peer.PeerIdR\x07voterId\"t\n\x15DeltaDfsHashBroadcast\x12$\n\
    \x0edelta_dfs_hash\x18\x01\x20\x01(\x0cR\x0cdeltaDfsHash\x125\n\x17previ\
    ous_delta_dfs_hash\x18\x02\x20\x01(\x0cR\x14previousDeltaDfsHashB\x02P\
    \x01J\xf5\x1b\n\x06\x12\x04\x13\0I\x01\n\xdf\x06\n\x01\x0c\x12\x03\x13\0\
    \x122\xd4\x06*\n\x20Copyright\x20(c)\x202019\x20Catalyst\x20Network\n\n\
    \x20This\x20file\x20is\x20part\x20of\x20Catalyst.Network.Protocol.Protob\
    uffs\x20<https://github.com/catalyst-network/protocol-protobuffs>\n\n\
    \x20Catalyst.Network.Protocol.Protobuffs\x20is\x20free\x20software:\x20y\
    ou\x20can\x20redistribute\x20it\x20and/or\x20modify\n\x20it\x20under\x20\
    the\x20terms\x20of\x20the\x20GNU\x20General\x20Public\x20License\x20as\
    \x20published\x20by\n\x20the\x20Free\x20Software\x20Foundation,\x20eithe\
    r\x20version\x202\x20of\x20the\x20License,\x20or\n\x20(at\x20your\x20opt\
    ion)\x20any\x20later\x20version.\n\x20\n\x20Catalyst.Network.Protocol.Pr\
    otobuffs\x20is\x20distributed\x20in\x20the\x20hope\x20that\x20it\x20will\
    \x20be\x20useful,\n\x20but\x20WITHOUT\x20ANY\x20WARRANTY;\x20without\x20\
    even\x20the\x20implied\x20warranty\x20of\n\x20MERCHANTABILITY\x20or\x20F\
    ITNESS\x20FOR\x20A\x20PARTICULAR\x20PURPOSE.\x20See\x20the\n\x20GNU\x20G\
    eneral\x20Public\x20License\x20for\x20more\x20details.\n\x20\n\x20You\
    \x20should\x20have\x20received\x20a\x20copy\x20of\x20the\x20GNU\x20Gener\
    al\x20Public\x20License\n\x20along\x20with\x20Catalyst.Network.Protocol.\
    Protobuffs\x20If\x20not,\x20see\x20<https://www.gnu.org/licenses/>.\n\n\
    \x08\n\x01\x08\x12\x03\x15\0\"\n\t\n\x02\x08\n\x12\x03\x15\0\"\n\t\n\x02\
    \x03\0\x12\x03\x17\0\x1c\n\t\n\x02\x03\x01\x12\x03\x18\0\x14\n\t\n\x02\
    \x03\x02\x12\x03\x19\0\x1b\n\t\n\x02\x03\x03\x12\x03\x1a\0)\n\x08\n\x01\
    \x02\x12\x03\x1c\0\x1f\nc\n\x02\x04\0\x12\x04!\0&\x01\x1aW*\n\x20Provide\
    s\x20a\x20network\x20error\x20message,\x20for\x20when\x20a\x20node\x20ca\
    nt\x20send/\x20build\x20a\x20valid\x20response\n\n\n\n\x03\x04\0\x01\x12\
    \x03!\x08\x1c\n\x0b\n\x04\x04\0\x02\0\x12\x03\"\x08-\n\x0c\n\x05\x04\0\
    \x02\0\x06\x12\x03\"\x08\x1e\n\x0c\n\x05\x04\0\x02\0\x01\x12\x03\"\x1f(\
    \n\x0c\n\x05\x04\0\x02\0\x03\x12\x03\"+,\n\x0b\n\x04\x04\0\x02\x01\x12\
    \x03#\x04\x1c\n\x0c\n\x05\x04\0\x02\x01\x06\x12\x03#\x04\x0f\n\x0c\n\x05\
    \x04\0\x02\x01\x01\x12\x03#\x10\x17\n\x0c\n\x05\x04\0\x02\x01\x03\x12\
    \x03#\x1a\x1b\n\x0b\n\x04\x04\0\x02\x02\x12\x03$\x04\x1d\n\x0c\n\x05\x04\
    \0\x02\x02\x05\x12\x03$\x04\t\n\x0c\n\x05\x04\0\x02\x02\x01\x12\x03$\n\
    \x18\n\x0c\n\x05\x04\0\x02\x02\x03\x12\x03$\x1b\x1c\n\x0b\n\x04\x04\0\
    \x02\x03\x12\x03%\x04\x13\n\x0c\n\x05\x04\0\x02\x03\x05\x12\x03%\x04\t\n\
    \x0c\n\x05\x04\0\x02\x03\x01\x12\x03%\n\x0e\n\x0c\n\x05\x04\0\x02\x03\
    \x03\x12\x03%\x11\x12\n\x95\x01\n\x02\x04\x01\x12\x04+\01\x01\x1a\x88\
    \x01*\n\x20A\x20wrapper\x20around\x20the\x20service\x20message,\x20the\
    \x20contents\x20of\x20service\x20message\x20should\x20be\x20signed\x20by\
    \x20the\x20sender\x20to\x20avoid\x20tampering\x20mid-transit.\n\n\n\n\
    \x03\x04\x01\x01\x12\x03+\x08\x17\n%\n\x04\x04\x01\x02\0\x12\x03,\x04\
    \x1c\"\x18\x20is\x20the\x20sender's\x20peerId\n\n\x0c\n\x05\x04\x01\x02\
    \0\x06\x12\x03,\x04\x0f\n\x0c\n\x05\x04\x01\x02\0\x01\x12\x03,\x10\x17\n\
    \x0c\n\x05\x04\x01\x02\0\x03\x12\x03,\x1a\x1b\nT\n\x04\x04\x01\x02\x01\
    \x12\x03-\x04\x1d\"G\x20is\x20a\x2016\x20bytes\x20guid\x20used\x20to\x20\
    match\x20responses\x20to\x20their\x20original\x20requests\n\n\x0c\n\x05\
    \x04\x01\x02\x01\x05\x12\x03-\x04\t\n\x0c\n\x05\x04\x01\x02\x01\x01\x12\
    \x03-\n\x18\n\x0c\n\x05\x04\x01\x02\x01\x03\x12\x03-\x1b\x1c\n\x88\x01\n\
    \x04\x04\x01\x02\x02\x12\x03.\x04\x18\"{\x20is\x20the\x20shortened\x20pr\
    otocol\x20name\x20of\x20the\x20message\x20type\x20being\x20encoded\x20in\
    \x20the\x20value\x20field\x20(cf\x20Any\x20from\x20protobuf\x20WellKnown\
    Types)\n\n\x0c\n\x05\x04\x01\x02\x02\x05\x12\x03.\x04\n\n\x0c\n\x05\x04\
    \x01\x02\x02\x01\x12\x03.\x0b\x13\n\x0c\n\x05\x04\x01\x02\x02\x03\x12\
    \x03.\x16\x17\ne\n\x04\x04\x01\x02\x03\x12\x03/\x04\x14\"X\x20is\x20the\
    \x20actual\x20value\x20of\x20the\x20message\x20being\x20wrapped\x20(cf\
    \x20Any\x20from\x20protobuf\x20WellKnownTypes)\n\n\x0c\n\x05\x04\x01\x02\
    \x03\x05\x12\x03/\x04\t\n\x0c\n\x05\x04\x01\x02\x03\x01\x12\x03/\n\x0f\n\
    \x0c\n\x05\x04\x01\x02\x03\x03\x12\x03/\x12\x13\n1\n\x04\x04\x01\x02\x04\
    \x12\x030\x04)\"$\x20is\x20the\x20ed25519ph\x20context\x20signature\n\n\
    \x0c\n\x05\x04\x01\x02\x04\x06\x12\x030\x04\x1a\n\x0c\n\x05\x04\x01\x02\
    \x04\x01\x12\x030\x1b$\n\x0c\n\x05\x04\x01\x02\x04\x03\x12\x030'(\n\n\n\
    \x02\x04\x02\x12\x043\09\x01\n\n\n\x03\x04\x02\x01\x12\x033\x08\x1c\n1\n\
    \x04\x04\x02\x02\0\x12\x034\x04)\"$\x20is\x20the\x20ed25519ph\x20context\
    \x20signature\n\n\x0c\n\x05\x04\x02\x02\0\x06\x12\x034\x04\x1a\n\x0c\n\
    \x05\x04\x02\x02\0\x01\x12\x034\x1b$\n\x0c\n\x05\x04\x02\x02\0\x03\x12\
    \x034'(\n5\n\x04\x04\x02\x02\x01\x12\x035\x04,\"(\x20\x20records\x20the\
    \x20transaction\x20creation\x20time\n\n\x0c\n\x05\x04\x02\x02\x01\x06\
    \x12\x035\x04\x1d\n\x0c\n\x05\x04\x02\x02\x01\x01\x12\x035\x1e'\n\x0c\n\
    \x05\x04\x02\x02\x01\x03\x12\x035*+\n3\n\x04\x04\x02\x02\x02\x12\x036\
    \x048\"&\x200\x20field\x20for\x20confidential\x20transaction\n\n\x0c\n\
    \x05\x04\x02\x02\x02\x04\x12\x036\x04\x0c\n\x0c\n\x05\x04\x02\x02\x02\
    \x06\x12\x036\r$\n\x0c\n\x05\x04\x02\x02\x02\x01\x12\x036%3\n\x0c\n\x05\
    \x04\x02\x02\x02\x03\x12\x03667\n7\n\x04\x04\x02\x02\x03\x12\x037\x04D\"\
    *\x200\x20field\x20for\x20non-confidential\x20transaction\n\n\x0c\n\x05\
    \x04\x02\x02\x03\x04\x12\x037\x04\x0c\n\x0c\n\x05\x04\x02\x02\x03\x06\
    \x12\x037\r*\n\x0c\n\x05\x04\x02\x02\x03\x01\x12\x037+?\n\x0c\n\x05\x04\
    \x02\x02\x03\x03\x12\x037BC\n\x0b\n\x04\x04\x02\x02\x04\x12\x038\x04<\n\
    \x0c\n\x05\x04\x02\x02\x04\x04\x12\x038\x04\x0c\n\x0c\n\x05\x04\x02\x02\
    \x04\x06\x12\x038\r&\n\x0c\n\x05\x04\x02\x02\x04\x01\x12\x038'7\n\x0c\n\
    \x05\x04\x02\x02\x04\x03\x12\x038:;\n\n\n\x02\x04\x03\x12\x04;\x01?\x01\
    \n\n\n\x03\x04\x03\x01\x12\x03;\t\x20\n\x8c\x01\n\x04\x04\x03\x02\0\x12\
    \x03<\x08\x17\"\x7f\x20The\x20hash\x20computed\x20for\x20the\x20current\
    \x20delta\x20produced\x20by\x20ProducerId.\x20This\x20is\x20meant\x20to\
    \x20be\x20used\x20when\x20voting\x20for\x20most\x20popular\x20hashes.\n\
    \n\x0c\n\x05\x04\x03\x02\0\x05\x12\x03<\x08\r\n\x0c\n\x05\x04\x03\x02\0\
    \x01\x12\x03<\x0e\x12\n\x0c\n\x05\x04\x03\x02\0\x03\x12\x03<\x15\x16\n;\
    \n\x04\x04\x03\x02\x01\x12\x03=\x08$\".\x20Identifier\x20of\x20the\x20pr\
    oducer\x20of\x20the\x20candidate.\n\n\x0c\n\x05\x04\x03\x02\x01\x06\x12\
    \x03=\x08\x13\n\x0c\n\x05\x04\x03\x02\x01\x01\x12\x03=\x14\x1f\n\x0c\n\
    \x05\x04\x03\x02\x01\x03\x12\x03=\"#\nU\n\x04\x04\x03\x02\x02\x12\x03>\
    \x08*\"H\x20The\x20DFS\x20address\x20for\x20the\x20content\x20of\x20the\
    \x20delta\x20preceding\x20this\x20candidate.\n\n\x0c\n\x05\x04\x03\x02\
    \x02\x05\x12\x03>\x08\r\n\x0c\n\x05\x04\x03\x02\x02\x01\x12\x03>\x0e%\n\
    \x0c\n\x05\x04\x03\x02\x02\x03\x12\x03>()\n\n\n\x02\x04\x04\x12\x04A\0D\
    \x01\n\n\n\x03\x04\x04\x01\x12\x03A\x08\x1f\nM\n\x04\x04\x04\x02\0\x12\
    \x03B\x08.\"@\x20The\x20candidate\x20favoured\x20by\x20the\x20voter\x20b\
    roadcasting\x20this\x20message.\n\n\x0c\n\x05\x04\x04\x02\0\x06\x12\x03B\
    \x08\x1f\n\x0c\n\x05\x04\x04\x02\0\x01\x12\x03B\x20)\n\x0c\n\x05\x04\x04\
    \x02\0\x03\x12\x03B,-\nP\n\x04\x04\x04\x02\x01\x12\x03C\x08!\"C\x20The\
    \x20PeerId\x20of\x20the\x20participant\x20submitting\x20its\x20vote\x20t\
    o\x20the\x20network.\n\n\x0c\n\x05\x04\x04\x02\x01\x06\x12\x03C\x08\x13\
    \n\x0c\n\x05\x04\x04\x02\x01\x01\x12\x03C\x14\x1c\n\x0c\n\x05\x04\x04\
    \x02\x01\x03\x12\x03C\x1f\x20\n\n\n\x02\x04\x05\x12\x04F\x01I\x01\n\n\n\
    \x03\x04\x05\x01\x12\x03F\t\x1e\nW\n\x04\x04\x05\x02\0\x12\x03G\x08!\"J\
    \x20The\x20DFS\x20address\x20at\x20which\x20the\x20full\x20content\x20of\
    \x20the\x20delta\x20can\x20be\x20retrieved.\n\n\x0c\n\x05\x04\x05\x02\0\
    \x05\x12\x03G\x08\r\n\x0c\n\x05\x04\x05\x02\0\x01\x12\x03G\x0e\x1c\n\x0c\
    \n\x05\x04\x05\x02\0\x03\x12\x03G\x1f\x20\nU\n\x04\x04\x05\x02\x01\x12\
    \x03H\x08*\"H\x20The\x20DFS\x20address\x20for\x20the\x20content\x20of\
    \x20the\x20delta\x20preceding\x20this\x20candidate.\n\n\x0c\n\x05\x04\
    \x05\x02\x01\x05\x12\x03H\x08\r\n\x0c\n\x05\x04\x05\x02\x01\x01\x12\x03H\
    \x0e%\n\x0c\n\x05\x04\x05\x02\x01\x03\x12\x03H()b\x06proto3\
";
static mut file_descriptor_proto_lazy: ::protobuf::lazy::Lazy<::protobuf::descriptor::FileDescriptorProto> = ::protobuf::lazy::Lazy {
    lock: ::protobuf::lazy::ONCE_INIT,
    ptr: 0 as *const ::protobuf::descriptor::FileDescriptorProto,
};
fn parse_descriptor_proto() -> ::protobuf::descriptor::FileDescriptorProto {
    ::protobuf::parse_from_bytes(file_descriptor_proto_data).unwrap()
}
pub fn file_descriptor_proto() -> &'static ::protobuf::descriptor::FileDescriptorProto {
    unsafe {
        file_descriptor_proto_lazy.get(|| {
            parse_descriptor_proto()
        })
    }
}