mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-03 09:29:46 +00:00
Add a binaries feature to the processor to reduce dependencies when used as a lib
processor isn't intended to be used as a library, yet serai-processor-tests does pull it in as a lib. This caused serai-processor-tests to need to compile rocksdb, which added multiple minutes to the compilation time.
This commit is contained in:
parent
b296be8515
commit
d60e007126
11 changed files with 23 additions and 26 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -7526,6 +7526,7 @@ dependencies = [
|
||||||
"serai-docker-tests",
|
"serai-docker-tests",
|
||||||
"serai-runtime",
|
"serai-runtime",
|
||||||
"sp-core",
|
"sp-core",
|
||||||
|
"sp-runtime",
|
||||||
"subxt",
|
"subxt",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
"tokio",
|
"tokio",
|
||||||
|
|
|
@ -39,7 +39,7 @@ env_logger = { version = "0.10", default-features = false, features = ["humantim
|
||||||
# Uses a single threaded runtime since this shouldn't ever be CPU-bound
|
# Uses a single threaded runtime since this shouldn't ever be CPU-bound
|
||||||
tokio = { version = "1", default-features = false, features = ["rt", "time", "macros"] }
|
tokio = { version = "1", default-features = false, features = ["rt", "time", "macros"] }
|
||||||
|
|
||||||
serai-db = { path = "../common/db", optional = true }
|
serai-db = { path = "../common/db", features = ["rocksdb"], optional = true }
|
||||||
|
|
||||||
serai-env = { path = "../common/env" }
|
serai-env = { path = "../common/env" }
|
||||||
|
|
||||||
|
@ -49,4 +49,4 @@ jsonrpsee = { version = "0.16", default-features = false, features = ["server"],
|
||||||
simple-request = { path = "../common/request", default-features = false }
|
simple-request = { path = "../common/request", default-features = false }
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
binaries = ["serai-db", "serai-db/rocksdb", "jsonrpsee"]
|
binaries = ["serai-db", "jsonrpsee"]
|
||||||
|
|
|
@ -46,7 +46,7 @@ RUN --mount=type=cache,target=/root/.cargo \
|
||||||
--mount=type=cache,target=/usr/local/cargo/git \
|
--mount=type=cache,target=/usr/local/cargo/git \
|
||||||
--mount=type=cache,target=/serai/target \
|
--mount=type=cache,target=/serai/target \
|
||||||
mkdir /serai/bin && \
|
mkdir /serai/bin && \
|
||||||
cargo build --release --features bitcoin -p serai-processor && \
|
cargo build --release --features "binaries bitcoin" -p serai-processor && \
|
||||||
mv /serai/target/release/serai-processor /serai/bin
|
mv /serai/target/release/serai-processor /serai/bin
|
||||||
FROM debian:bookworm-slim as image
|
FROM debian:bookworm-slim as image
|
||||||
|
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
cargo build --release --features bitcoin -p serai-processor && \
|
cargo build --release --features "binaries bitcoin" -p serai-processor && \
|
||||||
mv /serai/target/release/serai-processor /serai/bin
|
mv /serai/target/release/serai-processor /serai/bin
|
||||||
|
|
|
@ -46,7 +46,7 @@ RUN --mount=type=cache,target=/root/.cargo \
|
||||||
--mount=type=cache,target=/usr/local/cargo/git \
|
--mount=type=cache,target=/usr/local/cargo/git \
|
||||||
--mount=type=cache,target=/serai/target \
|
--mount=type=cache,target=/serai/target \
|
||||||
mkdir /serai/bin && \
|
mkdir /serai/bin && \
|
||||||
cargo build --release --features monero -p serai-processor && \
|
cargo build --release --features "binaries monero" -p serai-processor && \
|
||||||
mv /serai/target/release/serai-processor /serai/bin
|
mv /serai/target/release/serai-processor /serai/bin
|
||||||
FROM debian:bookworm-slim as image
|
FROM debian:bookworm-slim as image
|
||||||
|
|
||||||
|
|
|
@ -1,2 +1,2 @@
|
||||||
cargo build --release --features monero -p serai-processor && \
|
cargo build --release --features "binaries monero" -p serai-processor && \
|
||||||
mv /serai/target/release/serai-processor /serai/bin
|
mv /serai/target/release/serai-processor /serai/bin
|
||||||
|
|
|
@ -49,16 +49,16 @@ monero-serai = { path = "../coins/monero", default-features = false, features =
|
||||||
|
|
||||||
# Application
|
# Application
|
||||||
log = { version = "0.4", default-features = false, features = ["std"] }
|
log = { version = "0.4", default-features = false, features = ["std"] }
|
||||||
env_logger = { version = "0.10", default-features = false, features = ["humantime"] }
|
env_logger = { version = "0.10", default-features = false, features = ["humantime"], optional = true }
|
||||||
tokio = { version = "1", default-features = false, features = ["rt-multi-thread", "sync", "time", "macros"] }
|
tokio = { version = "1", default-features = false, features = ["rt-multi-thread", "sync", "time", "macros"] }
|
||||||
|
|
||||||
serai-db = { path = "../common/db", features = ["rocksdb"] }
|
serai-db = { path = "../common/db", features = ["rocksdb"], optional = true }
|
||||||
serai-env = { path = "../common/env" }
|
serai-env = { path = "../common/env", optional = true }
|
||||||
serai-client = { path = "../substrate/client", default-features = false }
|
serai-client = { path = "../substrate/client", default-features = false }
|
||||||
|
|
||||||
messages = { package = "serai-processor-messages", path = "./messages" }
|
messages = { package = "serai-processor-messages", path = "./messages", optional = true }
|
||||||
|
|
||||||
message-queue = { package = "serai-message-queue", path = "../message-queue" }
|
message-queue = { package = "serai-message-queue", path = "../message-queue", optional = true }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
futures = { version = "0.3", default-features = false }
|
futures = { version = "0.3", default-features = false }
|
||||||
|
@ -76,3 +76,5 @@ bitcoin = ["dep:secp256k1", "secp256k1", "bitcoin-serai", "serai-client/bitcoin"
|
||||||
|
|
||||||
ed25519 = ["dalek-ff-group", "frost/ed25519"]
|
ed25519 = ["dalek-ff-group", "frost/ed25519"]
|
||||||
monero = ["ed25519", "monero-serai", "serai-client/monero"]
|
monero = ["ed25519", "monero-serai", "serai-client/monero"]
|
||||||
|
|
||||||
|
binaries = ["env_logger", "serai-db", "serai-env", "messages", "message-queue"]
|
||||||
|
|
|
@ -12,9 +12,7 @@ use in_instructions_primitives::{Batch, SignedBatch};
|
||||||
use coins_primitives::OutInstructionWithBalance;
|
use coins_primitives::OutInstructionWithBalance;
|
||||||
use validator_sets_primitives::{ValidatorSet, KeyPair};
|
use validator_sets_primitives::{ValidatorSet, KeyPair};
|
||||||
|
|
||||||
#[derive(
|
#[derive(Clone, Copy, PartialEq, Eq, Debug, Zeroize, BorshSerialize, BorshDeserialize)]
|
||||||
Clone, Copy, PartialEq, Eq, Debug, Zeroize, Encode, Decode, BorshSerialize, BorshDeserialize,
|
|
||||||
)]
|
|
||||||
pub struct SubstrateContext {
|
pub struct SubstrateContext {
|
||||||
pub serai_time: u64,
|
pub serai_time: u64,
|
||||||
pub network_latest_finalized_block: BlockHash,
|
pub network_latest_finalized_block: BlockHash,
|
||||||
|
@ -239,9 +237,7 @@ pub mod coordinator {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(
|
#[derive(Clone, PartialEq, Eq, Debug, Zeroize, BorshSerialize, BorshDeserialize)]
|
||||||
Clone, PartialEq, Eq, Debug, Zeroize, Encode, Decode, BorshSerialize, BorshDeserialize,
|
|
||||||
)]
|
|
||||||
pub struct PlanMeta {
|
pub struct PlanMeta {
|
||||||
pub key: Vec<u8>,
|
pub key: Vec<u8>,
|
||||||
pub id: [u8; 32],
|
pub id: [u8; 32],
|
||||||
|
@ -261,7 +257,7 @@ pub mod coordinator {
|
||||||
pub mod substrate {
|
pub mod substrate {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
#[derive(Clone, PartialEq, Eq, Debug, Encode, Decode, BorshSerialize, BorshDeserialize)]
|
#[derive(Clone, PartialEq, Eq, Debug, BorshSerialize, BorshDeserialize)]
|
||||||
pub enum CoordinatorMessage {
|
pub enum CoordinatorMessage {
|
||||||
ConfirmKeyPair {
|
ConfirmKeyPair {
|
||||||
context: SubstrateContext,
|
context: SubstrateContext,
|
||||||
|
@ -287,9 +283,7 @@ pub mod substrate {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(
|
#[derive(Clone, PartialEq, Eq, Debug, Zeroize, BorshSerialize, BorshDeserialize)]
|
||||||
Clone, PartialEq, Eq, Debug, Zeroize, Encode, Decode, BorshSerialize, BorshDeserialize,
|
|
||||||
)]
|
|
||||||
pub enum ProcessorMessage {
|
pub enum ProcessorMessage {
|
||||||
Batch { batch: Batch },
|
Batch { batch: Batch },
|
||||||
SignedBatch { batch: SignedBatch },
|
SignedBatch { batch: SignedBatch },
|
||||||
|
|
|
@ -23,9 +23,10 @@ hex = "0.4"
|
||||||
scale = { package = "parity-scale-codec", version = "3" }
|
scale = { package = "parity-scale-codec", version = "3" }
|
||||||
scale-info = { version = "2", optional = true }
|
scale-info = { version = "2", optional = true }
|
||||||
|
|
||||||
|
sp-core = { git = "https://github.com/serai-dex/substrate" }
|
||||||
|
sp-runtime = { git = "https://github.com/serai-dex/substrate" }
|
||||||
serai-runtime = { path = "../runtime", version = "0.1" }
|
serai-runtime = { path = "../runtime", version = "0.1" }
|
||||||
|
|
||||||
sp-core = { git = "https://github.com/serai-dex/substrate" }
|
|
||||||
subxt = { version = "0.29", default-features = false, features = ["jsonrpsee-ws"], optional = true }
|
subxt = { version = "0.29", default-features = false, features = ["jsonrpsee-ws"], optional = true }
|
||||||
|
|
||||||
bitcoin = { version = "0.31", optional = true }
|
bitcoin = { version = "0.31", optional = true }
|
||||||
|
|
|
@ -168,15 +168,14 @@ impl Serai {
|
||||||
const TX_VERSION: u32 = 1;
|
const TX_VERSION: u32 = 1;
|
||||||
const EXTRINSIC_FORMAT_VERSION: u8 = 4;
|
const EXTRINSIC_FORMAT_VERSION: u8 = 4;
|
||||||
|
|
||||||
let era = subxt::config::substrate::Era::Immortal;
|
let era = sp_runtime::generic::Era::Immortal;
|
||||||
let extra = (era, Compact(nonce), tip);
|
let extra = (era, Compact(nonce), tip);
|
||||||
let genesis = self.0.genesis_hash();
|
let genesis = self.0.genesis_hash();
|
||||||
let mortality_checkpoint = genesis;
|
let mortality_checkpoint = genesis;
|
||||||
let mut signature_payload =
|
let mut signature_payload =
|
||||||
(call, extra, SPEC_VERSION, TX_VERSION, genesis, mortality_checkpoint).encode();
|
(call, extra, SPEC_VERSION, TX_VERSION, genesis, mortality_checkpoint).encode();
|
||||||
if signature_payload.len() > 256 {
|
if signature_payload.len() > 256 {
|
||||||
use subxt::config::Hasher;
|
signature_payload = sp_core::blake2_256(&signature_payload).to_vec();
|
||||||
signature_payload = BlakeTwo256::hash(&signature_payload).0.to_vec();
|
|
||||||
}
|
}
|
||||||
let signature = signer.sign(&signature_payload);
|
let signature = signer.sign(&signature_payload);
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ serai-primitives = { path = "../../primitives", default-features = false }
|
||||||
sp-runtime = { git = "https://github.com/serai-dex/substrate", default-features = false }
|
sp-runtime = { git = "https://github.com/serai-dex/substrate", default-features = false }
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
std = ["zeroize", "borsh?/std", "serde/std", "scale/std", "scale-info/std", "sp-runtime/std", "serai-primitives/std"]
|
std = ["zeroize", "borsh?/std", "serde?/std", "scale/std", "scale-info/std", "sp-runtime/std", "serai-primitives/std"]
|
||||||
borsh = ["dep:borsh", "serai-primitives/borsh"]
|
borsh = ["dep:borsh", "serai-primitives/borsh"]
|
||||||
serde = ["dep:serde", "serai-primitives/serde"]
|
serde = ["dep:serde", "serai-primitives/serde"]
|
||||||
default = ["std"]
|
default = ["std"]
|
||||||
|
|
Loading…
Reference in a new issue