Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: reinsert transactions from failed block #4675

Merged

Conversation

stringhandler
Copy link
Collaborator

Description

After removing transactions from the mempool from a failed validation, reinsert them to keep the valid ones

Motivation and Context

Currently, the implementation discards all transactions when validation fails. This is a pretty heavy approach, because the block may be incorrect in the header. There may even be an attack where a malicious user crafts a bad block and removes all transactions in the mempool.

In this approach, the transactions are reinserted into the mempool. If any of them are now invalid (e.g. double spends) they will be discarded

How Has This Been Tested?

existing tests, CI

sdbondi
sdbondi previously approved these changes Sep 14, 2022
Copy link
Member

@sdbondi sdbondi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Makes sense

hansieodendaal
hansieodendaal previously approved these changes Sep 14, 2022
Copy link
Contributor

@hansieodendaal hansieodendaal left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM - I agree with this approach

@SWvheerden
Copy link
Collaborator

This looks fine, but it does kinda seem like what's the point in removing them in the first place.
They are going to be re-added through the same process as when they were first added.

This will only catch the case where the mempool failed to process a mined block, but then again I don't know if this will catch it.

Copy link
Member

@sdbondi sdbondi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM, not for this PR, but in favour of splitting the comms logs up, maybe DHT+messaging, rpc and the rest.

I don't think outputting the byte contents of all outgoing messages is very useful

header_str,
self.tag,
self.body
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe the length rather?

comms/dht/src/outbound/message_params.rs Outdated Show resolved Hide resolved
@@ -86,7 +91,7 @@ where
}

fn call(&mut self, msg: R) -> Self::Future {
trace!(target: LOG_TARGET, "{}{}", self.prefix_msg, msg);
info!(target: LOG_TARGET, "{}{:?}", self.prefix_msg, msg);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps debug?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lol, meant debug-level logging (going by the guide of whether a user would be interested in this information)

@stringhandler stringhandler merged commit 8030364 into tari-project:development Sep 16, 2022
@stringhandler stringhandler deleted the st-reinsert-transactions branch September 16, 2022 07:52
sdbondi added a commit to sdbondi/tari that referenced this pull request Sep 16, 2022
* development: (72 commits)
  fix: reinsert transactions from failed block (tari-project#4675)
  fix: stray clippy error (tari-project#4685)
  fix(wallet): mark mined_height as null when pending outputs are cancelled (tari-project#4686)
  chore: updated dependancies (tari-project#4684)
  fix(p2p): remove DETACH flag usage (tari-project#4682)
  fix(comms): simplify and remove possibility of deadlock from pipelines and substream close (tari-project#4676)
  feat(ci): add default CI and FFI testing with custom dispatch (tari-project#4672)
  chore: remove broken test (tari-project#4678)
  fix: fix potential race condition between add_block and sync (tari-project#4677)
  fix deadlock (tari-project#4674)
  fix: add burn funds command to console wallet (see issue tari-project#4547) (tari-project#4655)
  v0.38.3
  fix: fee estimate (tari-project#4656)
  fix(comms/messaging): fix possible deadlock in outbound pipeline (tari-project#4657)
  fix: replace Luhn checksum with DammSum (tari-project#4639)
  fix(core/sync): handle deadline timeouts by changing peer (tari-project#4649)
  fix(ci): libtor build on Ubuntu (tari-project#4644)
  chore: fix log (tari-project#4634)
  v0.38.2
  fix(comms/rpc): detect early close in all cases (tari-project#4647)
  ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants