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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
// Copyright 2015-2020 Parity Technologies (UK) Ltd.
// This file is part of OpenEthereum.

// OpenEthereum is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.

// OpenEthereum is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.

// You should have received a copy of the GNU General Public License
// along with OpenEthereum.  If not, see <http://www.gnu.org/licenses/>.

use std::sync::{mpsc, Arc};

use crate::{
    sync::{self, ConnectionFilter, NetworkConfiguration, Params, SyncConfig},
    types::BlockNumber,
};
use ethcore::{client::BlockChainClient, snapshot::SnapshotService};
use std::collections::BTreeSet;

pub use crate::sync::{EthSync, ManageNetwork, SyncProvider};
pub use ethcore::client::ChainNotify;
use ethcore_logger::Config as LogConfig;
use ethereum_types::H256;

pub type SyncModules = (
    Arc<dyn SyncProvider>,
    Arc<dyn ManageNetwork>,
    Arc<dyn ChainNotify>,
    mpsc::Sender<sync::PriorityTask>,
    crossbeam_channel::Sender<H256>,
);

pub fn sync(
    config: SyncConfig,
    network_config: NetworkConfiguration,
    chain: Arc<dyn BlockChainClient>,
    forks: BTreeSet<BlockNumber>,
    snapshot_service: Arc<dyn SnapshotService>,
    _log_settings: &LogConfig,
    connection_filter: Option<Arc<dyn ConnectionFilter>>,
) -> Result<SyncModules, sync::Error> {
    let eth_sync = EthSync::new(
        Params {
            config,
            chain,
            forks,
            snapshot_service,
            network_config,
        },
        connection_filter,
    )?;

    Ok((
        eth_sync.clone() as Arc<dyn SyncProvider>,
        eth_sync.clone() as Arc<dyn ManageNetwork>,
        eth_sync.clone() as Arc<dyn ChainNotify>,
        eth_sync.priority_tasks(),
        eth_sync.new_transaction_hashes(),
    ))
}