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 runtime ID, check amount when minting collectibles, rebase GetInfo RPC fixes commit #589

Merged
merged 3 commits into from
Oct 17, 2023

Conversation

guggero
Copy link
Member

@guggero guggero commented Oct 16, 2023

Fixes #576.
Fixes #573.

Replaces #554.

Fixes multiple small issues.

@jharveyb
Copy link
Contributor

Would be good to have an itest for the runtime ID change; something like starting 100 tapd instances, pulling the runtime ID via universe info, and making sure that they are all unique.

@@ -275,7 +276,13 @@ func genServerConfig(cfg *Config, cfgLogger btclog.Logger,
SyncBatchSize: defaultUniverseSyncBatchSize,
})

runtimeID := prand.Int63() // nolint:gosec
var runtimeIDBytes [8]byte
Copy link
Member

@Roasbeef Roasbeef Oct 16, 2023

Choose a reason for hiding this comment

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

Any reason to not increase to 32 bytes so we don't have to think about it?

Copy link
Contributor

Choose a reason for hiding this comment

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

Could do both but p sure root cause was the RNG.

Copy link
Member Author

Choose a reason for hiding this comment

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

Any reason to not increase to 32 bytes so we don't have to think about it?

Yeah, just to make things non-breaking on the RPC interface.

I think 8 bytes should be waaaay enough for this. I'm pretty sure this was a combination of weak RNG+docker+macOS that lead to duplicates. I tried to reproduce this on my machine with a dummy docker setup and wasn't able to.

Using the better RNG should definitely make this almost impossible to hit.

Unfortunately neither a unit nor an integration test can help here, since as long as things are in the same process, we can never get a collision as even the weak RNG is a package-level variable. So if code from the same process request randomness, it will be different for each call as the calls are serialized. This can only be reproduced by spawning multiple processes within a very short time (which isn't super easy to do with our current setup).

I'm voting to just leave things the way they are and rely on the CPRNG being much better for this.

@Roasbeef
Copy link
Member

Would be good to have an itest for the runtime ID change; something like starting 100 tapd instances, pulling the runtime ID via universe info, and making sure that they are all unique.

Unit test here (forces us to abstract it a bit more) would prob be good enough here. Or we increase increase to 32 bytes and call it a day.

cmd/tapcli/assets.go Outdated Show resolved Hide resolved
@guggero guggero requested a review from Roasbeef October 17, 2023 07:18
Copy link
Contributor

@jharveyb jharveyb left a comment

Choose a reason for hiding this comment

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

LGTM 🚀

guggero and others added 3 commits October 17, 2023 18:06
Fixes #573 by using the cryptographic pseudo number generator for
generating the runtime ID.
Apparently when starting two nodes at the very same time the math/rand
library can generate the same ID on different processes.
Fixes #576 by making sure that the amount for collectible assets is
always set at 1.
… and block hash

Added additional fields to the GetInfo RPC response to provide richer details about the blockchain and the LND node. This includes the LND node's public key (identity), its alias, the current block height, and the latest block's hash.
Copy link
Member

@Roasbeef Roasbeef left a comment

Choose a reason for hiding this comment

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

LGTM 🗞️

@Roasbeef Roasbeef merged commit c8dc6c5 into main Oct 17, 2023
@guggero guggero deleted the multi-fixes branch October 17, 2023 17:46
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
4 participants