pub struct Bundle {
    pub primary: PrimaryBlock,
    pub canonicals: Vec<CanonicalBlock>,
}Expand description
Bundle represents a bundle as defined in section 4.2.1. Each Bundle contains one primary block and multiple canonical blocks.
Fields§
§primary: PrimaryBlock§canonicals: Vec<CanonicalBlock>Implementations§
Source§impl Bundle
 
impl Bundle
pub fn new(primary: PrimaryBlock, canonicals: Vec<CanonicalBlock>) -> Bundle
Sourcepub fn validate(&self) -> Result<(), ErrorList>
 
pub fn validate(&self) -> Result<(), ErrorList>
Validate bundle and optionally return list of errors.
Sourcepub fn sort_canonicals(&mut self)
 
pub fn sort_canonicals(&mut self)
Sort canonical blocks by block number
Sourcepub fn add_canonical_block(&mut self, cblock: CanonicalBlock)
 
pub fn add_canonical_block(&mut self, cblock: CanonicalBlock)
Automatically assign a block number and add canonical block to bundle
Sourcepub fn is_administrative_record(&self) -> bool
 
pub fn is_administrative_record(&self) -> bool
Checks whether the bundle is an administrative record
Sourcepub fn payload(&self) -> Option<&ByteBuffer>
 
pub fn payload(&self) -> Option<&ByteBuffer>
Return payload of bundle if an payload block exists and carries data.
Sourcepub fn set_payload_block(&mut self, payload: CanonicalBlock)
 
pub fn set_payload_block(&mut self, payload: CanonicalBlock)
Sets or updates the payload block
Sourcepub fn set_payload(&mut self, payload: ByteBuffer)
 
pub fn set_payload(&mut self, payload: ByteBuffer)
Sets or updates the payload
Sourcepub fn set_crc(&mut self, crc_type: CrcRawType)
 
pub fn set_crc(&mut self, crc_type: CrcRawType)
Sets the given CRCType for each block. The crc value is calculated on-the-fly before serializing.
Sourcepub fn crc_valid(&mut self) -> bool
 
pub fn crc_valid(&mut self) -> bool
Check whether a bundle has only valid CRC checksums in all blocks.
Sourcepub fn calculate_crc(&mut self)
 
pub fn calculate_crc(&mut self)
Calculate crc for all blocks.
Sourcepub fn extension_block_by_type(
    &self,
    block_type: CanonicalBlockType,
) -> Option<&CanonicalBlock>
 
pub fn extension_block_by_type( &self, block_type: CanonicalBlockType, ) -> Option<&CanonicalBlock>
Get first extension block matching the block type
Sourcepub fn extension_block_by_type_mut(
    &mut self,
    block_type: CanonicalBlockType,
) -> Option<&mut CanonicalBlock>
 
pub fn extension_block_by_type_mut( &mut self, block_type: CanonicalBlockType, ) -> Option<&mut CanonicalBlock>
Get mutable reference for first extension block matching the block type
Sourcepub fn to_cbor(&mut self) -> ByteBuffer
 
pub fn to_cbor(&mut self) -> ByteBuffer
Serialize bundle as CBOR encoded byte buffer.
Sourcepub fn id(&self) -> String
 
pub fn id(&self) -> String
ID returns a kind of uniquene representation of this bundle, containing the souce node and creation timestamp. If this bundle is a fragment, the offset is also present.
Sourcepub fn update_extensions(
    &mut self,
    local_node: EndpointID,
    residence_time: u128,
) -> bool
 
pub fn update_extensions( &mut self, local_node: EndpointID, residence_time: u128, ) -> bool
Update extension blocks such as hop count, bundle age and previous node. Return true if all successful, omit missing blocks. Return false if hop count is exceeded, bundle age exceeds life time or bundle lifetime itself is exceeded
Sourcepub fn previous_node(&self) -> Option<&EndpointID>
 
pub fn previous_node(&self) -> Option<&EndpointID>
Return the previous node of a bundle should a Previous Node Block exist