mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 02:17:58 +00:00
d9f02296ab
* RUSTSEC-2021-0076 bump libsecp256k1 libsecp256k1 allows overflowing signatures https://rustsec.org/advisories/RUSTSEC-2021-0076 Changes were made to conform to libsecp256k1 version differences. Closes #9356 * parse_standard_slice() -> parse_overflowing_slice() * Added v2 host function for ecdsa_verify * Add feature tag over helpers * Added ecdsa_verify v2 to test runner * PR feedback - Spaces -> tabs - renamed two helper functions * Fixed imports after rebasing * Bump rest of libsecp256k1 (and libp2p) libp2p also uses libsecp256k1 so it is required to be bumped too, along with all the version difference changes. * Add version2 for ecdsa pubkey recovery * libp2p rebase master fixes * Fix test panic when non Behaviour event is returned * Update bin/node/browser-testing/Cargo.toml * Update primitives/core/src/ecdsa.rs * Update primitives/core/src/ecdsa.rs * Update Cargo.lock Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com>
91 lines
3.3 KiB
Rust
91 lines
3.3 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 2021 Parity Technologies (UK) Ltd.
|
|
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0
|
|
|
|
// This program 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.
|
|
|
|
// This program 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 this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
/// Use this to override host functions.
|
|
/// eg
|
|
/// ```rust
|
|
/// use test_runner::override_host_functions;
|
|
/// pub struct SignatureVerificationOverride;
|
|
///
|
|
/// impl sp_wasm_interface::HostFunctions for SignatureVerificationOverride {
|
|
/// fn host_functions() -> Vec<&'static dyn sp_wasm_interface::Function> {
|
|
/// override_host_functions!(
|
|
/// "ext_crypto_ecdsa_verify_version_1", EcdsaVerify,
|
|
/// )
|
|
/// }
|
|
/// }
|
|
/// ```
|
|
#[macro_export]
|
|
macro_rules! override_host_functions {
|
|
($($fn_name:expr, $name:ident,)*) => {{
|
|
let mut host_functions = vec![];
|
|
$(
|
|
struct $name;
|
|
impl sp_wasm_interface::Function for $name {
|
|
fn name(&self) -> &str {
|
|
&$fn_name
|
|
}
|
|
|
|
fn signature(&self) -> sp_wasm_interface::Signature {
|
|
sp_wasm_interface::Signature {
|
|
args: std::borrow::Cow::Owned(vec![
|
|
sp_wasm_interface::ValueType::I32,
|
|
sp_wasm_interface::ValueType::I64,
|
|
sp_wasm_interface::ValueType::I32,
|
|
]),
|
|
return_value: Some(sp_wasm_interface::ValueType::I32),
|
|
}
|
|
}
|
|
|
|
fn execute(
|
|
&self,
|
|
context: &mut dyn sp_wasm_interface::FunctionContext,
|
|
_args: &mut dyn Iterator<Item = sp_wasm_interface::Value>,
|
|
) -> Result<Option<sp_wasm_interface::Value>, String> {
|
|
<bool as sp_runtime_interface::host::IntoFFIValue>::into_ffi_value(true, context)
|
|
.map(sp_wasm_interface::IntoValue::into_value)
|
|
.map(Some)
|
|
}
|
|
}
|
|
host_functions.push(&$name as &'static dyn sp_wasm_interface::Function);
|
|
)*
|
|
host_functions
|
|
}};
|
|
}
|
|
|
|
/// Provides host functions that overrides runtime signature verification
|
|
/// to always return true.
|
|
pub struct SignatureVerificationOverride;
|
|
|
|
impl sp_wasm_interface::HostFunctions for SignatureVerificationOverride {
|
|
fn host_functions() -> Vec<&'static dyn sp_wasm_interface::Function> {
|
|
override_host_functions!(
|
|
"ext_crypto_ecdsa_verify_version_1",
|
|
EcdsaVerify,
|
|
"ext_crypto_ecdsa_verify_version_2",
|
|
EcdsaVerifyV2,
|
|
"ext_crypto_ed25519_verify_version_1",
|
|
Ed25519Verify,
|
|
"ext_crypto_sr25519_verify_version_1",
|
|
Sr25519Verify,
|
|
"ext_crypto_sr25519_verify_version_2",
|
|
Sr25519VerifyV2,
|
|
)
|
|
}
|
|
}
|