diff --git a/consensus/src/user/provisioners.rs b/consensus/src/user/provisioners.rs index a21932023a..934941f6d1 100644 --- a/consensus/src/user/provisioners.rs +++ b/consensus/src/user/provisioners.rs @@ -6,6 +6,8 @@ use crate::user::sortition; use crate::user::stake::Stake; +use execution_core::dusk; +use execution_core::stake::MINIMUM_STAKE; use node_data::bls::{PublicKey, PublicKeyBytes}; use node_data::StepName; @@ -16,8 +18,7 @@ use std::mem; use super::committee::Committee; -pub const DUSK: u64 = 1_000_000_000; -const MINIMUM_STAKE: u64 = 1_000 * DUSK; +pub const DUSK: u64 = dusk(1.0); #[derive(Clone, Debug)] pub struct Provisioners { diff --git a/contracts/host_fn/Cargo.toml b/contracts/host_fn/Cargo.toml index e6c4bcfb68..ffa5557de9 100644 --- a/contracts/host_fn/Cargo.toml +++ b/contracts/host_fn/Cargo.toml @@ -9,5 +9,4 @@ crate-type = ["cdylib", "rlib"] [dependencies] execution-core = { version = "0.1.0", path = "../../execution-core" } dusk-bytes = "0.1" -dusk-plonk = { version = "0.16", default-features = false, features = ["rkyv-impl", "alloc"] } rusk-abi = { version = "0.13.0-rc", path = "../../rusk-abi" } diff --git a/contracts/license/Cargo.toml b/contracts/license/Cargo.toml index 29f643d2ff..e38842b6aa 100644 --- a/contracts/license/Cargo.toml +++ b/contracts/license/Cargo.toml @@ -7,11 +7,10 @@ edition = "2021" crate-type = ["cdylib", "rlib"] [dependencies] -execution-core = { version = "0.1.0", path = "../../execution-core" } +execution-core = { version = "0.1.0", path = "../../execution-core", features = ["zk"] } dusk-bytes = "0.1" dusk-poseidon = "0.39" poseidon-merkle = { version = "0.6", features = ["rkyv-impl", "zk", "size_32"] } -dusk-plonk = { version = "0.19", default-features = false, features = ["rkyv-impl", "alloc"] } rkyv = { version = "0.7", default-features = false, features = ["size_32"] } bytecheck = { version = "0.6", default-features = false } diff --git a/contracts/license/src/license_types.rs b/contracts/license/src/license_types.rs index 2e34a1db1e..1b72090cd3 100644 --- a/contracts/license/src/license_types.rs +++ b/contracts/license/src/license_types.rs @@ -9,9 +9,8 @@ use alloc::vec::Vec; use bytecheck::CheckBytes; use rkyv::{Archive, Deserialize, Serialize}; -use execution_core::BlsScalar; +use execution_core::{plonk::Proof, BlsScalar}; -use dusk_plonk::prelude::Proof; use poseidon_merkle::Item; #[allow(dead_code)] diff --git a/contracts/license/tests/license.rs b/contracts/license/tests/license.rs index 942f1296c0..2a37fe02a4 100644 --- a/contracts/license/tests/license.rs +++ b/contracts/license/tests/license.rs @@ -9,7 +9,6 @@ extern crate alloc; use std::ops::Range; use std::sync::mpsc; -use dusk_plonk::prelude::*; use dusk_poseidon::{Domain, Hash}; use ff::Field; use poseidon_merkle::Opening; @@ -21,8 +20,9 @@ use zk_citadel::license::{ }; use execution_core::{ + plonk::{Compiler, PublicParameters}, transfer::phoenix::{PublicKey, SecretKey, StealthAddress, ViewKey}, - BlsScalar, ContractId, JubJubAffine, GENERATOR_EXTENDED, + BlsScalar, ContractId, JubJubAffine, JubJubScalar, GENERATOR_EXTENDED, }; use rusk_abi::{ContractData, Session}; use rusk_profile::get_common_reference_string; diff --git a/contracts/stake/Cargo.toml b/contracts/stake/Cargo.toml index 7dd5d01c0d..a8e4ab3f32 100644 --- a/contracts/stake/Cargo.toml +++ b/contracts/stake/Cargo.toml @@ -9,7 +9,6 @@ crate-type = ["cdylib", "rlib"] [dependencies] execution-core = { version = "0.1.0", path = "../../execution-core" } dusk-bytes = "0.1" -dusk-plonk = { version = "0.19", default-features = false, features = ["rkyv-impl", "alloc"] } rkyv = { version = "0.7", default-features = false, features = ["size_32"] } [target.'cfg(target_family = "wasm")'.dependencies] @@ -18,7 +17,7 @@ rusk-abi = { version = "0.13.0-rc", path = "../../rusk-abi" } [dev-dependencies] rusk-profile = { version = "0.6", path = "../../rusk-profile" } rusk-abi = { version = "0.13.0-rc", path = "../../rusk-abi", default-features = false, features = ["host"] } -phoenix-circuits = "0.2.1-rc" +execution-core = { version = "0.1.0", path = "../../execution-core", features = ["zk"] } rkyv = { version = "0.7", default-features = false, features = ["size_32"] } hex = "0.4" rand = "0.8" diff --git a/contracts/stake/src/lib.rs b/contracts/stake/src/lib.rs index dba88e1d8a..1237da3170 100644 --- a/contracts/stake/src/lib.rs +++ b/contracts/stake/src/lib.rs @@ -10,14 +10,11 @@ extern crate alloc; -use execution_core::{dusk, transfer::TRANSFER_CONTRACT, Dusk}; +use execution_core::transfer::TRANSFER_CONTRACT; mod state; use state::StakeState; -/// The minimum amount of Dusk one can stake. -pub const MINIMUM_STAKE: Dusk = dusk(1_000.0); - static mut STATE: StakeState = StakeState::new(); // Transactions diff --git a/contracts/stake/src/state.rs b/contracts/stake/src/state.rs index 84cb602df5..62c61f4a3c 100644 --- a/contracts/stake/src/state.rs +++ b/contracts/stake/src/state.rs @@ -13,7 +13,7 @@ use execution_core::{ signatures::bls::PublicKey as BlsPublicKey, stake::{ next_epoch, Stake, StakeAmount, StakeData, StakeEvent, Withdraw, EPOCH, - STAKE_CONTRACT, STAKE_WARNINGS, + MINIMUM_STAKE, STAKE_CONTRACT, STAKE_WARNINGS, }, transfer::TRANSFER_CONTRACT, }; diff --git a/contracts/stake/tests/common/utils.rs b/contracts/stake/tests/common/utils.rs index 9eb5b78fb5..32d0c8b073 100644 --- a/contracts/stake/tests/common/utils.rs +++ b/contracts/stake/tests/common/utils.rs @@ -7,26 +7,25 @@ use std::sync::mpsc; use dusk_bytes::Serializable; -use dusk_plonk::prelude::*; use ff::Field; -use phoenix_circuits::transaction::{TxCircuit, TxInputNote, TxOutputNote}; use poseidon_merkle::Opening as PoseidonOpening; use rand::rngs::StdRng; use rand::SeedableRng; use execution_core::{ + plonk::{Prover, Verifier}, signatures::schnorr::SecretKey as SchnorrSecretKey, transfer::{ contract_exec::{ContractCall, ContractExec}, phoenix::{ value_commitment, Fee, Note, Payload as PhoenixPayload, PublicKey as PhoenixPublicKey, SecretKey as PhoenixSecretKey, - Sender, TreeLeaf, TxSkeleton, ViewKey as PhoenixViewKey, - NOTES_TREE_DEPTH, + Sender, TreeLeaf, TxCircuit, TxInputNote, TxOutputNote, TxSkeleton, + ViewKey as PhoenixViewKey, NOTES_TREE_DEPTH, }, Transaction, TRANSFER_CONTRACT, }, - ContractError, JubJubScalar, + BlsScalar, ContractError, JubJubAffine, JubJubScalar, }; use rusk_abi::{CallReceipt, PiecrustError, Session}; diff --git a/contracts/transfer/Cargo.toml b/contracts/transfer/Cargo.toml index 640b18edfa..97b4d62ee3 100644 --- a/contracts/transfer/Cargo.toml +++ b/contracts/transfer/Cargo.toml @@ -10,7 +10,6 @@ crate-type = ["cdylib", "rlib"] execution-core = { version = "0.1.0", path = "../../execution-core" } dusk-bytes = "0.1" poseidon-merkle = { version = "0.6", features = ["rkyv-impl"] } -dusk-plonk = { version = "0.19", default-features = false, features = ["rkyv-impl", "alloc"] } rkyv = { version = "0.7", default-features = false, features = ["size_32"] } ringbuffer = "0.15" @@ -21,7 +20,7 @@ rusk-abi = { version = "0.13.0-rc", path = "../../rusk-abi" } [dev-dependencies] rusk-profile = { version = "0.6", path = "../../rusk-profile" } rusk-abi = { version = "0.13.0-rc", path = "../../rusk-abi", default-features = false, features = ["host"] } -phoenix-circuits = "0.2.1-rc" +execution-core = { version = "0.1.0", path = "../../execution-core", features = ["zk"] } rkyv = { version = "0.7", default-features = false, features = ["size_32"] } bytecheck = { version = "0.6", default-features = false } hex = "0.4" diff --git a/contracts/transfer/tests/common.rs b/contracts/transfer/tests/common.rs index 85a5a99c73..948b0b10b2 100644 --- a/contracts/transfer/tests/common.rs +++ b/contracts/transfer/tests/common.rs @@ -7,6 +7,7 @@ use std::sync::mpsc; use execution_core::{ + plonk::{Prover, Verifier}, signatures::{ bls::{PublicKey as AccountPublicKey, SecretKey as AccountSecretKey}, schnorr::SecretKey as SchnorrSecretKey, @@ -20,18 +21,17 @@ use execution_core::{ phoenix::{ value_commitment, Fee, Note, Payload as PhoenixPayload, PublicKey, SecretKey, Sender, Transaction as PhoenixTransaction, TreeLeaf, - TxSkeleton, ViewKey, NOTES_TREE_DEPTH, + TxCircuit, TxInputNote, TxOutputNote, TxSkeleton, ViewKey, + NOTES_TREE_DEPTH, }, Transaction, TRANSFER_CONTRACT, }, - BlsScalar, ContractError, ContractId, JubJubScalar, + BlsScalar, ContractError, ContractId, JubJubAffine, JubJubScalar, }; use rusk_abi::{CallReceipt, PiecrustError, Session}; use dusk_bytes::Serializable; -use dusk_plonk::prelude::*; use ff::Field; -use phoenix_circuits::transaction::{TxCircuit, TxInputNote, TxOutputNote}; use poseidon_merkle::Opening as PoseidonOpening; use rand::rngs::StdRng; use rand::SeedableRng; diff --git a/execution-core/CHANGELOG.md b/execution-core/CHANGELOG.md index 749cd0f514..6341890004 100644 --- a/execution-core/CHANGELOG.md +++ b/execution-core/CHANGELOG.md @@ -37,7 +37,8 @@ signatures::{ PublicKey, SecretKey, Signature, - APK as AggPublicKey, + MutlisigPublicKey, + MultisigSignature }; schnorr::{ PublicKey, @@ -104,6 +105,31 @@ stake::{ }; licence::LICENSE_CONTRACT; ``` +- under the `"zk"` feature: +```rust +plonk::{ + pub use dusk_plonk::{ + Circuit, + Compiler, + Composer, + Constraint, + Error, + Proof, + Prover, + PublicParameters, + Verifier, + Witness, + WitnessPoint, + } +}; +transfer::phoenix::{ + pub use phoenix_circuits{ + TxCircuit, + TxInputNote, + TxOutputNote, + }; +}; +``` [Unreleased]: https://github.com/dusk-network/rusk/compare/execution-core-0.1.0...HEAD [0.1.0]: https://github.com/dusk-network/dusk-abi/releases/tag/execution-core-0.1.0 diff --git a/execution-core/Cargo.toml b/execution-core/Cargo.toml index 6d3a3b75b5..ffc203aa67 100644 --- a/execution-core/Cargo.toml +++ b/execution-core/Cargo.toml @@ -17,9 +17,19 @@ bytecheck = { version = "0.6", default-features = false } rand = { version = "0.8", default-features = false } ff = { version = "0.13", default-features = false } +# zk-dependencies +dusk-plonk = { version = "0.19", default-features = false, features = ["rkyv-impl", "alloc"], optional = true } +phoenix-circuits = { version = "0.2.1-rc", optional = true } + [dev-dependencies] rand = "0.8" [features] # It enables parallel thread aggregation of BlsPublicKey parallel = ["bls12_381-bls/parallel"] + +# It enables zk-capabilities +zk = ["dusk-plonk", "phoenix-circuits"] + +# Enables std feature for dusk-plonk +std = ["dusk-plonk/std"] diff --git a/execution-core/src/lib.rs b/execution-core/src/lib.rs index 1feccfde40..1847ad9af8 100644 --- a/execution-core/src/lib.rs +++ b/execution-core/src/lib.rs @@ -31,7 +31,7 @@ pub use dusk_jubjub::{ /// Signatures used in the Dusk protocol. pub mod signatures { - /// Types for the bls-signature scheme. + /// Types for the bls-signature scheme operating on the `bls12_381` curve. pub mod bls { pub use bls12_381_bls::{ Error, MultisigPublicKey, MultisigSignature, PublicKey, SecretKey, @@ -39,7 +39,7 @@ pub mod signatures { }; } - /// Types for the schnorr-signature scheme. + /// Types for the schnorr-signature scheme operating on the `jubjub` curve. pub mod schnorr { pub use jubjub_schnorr::{ PublicKey, SecretKey, Signature, SignatureDouble, @@ -52,6 +52,16 @@ pub use piecrust_uplink::{ CONTRACT_ID_BYTES, }; +/// Types and traits to create plonk circuits and generate and verify plonk +/// proofs. +#[cfg(feature = "zk")] +pub mod plonk { + pub use dusk_plonk::prelude::{ + Circuit, Compiler, Composer, Constraint, Error, Proof, Prover, + PublicParameters, Verifier, Witness, WitnessPoint, + }; +} + #[inline] const fn reserved(b: u8) -> ContractId { let mut bytes = [0u8; CONTRACT_ID_BYTES]; diff --git a/execution-core/src/stake.rs b/execution-core/src/stake.rs index 3d5b722542..2fcabc2694 100644 --- a/execution-core/src/stake.rs +++ b/execution-core/src/stake.rs @@ -21,6 +21,8 @@ use crate::{ ContractId, }; +use crate::{dusk, Dusk}; + /// ID of the genesis stake contract pub const STAKE_CONTRACT: ContractId = crate::reserved(0x2); @@ -188,6 +190,9 @@ pub struct StakeEvent { pub receiver: Option, } +/// The minimum amount of Dusk one can stake. +pub const MINIMUM_STAKE: Dusk = dusk(1_000.0); + /// The representation of a public key's stake. /// /// A user can stake for a particular `amount` larger in value than the diff --git a/execution-core/src/transfer/phoenix.rs b/execution-core/src/transfer/phoenix.rs index 7f5769ba64..011132cc59 100644 --- a/execution-core/src/transfer/phoenix.rs +++ b/execution-core/src/transfer/phoenix.rs @@ -29,6 +29,9 @@ pub use phoenix_core::{ StealthAddress, TxSkeleton, ViewKey, NOTE_VAL_ENC_SIZE, OUTPUT_NOTES, }; +#[cfg(feature = "zk")] +pub use phoenix_circuits::transaction::{TxCircuit, TxInputNote, TxOutputNote}; + /// Label used for the ZK transcript initialization. Must be the same for prover /// and verifier. pub const TRANSCRIPT_LABEL: &[u8] = b"dusk-network"; @@ -46,7 +49,7 @@ pub struct Fee { pub gas_price: u64, /// Address to send the remainder note pub stealth_address: StealthAddress, - /// Sender to use for the remainder + /// Sender to use for the remainder note pub sender: Sender, } diff --git a/node/src/chain.rs b/node/src/chain.rs index a648077013..d25e4ad8ca 100644 --- a/node/src/chain.rs +++ b/node/src/chain.rs @@ -26,6 +26,7 @@ pub use header_validation::verify_att; use node_data::ledger::{to_str, BlockWithLabel, Label}; use node_data::message::AsyncQueue; use node_data::message::{Payload, Topics}; +use std::ops::Deref; use std::sync::Arc; use std::time::Duration; use tokio::sync::RwLock; @@ -62,7 +63,9 @@ impl db: Arc>, vm: Arc>, ) -> anyhow::Result<()> { - let tip = Self::load_tip(db.clone(), vm.clone()).await?; + let tip = + Self::load_tip(db.read().await.deref(), vm.read().await.deref()) + .await?; let state_hash = tip.inner().header().state_hash; let provisioners_list = vm.read().await.get_provisioners(state_hash)?; @@ -73,8 +76,8 @@ impl tip, provisioners_list, db, - network.clone(), - vm.clone(), + network, + vm, self.max_consensus_queue_size, ) .await?; @@ -254,12 +257,9 @@ impl ChainSrv { /// Panics /// /// If register entry is read but block is not found. - async fn load_tip( - db: Arc>, - vm: Arc>, - ) -> Result { - let stored_block = db.read().await.update(|t| { - Ok(t.op_read(MD_HASH_KEY)?.and_then(|tip_hash| { + async fn load_tip(db: &DB, vm: &VM) -> Result { + let stored_block = db.view(|t| { + anyhow::Ok(t.op_read(MD_HASH_KEY)?.and_then(|tip_hash| { t.fetch_block(&tip_hash[..]) .expect("block to be found if metadata is set") })) @@ -268,8 +268,6 @@ impl ChainSrv { let block = match stored_block { Some(blk) => { let (_, label) = db - .read() - .await .view(|t| { t.fetch_block_label_by_height(blk.header().height) })? @@ -280,9 +278,9 @@ impl ChainSrv { None => { // Lack of register record means the loaded database is // either malformed or empty. - let state = vm.read().await.get_state_root()?; + let state = vm.get_state_root()?; let genesis_blk = genesis::generate_state(state); - db.write().await.update(|t| { + db.update(|t| { // Persist genesis block t.store_block( genesis_blk.header(), diff --git a/node/src/databroker.rs b/node/src/databroker.rs index bb91811de6..3377721973 100644 --- a/node/src/databroker.rs +++ b/node/src/databroker.rs @@ -97,15 +97,6 @@ impl DataBrokerSrv { impl LongLivedService for DataBrokerSrv { - async fn initialize( - &mut self, - _network: Arc>, - _db: Arc>, - _vm: Arc>, - ) -> anyhow::Result<()> { - Ok(()) - } - async fn execute( &mut self, network: Arc>, diff --git a/node/src/lib.rs b/node/src/lib.rs index 53a0680ea3..240a6ccbdb 100644 --- a/node/src/lib.rs +++ b/node/src/lib.rs @@ -96,12 +96,15 @@ pub trait Network: Send + Sync + 'static { pub trait LongLivedService: Send + Sync { + #[allow(unused_variables)] async fn initialize( &mut self, network: Arc>, database: Arc>, vm: Arc>, - ) -> anyhow::Result<()>; + ) -> anyhow::Result<()> { + Ok(()) + } async fn execute( &mut self, @@ -123,16 +126,6 @@ pub trait LongLivedService: Ok(()) } - async fn add_filter( - &self, - topic: u8, - filter_fn: BoxedFilter, - network: &Arc>, - ) -> anyhow::Result<()> { - network.write().await.add_filter(topic, filter_fn).await?; - Ok(()) - } - /// Returns service name. fn name(&self) -> &'static str; } diff --git a/node/src/mempool.rs b/node/src/mempool.rs index a21d4e7760..45c1e7ef72 100644 --- a/node/src/mempool.rs +++ b/node/src/mempool.rs @@ -55,29 +55,10 @@ impl MempoolSrv { } } -pub struct TxFilter {} -impl crate::Filter for TxFilter { - fn filter(&mut self, _msg: &Message) -> anyhow::Result<()> { - // TODO: Ensure transaction does not exist in the mempool state - // TODO: Ensure transaction does not exist in blockchain - // TODO: Check Nullifier - Ok(()) - } -} - #[async_trait] impl LongLivedService for MempoolSrv { - async fn initialize( - &mut self, - _network: Arc>, - _db: Arc>, - _vm: Arc>, - ) -> anyhow::Result<()> { - Ok(()) - } - async fn execute( &mut self, network: Arc>, @@ -92,16 +73,6 @@ impl ) .await?; - // Add a filter that will discard any transactions invalid to the actual - // mempool, blockchain state. - LongLivedService::::add_filter( - self, - Topics::Tx.into(), - Box::new(TxFilter {}), - &network, - ) - .await?; - loop { if let Ok(msg) = self.inbound.recv().await { match &msg.payload { diff --git a/node/src/telemetry.rs b/node/src/telemetry.rs index ae6f26007a..9e9dc20593 100644 --- a/node/src/telemetry.rs +++ b/node/src/telemetry.rs @@ -29,15 +29,6 @@ impl "telemetry" } - async fn initialize( - &mut self, - _network: Arc>, - _db: Arc>, - _vm: Arc>, - ) -> anyhow::Result<()> { - Ok(()) - } - /// Initialize and spawn Prometheus Exporter and Recorder async fn execute( &mut self, diff --git a/rusk-abi/Cargo.toml b/rusk-abi/Cargo.toml index 004a97775a..1f3960e256 100644 --- a/rusk-abi/Cargo.toml +++ b/rusk-abi/Cargo.toml @@ -10,17 +10,15 @@ exclude = [".github/workflows/ci.yml", ".gitignore"] [dependencies] blake2b_simd = { version = "1", default-features = false } -cfg-if = "1" dusk-poseidon = "0.39" dusk-bytes = "0.1" bytecheck = { version = "0.6", default-features = false } -dusk-plonk = { version = "0.19", default-features = false, features = ["rkyv-impl", "alloc"] } piecrust-uplink = { version = "0.16" } piecrust = { version = "0.23", optional = true } -execution-core = { version = "0.1.0", path = "../execution-core" } +execution-core = { version = "0.1.0", path = "../execution-core", features = ["zk"] } # These are patches since these crates don't seem to like semver. rkyv = { version = "=0.7.39", default-features = false, features = ["size_32"] } diff --git a/rusk-abi/src/host.rs b/rusk-abi/src/host.rs index ab37cafe6a..a6fb2b4ff4 100644 --- a/rusk-abi/src/host.rs +++ b/rusk-abi/src/host.rs @@ -8,9 +8,9 @@ use alloc::vec::Vec; use std::path::{Path, PathBuf}; use dusk_bytes::DeserializableSlice; -use dusk_plonk::prelude::{Proof, Verifier}; use dusk_poseidon::{Domain, Hash as PoseidonHash}; use execution_core::{ + plonk::{Proof, Verifier}, signatures::{ bls::{PublicKey as BlsPublicKey, Signature as BlsSignature}, schnorr::{ diff --git a/rusk-abi/tests/lib.rs b/rusk-abi/tests/lib.rs index 0a265a2b39..877197aadf 100644 --- a/rusk-abi/tests/lib.rs +++ b/rusk-abi/tests/lib.rs @@ -12,8 +12,11 @@ use std::sync::OnceLock; use rand_core::OsRng; use dusk_bytes::{ParseHexStr, Serializable}; -use dusk_plonk::prelude::*; use execution_core::{ + plonk::{ + Circuit, Compiler, Composer, Constraint, Error as PlonkError, + PublicParameters, + }, signatures::{ bls::{PublicKey as BlsPublicKey, SecretKey as BlsSecretKey}, schnorr::{ @@ -231,7 +234,7 @@ impl TestCircuit { } impl Circuit for TestCircuit { - fn circuit(&self, composer: &mut Composer) -> Result<(), Error> { + fn circuit(&self, composer: &mut Composer) -> Result<(), PlonkError> { // append 3 gates that always evaluate to true let a = composer.append_witness(self.a); diff --git a/rusk-prover/Cargo.toml b/rusk-prover/Cargo.toml index 9d65a2d6d0..49a090914b 100644 --- a/rusk-prover/Cargo.toml +++ b/rusk-prover/Cargo.toml @@ -6,20 +6,18 @@ autobins = false [dependencies] dusk-bytes = { version = "0.1" } -dusk-plonk = { version = "0.19", default-features = false } poseidon-merkle = { version = "0.6", features = ["rkyv-impl"] } rand_core = "0.6" rkyv = { version = "0.7", default-features = false, features = ["size_32"] } bytecheck = { version = "0.6", default-features = false } -execution-core = { version = "0.1.0", path = "../execution-core" } +execution-core = { version = "0.1.0", path = "../execution-core", features = ["zk"] } ## feature local_prover once_cell = { version = "1.9", optional = true } rand = { version = "0.8", optional = true } rusk-profile = { version = "0.6", path = "../rusk-profile", optional = true } -phoenix-circuits = { version = "0.2.1-rc", optional = true } [dev-dependencies] hex = "0.4" @@ -30,11 +28,11 @@ rand = "0.8" default = ["local_prover"] local_prover = [ "once_cell", - "dusk-plonk/std", "rand", "rusk-profile", - "phoenix-circuits", "std", ] no_random = [] -std = [] +std = [ + "execution-core/std" +] diff --git a/rusk-prover/src/prover.rs b/rusk-prover/src/prover.rs index 983c3035e2..81e9069c3e 100644 --- a/rusk-prover/src/prover.rs +++ b/rusk-prover/src/prover.rs @@ -9,7 +9,7 @@ mod execute; use crate::{ProverError, ProverResult}; use dusk_bytes::Serializable; -use dusk_plonk::prelude::Prover as PlonkProver; +use execution_core::plonk::Prover as PlonkProver; use once_cell::sync::Lazy; #[cfg(not(feature = "no_random"))] @@ -18,8 +18,6 @@ use rand::rngs::OsRng; #[cfg(feature = "no_random")] use rand::{rngs::StdRng, SeedableRng}; -use dusk_plonk::prelude::*; - #[derive(Debug, Default)] pub struct LocalProver; @@ -38,7 +36,7 @@ pub fn fetch_prover(circuit_name: &str) -> PlonkProver { panic!("there should be a prover key stored for {}", circuit_name) }); - Prover::try_from_bytes(pk).expect("Prover key is expected to by valid") + PlonkProver::try_from_bytes(pk).expect("Prover key is expected to by valid") } #[cfg(test)] diff --git a/rusk-prover/src/prover/execute.rs b/rusk-prover/src/prover/execute.rs index c94b28b6d6..b2ff210076 100644 --- a/rusk-prover/src/prover/execute.rs +++ b/rusk-prover/src/prover/execute.rs @@ -6,10 +6,13 @@ use super::*; -use execution_core::transfer::phoenix::{ - value_commitment, Sender, NOTES_TREE_DEPTH, +use execution_core::{ + transfer::phoenix::{ + value_commitment, Sender, TxCircuit, TxInputNote, TxOutputNote, + NOTES_TREE_DEPTH, + }, + JubJubAffine, }; -use phoenix_circuits::transaction::{TxCircuit, TxInputNote, TxOutputNote}; use rand::{CryptoRng, RngCore}; use crate::prover::fetch_prover; diff --git a/rusk-prover/src/tx.rs b/rusk-prover/src/tx.rs index 13e5c721e1..92f94ccc7c 100644 --- a/rusk-prover/src/tx.rs +++ b/rusk-prover/src/tx.rs @@ -10,8 +10,8 @@ use alloc::vec::Vec; use dusk_bytes::{ DeserializableSlice, Error as BytesError, Serializable, Write, }; -use dusk_plonk::prelude::Proof; use execution_core::{ + plonk::Proof, signatures::schnorr::{ Signature as SchnorrSignature, SignatureDouble as SchnorrSignatureDouble, diff --git a/rusk-recovery/Cargo.toml b/rusk-recovery/Cargo.toml index 755b4a434d..d02cbd857e 100644 --- a/rusk-recovery/Cargo.toml +++ b/rusk-recovery/Cargo.toml @@ -25,12 +25,11 @@ flate2 = "1" tar = "0.4" cargo_toml = "0.15" -phoenix-circuits = "0.2.1-rc" license-circuits = { version = "0.1", path = "../circuits/license" } rusk-profile = { version = "0.6", path = "../rusk-profile" } rusk-abi = { version = "0.13.0-rc", path = "../rusk-abi", default-features = false, features = ["host"] } -execution-core = { version = "0.1.0", path = "../execution-core" } +execution-core = { version = "0.1.0", path = "../execution-core", features = ["zk"] } serde_derive = { version = "1", optional = true } serde = { version = "1", optional = true } diff --git a/rusk-recovery/src/keys.rs b/rusk-recovery/src/keys.rs index 403c4e9fc5..34f4fbf370 100644 --- a/rusk-recovery/src/keys.rs +++ b/rusk-recovery/src/keys.rs @@ -5,8 +5,10 @@ // Copyright (c) DUSK NETWORK. All rights reserved. use crate::Theme; -use dusk_plonk::prelude::{Compiler, PublicParameters}; -use execution_core::transfer::phoenix::TRANSCRIPT_LABEL; +use execution_core::{ + plonk::{Compiler, PublicParameters}, + transfer::phoenix::TRANSCRIPT_LABEL, +}; use once_cell::sync::Lazy; use rand::rngs::StdRng; use rand::SeedableRng; diff --git a/rusk-recovery/src/keys/circuits.rs b/rusk-recovery/src/keys/circuits.rs index 0e21dc367c..5e1aab7dae 100644 --- a/rusk-recovery/src/keys/circuits.rs +++ b/rusk-recovery/src/keys/circuits.rs @@ -7,13 +7,12 @@ use std::io::{self, ErrorKind}; use cargo_toml::{Dependency, Manifest}; -use dusk_plonk::prelude::Circuit; use tracing::info; -use execution_core::transfer::phoenix::NOTES_TREE_DEPTH; +use execution_core::plonk::Circuit; +use execution_core::transfer::phoenix::{TxCircuit, NOTES_TREE_DEPTH}; use license_circuits::LicenseCircuit; -use phoenix_circuits::transaction::TxCircuit; type ExecuteCircuitOneTwo = TxCircuit; type ExecuteCircuitTwoTwo = TxCircuit; diff --git a/rusk/Cargo.toml b/rusk/Cargo.toml index d2d5b6b83e..3caac8609b 100644 --- a/rusk/Cargo.toml +++ b/rusk/Cargo.toml @@ -43,7 +43,6 @@ blake2b_simd = { version = "1", default-features = false } poseidon-merkle = { version = "0.6", features = ["rkyv-impl", "size_32"] } sha3 = "0.10" -dusk-plonk = "0.19" dusk-bytes = "0.1" kadcast = "0.6.0-rc" pin-project = "1" @@ -59,7 +58,7 @@ tokio-rustls = "0.25" rustls-pemfile = "2" async-trait = "0.1" -execution-core = { version = "0.1.0", path = "../execution-core" } +execution-core = { version = "0.1.0", path = "../execution-core", features = ["zk"] } rusk-profile = { version = "0.6", path = "../rusk-profile" } rusk-abi = { version = "0.13.0-rc", path = "../rusk-abi", default-features = false, features = ["host"] } rusk-prover = { version = "0.3", path = "../rusk-prover", optional = true } diff --git a/rusk/src/lib/chain.rs b/rusk/src/lib/chain.rs index e65ace9dbc..cf58aa484d 100644 --- a/rusk/src/lib/chain.rs +++ b/rusk/src/lib/chain.rs @@ -21,8 +21,6 @@ use rusk_abi::VM; use crate::http::RuesEvent; -pub const MINIMUM_STAKE: Dusk = dusk(1000.0); - #[derive(Debug, Clone, Copy)] pub struct RuskTip { pub current: [u8; 32], diff --git a/rusk/tests/common/wallet.rs b/rusk/tests/common/wallet.rs index bd7ad2b9fd..5e514df10b 100644 --- a/rusk/tests/common/wallet.rs +++ b/rusk/tests/common/wallet.rs @@ -11,8 +11,8 @@ use std::sync::{Arc, RwLock}; use crate::common::block::Block as BlockAwait; use dusk_bytes::{DeserializableSlice, Serializable}; -use dusk_plonk::prelude::Proof; use execution_core::{ + plonk::Proof, signatures::bls::PublicKey as BlsPublicKey, stake::StakeData, transfer::{ diff --git a/rusk/tests/services/stake.rs b/rusk/tests/services/stake.rs index 0648822309..5dbf9e8cd8 100644 --- a/rusk/tests/services/stake.rs +++ b/rusk/tests/services/stake.rs @@ -7,6 +7,7 @@ use std::path::Path; use std::sync::{Arc, RwLock}; +use execution_core::stake::MINIMUM_STAKE; use execution_core::{ dusk, signatures::bls::PublicKey as BlsPublicKey, @@ -15,7 +16,6 @@ use execution_core::{ }; use rand::prelude::*; use rand::rngs::StdRng; -use rusk::node::MINIMUM_STAKE; use rusk::{Result, Rusk}; use std::collections::HashMap; use tempfile::tempdir; diff --git a/test-wallet/Cargo.toml b/test-wallet/Cargo.toml index 3220d0cc56..570e82861e 100644 --- a/test-wallet/Cargo.toml +++ b/test-wallet/Cargo.toml @@ -12,7 +12,6 @@ sha2 = { version = "^0.10", default-features = false } dusk-bytes = "^0.1" dusk-poseidon = { version = "0.39", default-features = false } poseidon-merkle = { version = "0.6", features = ["rkyv-impl"] } -dusk-plonk = { version = "0.19", default-features = false } rkyv = { version = "0.7", default-features = false } rusk-prover = { version = "0.3.0", path = "../rusk-prover", default-features = false } ff = { version = "0.13", default-features = false }