mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-06 10:18:02 +00:00
2135fa872b
see #2189 This PR does the following: - Bring the user api functions into a new pallet-contracts-uapi (They are currently defined in ink! [here])(https://github.com/paritytech/ink/blob/master/crates/env/src/engine/on_chain/ext.rs) - Add older api versions and unstable to the user api trait. - Remove pallet-contracts-primitives and bring the types it defined in uapi / pallet-contracts - Add the infrastructure to build fixtures from Rust files and test it works by replacing `dummy.wat` and `call.wat` - Move all the doc from wasm/runtime.rs to pallet-contracts-uapi. This will be done in a follow up: - convert the rest of the test from .wat to rust - bring risc-v uapi up to date with wasm - finalize the uapi host fns, making sure everything is codegen from the source host fns in pallet-contracts --------- Co-authored-by: Alexander Theißen <alex.theissen@me.com>
113 lines
3.6 KiB
Rust
113 lines
3.6 KiB
Rust
// This file is part of Substrate.
|
|
|
|
// Copyright (C) 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.
|
|
|
|
pub use crate::{
|
|
exec::{ExecResult, ExportedFunction},
|
|
primitives::ExecReturnValue,
|
|
};
|
|
use crate::{Config, LOG_TARGET};
|
|
|
|
/// Umbrella trait for all interfaces that serves for debugging.
|
|
pub trait Debugger<T: Config>: Tracing<T> + CallInterceptor<T> {}
|
|
|
|
impl<T: Config, V> Debugger<T> for V where V: Tracing<T> + CallInterceptor<T> {}
|
|
|
|
/// Defines methods to capture contract calls, enabling external observers to
|
|
/// measure, trace, and react to contract interactions.
|
|
pub trait Tracing<T: Config> {
|
|
/// The type of [`CallSpan`] that is created by this trait.
|
|
type CallSpan: CallSpan;
|
|
|
|
/// Creates a new call span to encompass the upcoming contract execution.
|
|
///
|
|
/// This method should be invoked just before the execution of a contract and
|
|
/// marks the beginning of a traceable span of execution.
|
|
///
|
|
/// # Arguments
|
|
///
|
|
/// * `contract_address` - The address of the contract that is about to be executed.
|
|
/// * `entry_point` - Describes whether the call is the constructor or a regular call.
|
|
/// * `input_data` - The raw input data of the call.
|
|
fn new_call_span(
|
|
contract_address: &T::AccountId,
|
|
entry_point: ExportedFunction,
|
|
input_data: &[u8],
|
|
) -> Self::CallSpan;
|
|
}
|
|
|
|
/// Defines a span of execution for a contract call.
|
|
pub trait CallSpan {
|
|
/// Called just after the execution of a contract.
|
|
///
|
|
/// # Arguments
|
|
///
|
|
/// * `output` - The raw output of the call.
|
|
fn after_call(self, output: &ExecReturnValue);
|
|
}
|
|
|
|
impl<T: Config> Tracing<T> for () {
|
|
type CallSpan = ();
|
|
|
|
fn new_call_span(
|
|
contract_address: &T::AccountId,
|
|
entry_point: ExportedFunction,
|
|
input_data: &[u8],
|
|
) {
|
|
log::trace!(target: LOG_TARGET, "call {entry_point:?} account: {contract_address:?}, input_data: {input_data:?}")
|
|
}
|
|
}
|
|
|
|
impl CallSpan for () {
|
|
fn after_call(self, output: &ExecReturnValue) {
|
|
log::trace!(target: LOG_TARGET, "call result {output:?}")
|
|
}
|
|
}
|
|
|
|
/// Provides an interface for intercepting contract calls.
|
|
pub trait CallInterceptor<T: Config> {
|
|
/// Allows to intercept contract calls and decide whether they should be executed or not.
|
|
/// If the call is intercepted, the mocked result of the call is returned.
|
|
///
|
|
/// # Arguments
|
|
///
|
|
/// * `contract_address` - The address of the contract that is about to be executed.
|
|
/// * `entry_point` - Describes whether the call is the constructor or a regular call.
|
|
/// * `input_data` - The raw input data of the call.
|
|
///
|
|
/// # Expected behavior
|
|
///
|
|
/// This method should return:
|
|
/// * `Some(ExecResult)` - if the call should be intercepted and the mocked result of the call
|
|
/// is returned.
|
|
/// * `None` - otherwise, i.e. the call should be executed normally.
|
|
fn intercept_call(
|
|
contract_address: &T::AccountId,
|
|
entry_point: &ExportedFunction,
|
|
input_data: &[u8],
|
|
) -> Option<ExecResult>;
|
|
}
|
|
|
|
impl<T: Config> CallInterceptor<T> for () {
|
|
fn intercept_call(
|
|
_contract_address: &T::AccountId,
|
|
_entry_point: &ExportedFunction,
|
|
_input_data: &[u8],
|
|
) -> Option<ExecResult> {
|
|
None
|
|
}
|
|
}
|