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
48
//! `zebra_scan::service::ScanService` response types.

use std::collections::BTreeMap;

use zebra_chain::{block::Height, transaction};

/// A relevant transaction for a key and the block height where it was found.
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct ScanResult {
    /// The key that successfully decrypts the transaction
    pub key: String,

    /// The height of the block with the transaction
    pub height: Height,

    /// A transaction ID, which uniquely identifies mined v5 transactions,
    /// and all v1-v4 transactions.
    pub tx_id: transaction::Hash,
}

#[derive(Debug)]
/// Response types for `zebra_scan::service::ScanService`
pub enum Response {
    /// Response to the [`Info`](super::request::Request::Info) request
    Info {
        /// The minimum sapling birthday height for the shielded scanner
        min_sapling_birthday_height: Height,
    },

    /// Response to [`RegisterKeys`](super::request::Request::RegisterKeys) request
    ///
    /// Contains the keys that the scanner accepted.
    RegisteredKeys(Vec<String>),

    /// Response to [`Results`](super::request::Request::Results) request
    ///
    /// We use the nested `BTreeMap` so we don't repeat any piece of response data.
    Results(BTreeMap<String, BTreeMap<Height, Vec<transaction::Hash>>>),

    /// Response to [`DeleteKeys`](super::request::Request::DeleteKeys) request
    DeletedKeys,

    /// Response to [`ClearResults`](super::request::Request::ClearResults) request
    ClearedResults,

    /// Response to [`SubscribeResults`](super::request::Request::SubscribeResults) request
    SubscribeResults(tokio::sync::mpsc::Receiver<ScanResult>),
}