Skip to content

Commit

Permalink
Merge pull request #22 from gogo2464/remove-delta
Browse files Browse the repository at this point in the history
remove validate delta
  • Loading branch information
iduartgomez authored Oct 12, 2024
2 parents f3d6893 + c900428 commit 89f0a4b
Show file tree
Hide file tree
Showing 9 changed files with 0 additions and 247 deletions.
7 changes: 0 additions & 7 deletions examples/contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,13 +16,6 @@ impl ContractInterface for Contract {
unimplemented!()
}

fn validate_delta(
_parameters: Parameters<'static>,
_delta: StateDelta<'static>,
) -> Result<bool, ContractError> {
unimplemented!()
}

fn update_state(
_parameters: Parameters<'static>,
_state: State<'static>,
Expand Down
40 changes: 0 additions & 40 deletions rust-macros/src/contract_impl.rs
Original file line number Diff line number Diff line change
Expand Up @@ -352,13 +352,6 @@ impl ImplTrait {
::freenet_stdlib::typed_contract::inner_validate_state::<#type_name>(parameters, state, related)
}

fn validate_delta(
parameters: ::freenet_stdlib::prelude::Parameters<'static>,
delta: ::freenet_stdlib::prelude::StateDelta<'static>,
) -> ::core::result::Result<bool, ::freenet_stdlib::prelude::ContractError> {
::freenet_stdlib::typed_contract::inner_validate_delta::<#type_name>(parameters, delta)
}

fn update_state(
parameters: ::freenet_stdlib::prelude::Parameters<'static>,
state: ::freenet_stdlib::prelude::State<'static>,
Expand Down Expand Up @@ -415,17 +408,6 @@ impl ImplTrait {
}
});

let validate_delta_impl = self.children.iter().map(|child| {
quote! {
if !::freenet_stdlib::contract_composition::from_bytes::inner_validate_delta::<
#type_name,
#child,
>(parameters.clone(), delta.clone())? {
return ::core::result::Result::Ok(false);
}
}
});

