mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-09 04:19:33 +00:00
899a9604e1
* Move pallet-asset-conversion * update licensing * initial integration * Integrate Currency & Assets types * integrate liquidity tokens * fmt * integrate dex pallet tests * fmt * compilation error fixes * integrate dex benchmarks * fmt * cargo clippy * replace all occurrences of "asset" with "coin" * add the actual add liq/swap logic to in-instructions * add client side & tests * fix deny * Lint and changes - Renames InInstruction::AddLiquidity to InInstruction::SwapAndAddLiquidity - Makes create_pool an internal function - Makes dex-pallet exclusively create pools against a native coin - Removes various fees - Adds new crates to GH workflow * Fix rebase artifacts * Correct other rebase artifact * Correct CI specification for liquidity-tokens * Correct primitives' test to the standardized pallet account scheme --------- Co-authored-by: Luke Parker <lukeparker5132@gmail.com>
134 lines
3.3 KiB
Rust
134 lines
3.3 KiB
Rust
#![cfg_attr(docsrs, feature(doc_cfg))]
|
|
#![cfg_attr(docsrs, feature(doc_auto_cfg))]
|
|
#![cfg_attr(not(feature = "std"), no_std)]
|
|
|
|
#[cfg(feature = "std")]
|
|
use zeroize::Zeroize;
|
|
|
|
use serde::{Serialize, Deserialize};
|
|
|
|
use scale::{Encode, Decode, MaxEncodedLen};
|
|
use scale_info::TypeInfo;
|
|
|
|
use sp_application_crypto::sr25519::Signature;
|
|
|
|
#[cfg(not(feature = "std"))]
|
|
use sp_std::vec::Vec;
|
|
use sp_runtime::RuntimeDebug;
|
|
|
|
#[rustfmt::skip]
|
|
use serai_primitives::{BlockHash, Balance, NetworkId, SeraiAddress, ExternalAddress, system_address};
|
|
|
|
mod shorthand;
|
|
pub use shorthand::*;
|
|
|
|
pub const MAX_BATCH_SIZE: usize = 25_000; // ~25kb
|
|
|
|
// This is the account which will be the origin for any dispatched `InInstruction`s.
|
|
pub const IN_INSTRUCTION_EXECUTOR: SeraiAddress = system_address(b"InInstructions-executor");
|
|
|
|
#[derive(
|
|
Clone, PartialEq, Eq, Debug, Serialize, Deserialize, Encode, Decode, MaxEncodedLen, TypeInfo,
|
|
)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub enum OutAddress {
|
|
Serai(SeraiAddress),
|
|
External(ExternalAddress),
|
|
}
|
|
|
|
impl OutAddress {
|
|
pub fn is_native(&self) -> bool {
|
|
matches!(self, Self::Serai(_))
|
|
}
|
|
|
|
pub fn as_native(self) -> Option<SeraiAddress> {
|
|
match self {
|
|
Self::Serai(addr) => Some(addr),
|
|
_ => None,
|
|
}
|
|
}
|
|
|
|
pub fn as_external(self) -> Option<ExternalAddress> {
|
|
match self {
|
|
Self::External(addr) => Some(addr),
|
|
Self::Serai(_) => None,
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(
|
|
Clone, PartialEq, Eq, Debug, Serialize, Deserialize, Encode, Decode, MaxEncodedLen, TypeInfo,
|
|
)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub enum DexCall {
|
|
// address to send the lp tokens to
|
|
// TODO: Update this per documentation/Shorthand
|
|
SwapAndAddLiquidity(SeraiAddress),
|
|
// minimum out balance and out address
|
|
Swap(Balance, OutAddress),
|
|
}
|
|
|
|
#[derive(
|
|
Clone, PartialEq, Eq, Debug, Serialize, Deserialize, Encode, Decode, MaxEncodedLen, TypeInfo,
|
|
)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub enum InInstruction {
|
|
Transfer(SeraiAddress),
|
|
Dex(DexCall),
|
|
}
|
|
|
|
#[derive(
|
|
Clone,
|
|
PartialEq,
|
|
Eq,
|
|
Serialize,
|
|
Deserialize,
|
|
Encode,
|
|
Decode,
|
|
MaxEncodedLen,
|
|
TypeInfo,
|
|
RuntimeDebug,
|
|
)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub struct RefundableInInstruction {
|
|
pub origin: Option<ExternalAddress>,
|
|
pub instruction: InInstruction,
|
|
}
|
|
|
|
#[derive(
|
|
Clone, PartialEq, Eq, Debug, Serialize, Deserialize, Encode, Decode, MaxEncodedLen, TypeInfo,
|
|
)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub struct InInstructionWithBalance {
|
|
pub instruction: InInstruction,
|
|
pub balance: Balance,
|
|
}
|
|
|
|
#[derive(Clone, PartialEq, Eq, Serialize, Deserialize, Encode, Decode, TypeInfo, RuntimeDebug)]
|
|
#[cfg_attr(feature = "std", derive(Zeroize))]
|
|
pub struct Batch {
|
|
pub network: NetworkId,
|
|
pub id: u32,
|
|
pub block: BlockHash,
|
|
pub instructions: Vec<InInstructionWithBalance>,
|
|
}
|
|
|
|
#[derive(Clone, PartialEq, Eq, Serialize, Deserialize, Encode, Decode, TypeInfo, RuntimeDebug)]
|
|
pub struct SignedBatch {
|
|
pub batch: Batch,
|
|
pub signature: Signature,
|
|
}
|
|
|
|
#[cfg(feature = "std")]
|
|
impl Zeroize for SignedBatch {
|
|
fn zeroize(&mut self) {
|
|
self.batch.zeroize();
|
|
self.signature.as_mut().zeroize();
|
|
}
|
|
}
|
|
|
|
// TODO: Make this an associated method?
|
|
/// The message for the batch signature.
|
|
pub fn batch_message(batch: &Batch) -> Vec<u8> {
|
|
[b"InInstructions-batch".as_ref(), &batch.encode()].concat()
|
|
}
|