3854b8a689
* stub implementations of light client trait * Light provider trait * light client sync stubs * LES boilerplate * stub implementation of provider for client * skeleton and request traits * request definitions * new_list -> begin_list * handle unknown packet * revise light implementation strategy * make verification module public * Move all light client work to own crate * experiment with answering requests * buffer flow scaffolding * remove LESv2 requests * buffer flow basics, implement cost table * begin status module * implement handshake parsing and creation * implement announcement serialization * errors, punishment, and handshake * handle announcements * making announcements, clean up warnings * allow dead code temporarily
47 lines
1.7 KiB
Rust
47 lines
1.7 KiB
Rust
// Copyright 2015, 2016 Ethcore (UK) Ltd.
|
|
// This file is part of Parity.
|
|
|
|
// Parity 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.
|
|
|
|
// Parity 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 Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Light client logic and implementation.
|
|
//!
|
|
//! A "light" client stores very little chain-related data locally
|
|
//! unlike a full node, which stores all blocks, headers, receipts, and more.
|
|
//!
|
|
//! This enables the client to have a much lower resource footprint in
|
|
//! exchange for the cost of having to ask the network for state data
|
|
//! while responding to queries. This makes a light client unsuitable for
|
|
//! low-latency applications, but perfectly suitable for simple everyday
|
|
//! use-cases like sending transactions from a personal account.
|
|
//!
|
|
//! It starts by performing a header-only sync, verifying random samples
|
|
//! of members of the chain to varying degrees.
|
|
|
|
// TODO: remove when integrating with parity.
|
|
#![allow(dead_code)]
|
|
|
|
pub mod client;
|
|
pub mod net;
|
|
pub mod provider;
|
|
pub mod request;
|
|
|
|
extern crate ethcore_util as util;
|
|
extern crate ethcore_network as network;
|
|
extern crate ethcore_io as io;
|
|
extern crate ethcore;
|
|
extern crate rlp;
|
|
extern crate time;
|
|
|
|
#[macro_use]
|
|
extern crate log; |