mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-26 21:37:56 +00:00
c6f07d8f31
* Indentation fix. * Prepare request-response for PoV fetching. * Drop old PoV distribution. * WIP: Fetch PoV directly from backing. * Backing compiles. * Runtime access and connection management for PoV distribution. * Get rid of seemingly dead code. * Implement PoV fetching. Backing does not yet use it. * Don't send `ConnectToValidators` for empty list. * Even better - no need to check over and over again. * PoV fetching implemented. + Typechecks + Should work Missing: - Guide - Tests - Do fallback fetching in case fetching from seconding validator fails. * Check PoV hash upon reception. * Implement retry of PoV fetching in backing. * Avoid pointless validation spawning. * Add jaeger span to pov requesting. * Add back tracing. * Review remarks. * Whitespace. * Whitespace again. * Cleanup + fix tests. * Log to log target in overseer. * Fix more tests. * Don't fail if group cannot be found. * Simple test for PoV fetcher. * Handle missing group membership better. * Add test for retry functionality. * Fix flaky test. * Spaces again. * Guide updates. * Spaces.
171 lines
5.1 KiB
Rust
171 lines
5.1 KiB
Rust
// Copyright 2021 Parity Technologies (UK) Ltd.
|
|
// This file is part of Polkadot.
|
|
|
|
// Polkadot 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.
|
|
|
|
// Polkadot 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 Polkadot. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Requests and responses as sent over the wire for the individual protocols.
|
|
|
|
use parity_scale_codec::{Decode, Encode};
|
|
|
|
use polkadot_primitives::v1::{
|
|
AvailableData, CandidateHash, CandidateReceipt, ErasureChunk, ValidatorIndex,
|
|
CompressedPoV, Hash,
|
|
};
|
|
use polkadot_primitives::v1::Id as ParaId;
|
|
|
|
use super::request::IsRequest;
|
|
use super::Protocol;
|
|
|
|
/// Request an availability chunk.
|
|
#[derive(Debug, Copy, Clone, Encode, Decode)]
|
|
pub struct ChunkFetchingRequest {
|
|
/// Hash of candidate we want a chunk for.
|
|
pub candidate_hash: CandidateHash,
|
|
/// The index of the chunk to fetch.
|
|
pub index: ValidatorIndex,
|
|
}
|
|
|
|
/// Receive a requested erasure chunk.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub enum ChunkFetchingResponse {
|
|
/// The requested chunk data.
|
|
#[codec(index = 0)]
|
|
Chunk(ChunkResponse),
|
|
/// Node was not in possession of the requested chunk.
|
|
#[codec(index = 1)]
|
|
NoSuchChunk,
|
|
}
|
|
|
|
impl From<Option<ChunkResponse>> for ChunkFetchingResponse {
|
|
fn from(x: Option<ChunkResponse>) -> Self {
|
|
match x {
|
|
Some(c) => ChunkFetchingResponse::Chunk(c),
|
|
None => ChunkFetchingResponse::NoSuchChunk,
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Skimmed down variant of `ErasureChunk`.
|
|
///
|
|
/// Instead of transmitting a full `ErasureChunk` we transmit `ChunkResponse` in
|
|
/// `ChunkFetchingResponse`, which omits the chunk's index. The index is already known by
|
|
/// the requester and by not transmitting it, we ensure the requester is going to use his index
|
|
/// value for validating the response, thus making sure he got what he requested.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub struct ChunkResponse {
|
|
/// The erasure-encoded chunk of data belonging to the candidate block.
|
|
pub chunk: Vec<u8>,
|
|
/// Proof for this chunk's branch in the Merkle tree.
|
|
pub proof: Vec<Vec<u8>>,
|
|
}
|
|
|
|
impl From<ErasureChunk> for ChunkResponse {
|
|
fn from(ErasureChunk {chunk, index: _, proof}: ErasureChunk) -> Self {
|
|
ChunkResponse {chunk, proof}
|
|
}
|
|
}
|
|
|
|
impl ChunkResponse {
|
|
/// Re-build an `ErasureChunk` from response and request.
|
|
pub fn recombine_into_chunk(self, req: &ChunkFetchingRequest) -> ErasureChunk {
|
|
ErasureChunk {
|
|
chunk: self.chunk,
|
|
proof: self.proof,
|
|
index: req.index,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl IsRequest for ChunkFetchingRequest {
|
|
type Response = ChunkFetchingResponse;
|
|
const PROTOCOL: Protocol = Protocol::ChunkFetching;
|
|
}
|
|
|
|
/// Request the advertised collation at that relay-parent.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub struct CollationFetchingRequest {
|
|
/// Relay parent we want a collation for.
|
|
pub relay_parent: Hash,
|
|
/// The `ParaId` of the collation.
|
|
pub para_id: ParaId,
|
|
}
|
|
|
|
/// Responses as sent by collators.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub enum CollationFetchingResponse {
|
|
/// Deliver requested collation.
|
|
#[codec(index = 0)]
|
|
Collation(CandidateReceipt, CompressedPoV),
|
|
}
|
|
|
|
impl IsRequest for CollationFetchingRequest {
|
|
type Response = CollationFetchingResponse;
|
|
const PROTOCOL: Protocol = Protocol::CollationFetching;
|
|
}
|
|
|
|
/// Request the advertised collation at that relay-parent.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub struct PoVFetchingRequest {
|
|
/// Candidate we want a PoV for.
|
|
pub candidate_hash: CandidateHash,
|
|
}
|
|
|
|
/// Responses to `PoVFetchingRequest`.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub enum PoVFetchingResponse {
|
|
/// Deliver requested PoV.
|
|
#[codec(index = 0)]
|
|
PoV(CompressedPoV),
|
|
/// PoV was not found in store.
|
|
#[codec(index = 1)]
|
|
NoSuchPoV,
|
|
}
|
|
|
|
impl IsRequest for PoVFetchingRequest {
|
|
type Response = PoVFetchingResponse;
|
|
const PROTOCOL: Protocol = Protocol::PoVFetching;
|
|
}
|
|
|
|
/// Request the entire available data for a candidate.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub struct AvailableDataFetchingRequest {
|
|
/// The candidate hash to get the available data for.
|
|
pub candidate_hash: CandidateHash,
|
|
}
|
|
|
|
/// Receive a requested available data.
|
|
#[derive(Debug, Clone, Encode, Decode)]
|
|
pub enum AvailableDataFetchingResponse {
|
|
/// The requested data.
|
|
#[codec(index = 0)]
|
|
AvailableData(AvailableData),
|
|
/// Node was not in possession of the requested data.
|
|
#[codec(index = 1)]
|
|
NoSuchData,
|
|
}
|
|
|
|
impl From<Option<AvailableData>> for AvailableDataFetchingResponse {
|
|
fn from(x: Option<AvailableData>) -> Self {
|
|
match x {
|
|
Some(data) => AvailableDataFetchingResponse::AvailableData(data),
|
|
None => AvailableDataFetchingResponse::NoSuchData,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl IsRequest for AvailableDataFetchingRequest {
|
|
type Response = AvailableDataFetchingResponse;
|
|
const PROTOCOL: Protocol = Protocol::AvailableDataFetching;
|
|
}
|