mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 03:27:58 +00:00
7b56ab15b4
* Run cargo fmt on the whole code base * Second run * Add CI check * Fix compilation * More unnecessary braces * Handle weights * Use --all * Use correct attributes... * Fix UI tests * AHHHHHHHHH * 🤦 * Docs * Fix compilation * 🤷 * Please stop * 🤦 x 2 * More * make rustfmt.toml consistent with polkadot Co-authored-by: André Silva <andrerfosilva@gmail.com>
98 lines
3.1 KiB
Rust
98 lines
3.1 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2018-2021 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
//! Low-level types used throughout the Substrate code.
|
|
|
|
#![warn(missing_docs)]
|
|
#![cfg_attr(not(feature = "std"), no_std)]
|
|
|
|
use sp_runtime::{
|
|
generic,
|
|
traits::{BlakeTwo256, IdentifyAccount, Verify},
|
|
MultiSignature, OpaqueExtrinsic,
|
|
};
|
|
|
|
/// An index to a block.
|
|
pub type BlockNumber = u32;
|
|
|
|
/// Alias to 512-bit hash when used in the context of a transaction signature on the chain.
|
|
pub type Signature = MultiSignature;
|
|
|
|
/// Some way of identifying an account on the chain. We intentionally make it equivalent
|
|
/// to the public key of our transaction signing scheme.
|
|
pub type AccountId = <<Signature as Verify>::Signer as IdentifyAccount>::AccountId;
|
|
|
|
/// The type for looking up accounts. We don't expect more than 4 billion of them.
|
|
pub type AccountIndex = u32;
|
|
|
|
/// Balance of an account.
|
|
pub type Balance = u128;
|
|
|
|
/// Type used for expressing timestamp.
|
|
pub type Moment = u64;
|
|
|
|
/// Index of a transaction in the chain.
|
|
pub type Index = u32;
|
|
|
|
/// A hash of some data used by the chain.
|
|
pub type Hash = sp_core::H256;
|
|
|
|
/// A timestamp: milliseconds since the unix epoch.
|
|
/// `u64` is enough to represent a duration of half a billion years, when the
|
|
/// time scale is milliseconds.
|
|
pub type Timestamp = u64;
|
|
|
|
/// Digest item type.
|
|
pub type DigestItem = generic::DigestItem<Hash>;
|
|
/// Header type.
|
|
pub type Header = generic::Header<BlockNumber, BlakeTwo256>;
|
|
/// Block type.
|
|
pub type Block = generic::Block<Header, OpaqueExtrinsic>;
|
|
/// Block ID.
|
|
pub type BlockId = generic::BlockId<Block>;
|
|
|
|
/// App-specific crypto used for reporting equivocation/misbehavior in BABE and
|
|
/// GRANDPA. Any rewards for misbehavior reporting will be paid out to this
|
|
/// account.
|
|
pub mod report {
|
|
use super::{Signature, Verify};
|
|
use frame_system::offchain::AppCrypto;
|
|
use sp_core::crypto::{key_types, KeyTypeId};
|
|
|
|
/// Key type for the reporting module. Used for reporting BABE and GRANDPA
|
|
/// equivocations.
|
|
pub const KEY_TYPE: KeyTypeId = key_types::REPORTING;
|
|
|
|
mod app {
|
|
use sp_application_crypto::{app_crypto, sr25519};
|
|
app_crypto!(sr25519, super::KEY_TYPE);
|
|
}
|
|
|
|
/// Identity of the equivocation/misbehavior reporter.
|
|
pub type ReporterId = app::Public;
|
|
|
|
/// An `AppCrypto` type to allow submitting signed transactions using the reporting
|
|
/// application key as signer.
|
|
pub struct ReporterAppCrypto;
|
|
|
|
impl AppCrypto<<Signature as Verify>::Signer, Signature> for ReporterAppCrypto {
|
|
type RuntimeAppPublic = ReporterId;
|
|
type GenericSignature = sp_core::sr25519::Signature;
|
|
type GenericPublic = sp_core::sr25519::Public;
|
|
}
|
|
}
|