Struct Hash

Source
pub struct Hash {
    pub input: InputPort<Bytes>,
    pub output: OutputPort<Bytes>,
    pub hash: OutputPort<Bytes>,
    pub algorithm: HashAlgorithm,
    /* private fields */
}
Expand description

Computes the cryptographic hash of a byte stream, while optionally passing it through.

§Block Diagram

block-beta
    columns 7
    Source space:2 Hash space:2 Sink
    space:7
    space:7
    space:3 Result space:3
    Source-- "input" -->Hash
    Hash-- "output" -->Sink
    Hash-- "hash" -->Result

    classDef block height:48px,padding:8px;
    classDef hidden visibility:none;
    class Hash block
    class Source hidden
    class Sink hidden
    class Result hidden

§Sequence Diagram

sequenceDiagram
    autonumber
    participant BlockA as Another block
    participant Hash.input as Hash.input port
    participant Hash as Hash block
    participant Hash.output as Hash.output port
    participant BlockB as Another block
    participant Hash.hash as Hash.hash port
    participant BlockC as Another block

    BlockA-->>Hash: Connect
    Hash-->>BlockB: Connect

    loop Hash process
        BlockA->>Hash: Message (Bytes)
        Hash->>Hash: Update state
        Hash->>BlockB: Message (Bytes)
    end

    BlockA-->>Hash: Disconnect
    Hash-->>Hash.input: Close
    Hash-->>Hash.output: Close
    Hash-->>BlockB: Disconnect

    Hash-->>BlockC: Connect
    Hash->>BlockC: Hash
    Hash-->>Hash.hash: Close
    Hash-->>BlockC: Disconnect

    %% TODO

§Examples

§Using the block in a system

System::build(|s| {
    let stdin = s.read_stdin();
    let hasher = s.hash_blake3();
    let hex_encoder = s.encode_hex();
    let stdout = s.write_stdout();
    s.connect(&stdin.output, &hasher.input);
    s.connect(&hasher.hash, &hex_encoder.input);
    s.connect(&hex_encoder.output, &stdout.input);
});

§Running the block via the CLI

$ protoflow execute Hash algorithm=blake3

Fields§

§input: InputPort<Bytes>

The input byte stream.

§output: OutputPort<Bytes>

The (optional) output target for the stream being passed through.

§hash: OutputPort<Bytes>

The output port for the computed hash.

§algorithm: HashAlgorithm

A configuration parameter for which algorithm to use.

Implementations§

Source§

impl Hash

Source

pub fn new( input: InputPort<Bytes>, output: OutputPort<Bytes>, hash: OutputPort<Bytes>, ) -> Self

Source

pub fn with_params( input: InputPort<Bytes>, output: OutputPort<Bytes>, hash: OutputPort<Bytes>, algorithm: Option<HashAlgorithm>, ) -> Self

Source

pub fn with_system(system: &System, algorithm: Option<HashAlgorithm>) -> Self

Trait Implementations§

Source§

impl Block for Hash

Source§

fn execute(&mut self, runtime: &dyn BlockRuntime) -> BlockResult

Executes this block’s computation.
Source§

fn prepare(&mut self, _runtime: &dyn BlockRuntime) -> Result<(), BlockError>

Prepares this block for execution. Read more
Source§

impl BlockDescriptor for Hash

Source§

fn inputs(&self) -> Vec<PortDescriptor>

A description of this block’s input ports.
Source§

fn outputs(&self) -> Vec<PortDescriptor>

A description of this block’s output ports.
Source§

fn parameters(&self) -> Vec<ParameterDescriptor>

A description of this block’s parameters.
Source§

fn ports(&self) -> Vec<PortDescriptor>

A description of this block’s I/O ports.
Source§

impl Clone for Hash

Source§

fn clone(&self) -> Hash

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl MaybeLabeled for Hash

Source§

fn label(&self) -> Option<Cow<'_, str>>

Returns the human-readable label, if any, of the object.
Source§

fn is_labeled(&self) -> bool

Checks whether the object has a human-readable label.
Source§

impl MaybeNamed for Hash

Source§

fn name(&self) -> Option<Cow<'_, str>>

Returns the name, if any, of the object.
Source§

fn is_named(&self) -> bool

Checks whether the object has a name.
Source§

impl StdioSystem for Hash

Auto Trait Implementations§

§

impl Freeze for Hash

§

impl !RefUnwindSafe for Hash

§

impl Send for Hash

§

impl Sync for Hash

§

impl Unpin for Hash

§

impl !UnwindSafe for Hash

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> AsBlock for T
where T: Block,

Source§

fn as_block(&self) -> &dyn Block

Source§

impl<T> AsBlockDescriptor for T
where T: BlockDescriptor,

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V