let update_state_impl = self.children.iter().map(|child| {
quote! {{
let modification = ::freenet_stdlib::contract_composition::from_bytes::inner_update_state::<
Expand Down Expand Up @@ -454,14 +436,6 @@ impl ImplTrait {
::core::result::Result::Ok(::freenet_stdlib::prelude::ValidateResult::Valid)
}

fn validate_delta(
parameters: ::freenet_stdlib::prelude::Parameters<'static>,
delta: ::freenet_stdlib::prelude::StateDelta<'static>,
) -> ::core::result::Result<bool, ::freenet_stdlib::prelude::ContractError> {
#(#validate_delta_impl)*
::core::result::Result::Ok(true)
}

fn update_state(
parameters: ::freenet_stdlib::prelude::Parameters<'static>,
state: ::freenet_stdlib::prelude::State<'static>,
Expand Down Expand Up @@ -513,13 +487,11 @@ impl ImplTrait {

fn gen_extern_functions(&self) -> TokenStream {
let validate_state_fn = self.gen_validate_state_fn();
let validate_delta_fn = self.gen_validate_delta_fn();
let update_fn = self.gen_update_state_fn();
let summarize_fn = self.gen_summarize_state_fn();
let get_delta_fn = self.gen_get_state_delta();
quote! {
#validate_state_fn
#validate_delta_fn
#update_fn
#summarize_fn
#get_delta_fn
Expand All @@ -538,18 +510,6 @@ impl ImplTrait {
}
}

fn gen_validate_delta_fn(&self) -> TokenStream {
let type_name = &self.type_name;
let ret = self.ffi_ret_type();
quote! {
#[no_mangle]
#[cfg(feature = "freenet-main-contract")]
pub extern "C" fn validate_delta(parameters: i64, delta: i64) -> #ret {
::freenet_stdlib::memory::wasm_interface::inner_validate_delta::<#type_name>(parameters, delta)
}
}
}

fn gen_update_state_fn(&self) -> TokenStream {
let type_name = &self.type_name;
let ret = self.ffi_ret_type();
Expand Down
30 changes: 0 additions & 30 deletions rust/examples/chatroom.rs
Original file line number Diff line number Diff line change
Expand Up @@ -94,16 +94,6 @@ impl ContractComponent for ChatRoom {
unimplemented!()
}

fn verify_delta<Child>(
_: &Self::Parameters,
_: &Self::Delta,
) -> Result<bool, freenet_stdlib::prelude::ContractError>
where
Child: ContractComponent,
{
unimplemented!()
}

fn merge(
&mut self,
_: &Self::Parameters,
Expand Down Expand Up @@ -196,16 +186,6 @@ pub mod dependency_2 {
unreachable!()
}

fn verify_delta<Child>(
_: &Self::Parameters,
_: &Self::Delta,
) -> Result<bool, freenet_stdlib::prelude::ContractError>
where
Child: ContractComponent,
{
unreachable!()
}

fn merge(
&mut self,
_: &Self::Parameters,
Expand Down Expand Up @@ -275,16 +255,6 @@ pub mod dependency_2 {
unimplemented!()
}

fn verify_delta<Child>(
_: &Self::Parameters,
_: &Self::Delta,
) -> Result<bool, freenet_stdlib::prelude::ContractError>
where
Child: ContractComponent,
{
unimplemented!()
}

fn merge(
&mut self,
_: &Self::Parameters,
Expand Down
30 changes: 0 additions & 30 deletions rust/examples/contract_components.rs
Original file line number Diff line number Diff line change
Expand Up @@ -99,20 +99,6 @@ mod parent {
Ok(ValidateResult::Valid)
}

fn verify_delta<Child>(
parameters: &Self::Parameters,
delta: &Self::Delta,
) -> Result<bool, ContractError>
where
Child: ContractComponent,
{
<ChildComponent as ContractComponent>::verify_delta::<ChildComponent>(
&parameters.into(),
&delta.into(),
)?;
Ok(true)
}

fn merge(
&mut self,
parameters: &Self::Parameters,
Expand Down Expand Up @@ -254,18 +240,6 @@ mod children {
Ok(ValidateResult::Valid)
}

fn verify_delta<Child>(
parameters: &Self::Parameters,
_delta: &Self::Delta,
) -> Result<bool, ContractError>
where
Child: ContractComponent,
{
let _pub_key = PubKey::from(parameters.clone());
// assert something in Self::Delta is signed with pub key
Ok(true)
}

fn merge(
&mut self,
parameters: &Self::Parameters,
Expand Down Expand Up @@ -337,10 +311,6 @@ mod children {
unimplemented!()
}

fn verify_delta(_: Self::Parameters, _: Self::Delta) -> Result<bool, ContractError> {
unimplemented!()
}

fn merge(
&mut self,
_: &Self::Parameters,
Expand Down
7 changes: 0 additions & 7 deletions rust/examples/typed_contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,13 +44,6 @@ impl TypedContract for Contract {
unimplemented!()
}

fn verify_delta(
_: Self::Parameters,
_: Self::Delta,
) -> Result<bool, freenet_stdlib::prelude::ContractError> {
Ok(true)
}

fn merge(
&mut self,
_: &Self::Parameters,
Expand Down
46 changes: 0 additions & 46 deletions rust/src/contract_composition.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,14 +36,6 @@ pub trait ContractComponent: std::any::Any + Sized {
Child: ContractComponent,
Self::Context: for<'x> From<&'x Ctx>;

/// Corresponds to ContractInterface `validate_delta`
fn verify_delta<Child>(
parameters: &Self::Parameters,
delta: &Self::Delta,
) -> Result<bool, ContractError>
where
Child: ContractComponent;

/// Corresponds to ContractInterface `update_state`
fn merge(
&mut self,
Expand Down Expand Up @@ -145,16 +137,6 @@ where
Ok(ValidateResult::Valid)
}

fn verify_delta<Child>(
parameters: &Self::Parameters,
delta: &Self::Delta,
) -> Result<bool, ContractError>
where
Child: ContractComponent,
{
<T as ContractComponent>::verify_delta::<Child>(parameters, delta)
}

fn merge(
&mut self,
parameters: &Self::Parameters,
Expand Down Expand Up @@ -274,34 +256,6 @@ pub mod from_bytes {
Ok(ValidateResult::Valid)
}

pub fn inner_validate_delta<T, Child>(
parameters: Parameters<'static>,
delta: StateDelta<'static>,
) -> Result<bool, ContractError>
where
T: ContractComponent + EncodingAdapter,
<T as EncodingAdapter>::Parameters: Into<<T as ContractComponent>::Parameters>,
<T as EncodingAdapter>::Delta: Into<<T as ContractComponent>::Delta>,
ContractError: From<
<<T as EncodingAdapter>::ParametersEncoder as Encoder<
<T as EncodingAdapter>::Parameters,
>>::Error,
>,
ContractError: From<
<<T as EncodingAdapter>::DeltaEncoder as Encoder<<T as EncodingAdapter>::Delta>>::Error,
>,
Child: ContractComponent,
<Child as ContractComponent>::Parameters:
for<'x> From<&'x <T as ContractComponent>::Parameters>,
<Child as ContractComponent>::Delta: for<'x> From<&'x <T as ContractComponent>::Delta>,
{
let typed_params =
<<T as EncodingAdapter>::ParametersEncoder>::deserialize(parameters.as_ref())?.into();
let typed_delta =
<<T as EncodingAdapter>::DeltaEncoder>::deserialize(delta.as_ref())?.into();
<T as ContractComponent>::verify_delta::<Child>(&typed_params, &typed_delta)
}

pub fn inner_update_state<T, Child>(
parameters: Parameters<'static>,
state: State<'static>,
Expand Down
60 changes: 0 additions & 60 deletions rust/src/contract_interface.rs
Original file line number Diff line number Diff line change
Expand Up @@ -401,13 +401,6 @@ impl<'a> TryFromFbs<&FbsUpdateData<'a>> for UpdateData<'a> {
/// Ok(ValidateResult::Valid)
/// }
///
/// fn validate_delta(
/// _parameters: Parameters<'static>,
/// _delta: StateDelta<'static>
/// ) -> Result<bool, ContractError> {
/// Ok(true)
/// }
///
/// fn update_state(
/// _parameters: Parameters<'static>,
/// state: State<'static>,
Expand Down Expand Up @@ -451,13 +444,6 @@ pub trait ContractInterface {
related: RelatedContracts<'static>,
) -> Result<ValidateResult, ContractError>;

/// Verify that a delta is valid if possible, returns false if and only delta is
/// definitely invalid, true otherwise.
fn validate_delta(
parameters: Parameters<'static>,
delta: StateDelta<'static>,
) -> Result<bool, ContractError>;

/// Update the state to account for the new data
fn update_state(
parameters: Parameters<'static>,
Expand Down Expand Up @@ -1386,26 +1372,6 @@ pub(crate) mod wasm_interface {
}
}

pub unsafe fn unwrap_validate_delta_res(
self,
mem: WasmLinearMem,
) -> Result<bool, ContractError> {
#![allow(clippy::let_and_return)]
let kind = ResultKind::from(self.kind);
match kind {
ResultKind::ValidateDelta => {
let ptr = crate::memory::buf::compute_ptr(self.ptr as *mut u8, &mem);
let serialized = std::slice::from_raw_parts(ptr as *const u8, self.size as _);
let value = bincode::deserialize(serialized)
.map_err(|e| ContractError::Other(format!("{e}")))?;
#[cfg(feature = "trace")]
self.log_input(serialized, &value, ptr);
value
}
_ => unreachable!(),
}
}

pub unsafe fn unwrap_update_state(
self,
mem: WasmLinearMem,
Expand Down Expand Up @@ -1799,11 +1765,6 @@ pub mod encoding {
related: RelatedContractsContainer,
) -> Result<ValidateResult, ContractError>;

fn verify_delta(
parameters: Self::Parameters,
delta: Self::Delta,
) -> Result<bool, ContractError>;

fn merge(
&mut self,
parameters: &Self::Parameters,
Expand Down Expand Up @@ -1893,27 +1854,6 @@ pub mod encoding {
typed_state.verify(typed_params, related_container)
}

pub fn inner_validate_delta<T>(
parameters: Parameters<'static>,
delta: StateDelta<'static>,
) -> Result<bool, ContractError>
where
T: EncodingAdapter + TypedContract,
ContractError: From<
<<T as EncodingAdapter>::ParametersEncoder as Encoder<
<T as EncodingAdapter>::Parameters,
>>::Error,
>,
ContractError: From<
<<T as EncodingAdapter>::DeltaEncoder as Encoder<<T as EncodingAdapter>::Delta>>::Error,
>,
{
let typed_params =
<<T as EncodingAdapter>::ParametersEncoder>::deserialize(parameters.as_ref())?;
let typed_delta = <<T as EncodingAdapter>::DeltaEncoder>::deserialize(delta.as_ref())?;
<T as TypedContract>::verify_delta(typed_params, typed_delta)
}

pub fn inner_update_state<T>(
parameters: Parameters<'static>,
state: State<'static>,
Expand Down
20 changes: 0 additions & 20 deletions rust/src/memory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -82,26 +82,6 @@ pub mod wasm_interface {
ContractInterfaceResult::from(result).into_raw()
}

pub fn inner_validate_delta<T: ContractInterface>(parameters: i64, delta: i64) -> i64 {
if let Err(e) = set_logger().map_err(|e| e.into_raw()) {
return e;
}
let parameters = unsafe {
let param_buf = &mut *(parameters as *mut super::buf::BufferBuilder);
let bytes =
&*std::ptr::slice_from_raw_parts(param_buf.start(), param_buf.bytes_written());
Parameters::from(bytes)
};
let delta = unsafe {
let delta_buf = &mut *(delta as *mut super::buf::BufferBuilder);
let bytes =
&*std::ptr::slice_from_raw_parts(delta_buf.start(), delta_buf.bytes_written());
StateDelta::from(bytes)
};
let result = <T as ContractInterface>::validate_delta(parameters, delta);
ContractInterfaceResult::from(result).into_raw()
}

pub fn inner_update_state<T: ContractInterface>(
parameters: i64,
state: i64,
Expand Down
Loading

0 comments on commit 89f0a4b

Please sign in to comment.