mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-10 21:04:59 +00:00
tx from impls
This commit is contained in:
parent
8ac5cdd490
commit
7660532840
1 changed files with 93 additions and 13 deletions
|
@ -10,7 +10,7 @@ use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
use cuprate_helper::cast::usize_to_u64;
|
use cuprate_helper::cast::usize_to_u64;
|
||||||
|
|
||||||
use monero_serai::{ringct::RctType, transaction};
|
use monero_serai::{ringct, transaction};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
hex::{HexBytes1, HexBytes32, HexBytes64, HexBytes8},
|
hex::{HexBytes1, HexBytes32, HexBytes64, HexBytes8},
|
||||||
|
@ -140,20 +140,43 @@ impl From<transaction::Transaction> for Transaction {
|
||||||
};
|
};
|
||||||
|
|
||||||
let r#type = match proofs.rct_type() {
|
let r#type = match proofs.rct_type() {
|
||||||
RctType::AggregateMlsagBorromean => 1,
|
ringct::RctType::AggregateMlsagBorromean => 1,
|
||||||
RctType::MlsagBorromean => 2,
|
ringct::RctType::MlsagBorromean => 2,
|
||||||
RctType::MlsagBulletproofs => 3,
|
ringct::RctType::MlsagBulletproofs => 3,
|
||||||
RctType::MlsagBulletproofsCompactAmount => 4,
|
ringct::RctType::MlsagBulletproofsCompactAmount => 4,
|
||||||
RctType::ClsagBulletproof => 5,
|
ringct::RctType::ClsagBulletproof => 5,
|
||||||
RctType::ClsagBulletproofPlus => 6,
|
ringct::RctType::ClsagBulletproofPlus => 6,
|
||||||
};
|
};
|
||||||
|
|
||||||
let txnFee = proofs.base.fee;
|
let txnFee = proofs.base.fee;
|
||||||
|
|
||||||
|
let ecdhInfo = proofs
|
||||||
|
.base
|
||||||
|
.encrypted_amounts
|
||||||
|
.into_iter()
|
||||||
|
.map(EcdhInfo::from)
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
let outPk = proofs
|
||||||
|
.base
|
||||||
|
.commitments
|
||||||
|
.into_iter()
|
||||||
|
.map(|point| HexBytes32(point.compress().0))
|
||||||
|
.collect();
|
||||||
|
|
||||||
|
let rct_signatures = RctSignatures {
|
||||||
|
r#type,
|
||||||
|
txnFee,
|
||||||
|
ecdhInfo,
|
||||||
|
outPk,
|
||||||
|
};
|
||||||
|
|
||||||
|
let rctsig_prunable = RctSigPrunable::from(proofs.prunable);
|
||||||
|
|
||||||
Self::V2 {
|
Self::V2 {
|
||||||
prefix,
|
prefix,
|
||||||
rct_signatures: todo!(),
|
rct_signatures: Some(rct_signatures),
|
||||||
rctsig_prunable: todo!(),
|
rctsig_prunable: Some(rctsig_prunable),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -180,6 +203,43 @@ pub struct RctSigPrunable {
|
||||||
pub pseudoOuts: Vec<String>,
|
pub pseudoOuts: Vec<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[expect(unused_variables, reason = "TODO: finish impl")]
|
||||||
|
impl From<ringct::RctPrunable> for RctSigPrunable {
|
||||||
|
fn from(r: ringct::RctPrunable) -> Self {
|
||||||
|
use ringct::RctPrunable as R;
|
||||||
|
|
||||||
|
match r {
|
||||||
|
R::AggregateMlsagBorromean { mlsag, borromean } => {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
R::MlsagBorromean { mlsags, borromean } => {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
R::MlsagBulletproofs {
|
||||||
|
mlsags,
|
||||||
|
pseudo_outs,
|
||||||
|
bulletproof,
|
||||||
|
} => {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
R::MlsagBulletproofsCompactAmount {
|
||||||
|
mlsags,
|
||||||
|
pseudo_outs,
|
||||||
|
bulletproof,
|
||||||
|
} => {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
R::Clsag {
|
||||||
|
clsags,
|
||||||
|
pseudo_outs,
|
||||||
|
bulletproof,
|
||||||
|
} => {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// [`RctSigPrunable::bpp`].
|
/// [`RctSigPrunable::bpp`].
|
||||||
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
|
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
|
||||||
|
@ -206,10 +266,30 @@ pub struct Clsag {
|
||||||
/// [`RctSignatures::ecdhInfo`].
|
/// [`RctSignatures::ecdhInfo`].
|
||||||
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
#[derive(Clone, Debug, PartialEq, Eq, PartialOrd, Ord, Hash)]
|
||||||
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
|
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
|
||||||
pub struct EcdhInfo {
|
#[cfg_attr(feature = "serde", serde(untagged))]
|
||||||
pub amount: HexBytes8,
|
#[expect(variant_size_differences)]
|
||||||
#[serde(default, skip_serializing_if = "Option::is_none")]
|
pub enum EcdhInfo {
|
||||||
pub mask: Option<String>,
|
Original {
|
||||||
|
amount: HexBytes32,
|
||||||
|
mask: HexBytes32,
|
||||||
|
},
|
||||||
|
Compact {
|
||||||
|
amount: HexBytes8,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<ringct::EncryptedAmount> for EcdhInfo {
|
||||||
|
fn from(ea: ringct::EncryptedAmount) -> Self {
|
||||||
|
match ea {
|
||||||
|
ringct::EncryptedAmount::Original { amount, mask } => Self::Original {
|
||||||
|
amount: HexBytes32(amount),
|
||||||
|
mask: HexBytes32(mask),
|
||||||
|
},
|
||||||
|
ringct::EncryptedAmount::Compact { amount } => Self::Compact {
|
||||||
|
amount: HexBytes8(amount),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// [`TransactionPrefix::vin`].
|
/// [`TransactionPrefix::vin`].
|
||||||
|
|
Loading…
Reference in a new issue