|
@@ -22,9 +22,9 @@ use std::collections::HashMap;
|
|
|
/// Since the transaction ID is calculated from the transaction itself, to provide cryptographic
|
|
|
/// security that its content was not altered.
|
|
|
#[derive(Debug, Clone, Deserialize, Serialize)]
|
|
|
-pub struct TransactionInner {
|
|
|
+pub struct Revision {
|
|
|
/// A pointer to the first revision of the transaction.
|
|
|
- first_revision: Option<TransactionId>,
|
|
|
+ first: Option<TransactionId>,
|
|
|
/// Any previous transaction that this transaction is replacing.
|
|
|
previous: Option<TransactionId>,
|
|
|
/// A human-readable description of the transaction changes.
|
|
@@ -43,7 +43,7 @@ pub struct TransactionInner {
|
|
|
updated_at: DateTime<Utc>,
|
|
|
}
|
|
|
|
|
|
-impl TransactionInner {
|
|
|
+impl Revision {
|
|
|
pub fn calculate_id(&self) -> Result<TransactionId, Error> {
|
|
|
let mut hasher = Sha256::new();
|
|
|
let bytes = bincode::serialize(self)?;
|
|
@@ -162,20 +162,20 @@ pub struct Transaction {
|
|
|
/// The TransactionID is the RevisionID of the first revision of the transaction.
|
|
|
pub id: TransactionId,
|
|
|
/// Current Revision ID.
|
|
|
- pub revision: TransactionId,
|
|
|
+ pub current: TransactionId,
|
|
|
/// The transaction inner details
|
|
|
#[serde(flatten)]
|
|
|
- inner: TransactionInner,
|
|
|
+ inner: Revision,
|
|
|
}
|
|
|
|
|
|
-impl TryFrom<TransactionInner> for Transaction {
|
|
|
+impl TryFrom<Revision> for Transaction {
|
|
|
type Error = Error;
|
|
|
|
|
|
- fn try_from(inner: TransactionInner) -> Result<Self, Self::Error> {
|
|
|
+ fn try_from(inner: Revision) -> Result<Self, Self::Error> {
|
|
|
let id = inner.calculate_id()?;
|
|
|
Ok(Transaction {
|
|
|
- id: inner.first_revision.clone().unwrap_or_else(|| id.clone()),
|
|
|
- revision: id,
|
|
|
+ id: inner.first.clone().unwrap_or_else(|| id.clone()),
|
|
|
+ current: id,
|
|
|
inner,
|
|
|
})
|
|
|
}
|
|
@@ -192,8 +192,8 @@ impl Transaction {
|
|
|
status: Status,
|
|
|
pay_to: Vec<(AccountId, Amount)>,
|
|
|
) -> Result<Transaction, Error> {
|
|
|
- TransactionInner {
|
|
|
- first_revision: None,
|
|
|
+ Revision {
|
|
|
+ first: None,
|
|
|
changelog: "".to_owned(),
|
|
|
previous: None,
|
|
|
spends: vec![],
|
|
@@ -243,8 +243,8 @@ impl Transaction {
|
|
|
status: Status,
|
|
|
spend: Vec<PaymentFrom>,
|
|
|
) -> Result<Transaction, Error> {
|
|
|
- TransactionInner {
|
|
|
- first_revision: None,
|
|
|
+ Revision {
|
|
|
+ first: None,
|
|
|
changelog: "".to_owned(),
|
|
|
previous: None,
|
|
|
spends: spend,
|
|
@@ -260,7 +260,7 @@ impl Transaction {
|
|
|
}
|
|
|
|
|
|
/// Gets the inner transaction
|
|
|
- pub fn inner(&self) -> &TransactionInner {
|
|
|
+ pub fn inner(&self) -> &Revision {
|
|
|
&self.inner
|
|
|
}
|
|
|
|
|
@@ -282,8 +282,8 @@ impl Transaction {
|
|
|
.map(|(to, amount)| PaymentTo { to, amount })
|
|
|
.collect();
|
|
|
|
|
|
- TransactionInner {
|
|
|
- first_revision: None,
|
|
|
+ Revision {
|
|
|
+ first: None,
|
|
|
changelog: "".to_owned(),
|
|
|
previous: None,
|
|
|
spends,
|
|
@@ -319,11 +319,11 @@ impl Transaction {
|
|
|
.is_valid_transition(&self.inner.status, &new_status)?;
|
|
|
let mut inner = self.inner;
|
|
|
inner.changelog = reason;
|
|
|
- if inner.first_revision.is_none() {
|
|
|
- inner.first_revision = Some(self.id);
|
|
|
+ if inner.first.is_none() {
|
|
|
+ inner.first = Some(self.id);
|
|
|
}
|
|
|
inner.updated_at = Utc::now();
|
|
|
- inner.previous = Some(self.revision);
|
|
|
+ inner.previous = Some(self.current);
|
|
|
inner.status = new_status;
|
|
|
let mut x: Transaction = inner.try_into()?;
|
|
|
x.persist(config).await?;
|
|
@@ -334,7 +334,7 @@ impl Transaction {
|
|
|
pub(crate) fn validate(&self) -> Result<(), Error> {
|
|
|
let calculated_revision_id = self.inner.calculate_id()?;
|
|
|
|
|
|
- if self.revision != calculated_revision_id
|
|
|
+ if self.current != calculated_revision_id
|
|
|
|| (self.inner.previous.is_none() && self.id != calculated_revision_id)
|
|
|
{
|
|
|
return Err(Error::InvalidTransactionId(
|
|
@@ -399,10 +399,11 @@ impl Transaction {
|
|
|
|
|
|
if let Some(previous_id) = &self.inner.previous {
|
|
|
// Make sure this update is updating the last revision and the status is not final
|
|
|
- let current_transaction = batch.get_transaction(&self.id).await?;
|
|
|
+ let current_transaction = batch
|
|
|
+ .get_transaction_with_revision(&self.id, previous_id)
|
|
|
+ .await?;
|
|
|
|
|
|
- if current_transaction.revision != *previous_id
|
|
|
- || config.status.is_final(¤t_transaction.inner.status)
|
|
|
+ if config.status.is_final(¤t_transaction.inner.status)
|
|
|
|| self.inner.transaction_fingerprint()?
|
|
|
!= current_transaction.inner.transaction_fingerprint()?
|
|
|
{
|