-
Notifications
You must be signed in to change notification settings - Fork 3
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
Public keys #6
Comments
From what I can tell, currently, the generated public/private key pair is 2048 bit in length. Is it a custom implementation of a public key generation algorithm? Can we speed it up by allowing public/private key pairs using more efficient algorithms like Ed25519? |
public key generated on More Modular Exponential (MODP) Diffie-Hellman groups, it's also prime order group like ECC points cycle group https://tools.ietf.org/html/rfc3526 . I mentioned before, now, it does not meet the requirement for production enviroment. ECC groups are plan in the future. you can try to change code for Ed25519 using Rust trait, this can adding more curves including secp256k1 or twisted Edward Curve(Ed25519 Curve) the impl is here Lines 81 to 100 in 214c1d1
There is no restriction on the specific structure of the group in the PVSS paper, It only needs to be a prime order group |
Sorry. This was indeed my previous plan: to support more curves(you can check README), but since this project is an amateur one, that feature is not supported now. So there is no specific time point for this feature to be supported. Thank you for your feedback |
Is this an urgent issue for you? If you know something about cryptography, you should be able to check my implementation code and add a configurable function for generating a secret key pair algorithm (since many curves have Rust implementations already), but it takes quite a bit of time. |
Not urgent, I will keep you informed when I need a production implementation |
Yes, this project is an implementation of the PVSS thesis, mainly because the PVSS algorithm does not focus on specific curves and was first done as an attempt to make a prototype. In fact, the PVSS paper is not too difficult, you can look at the README inside the references provided, in particular, <how to share secret> which is an earlier paper that helps you understand the implementation code。 finally try to read <A Simple Publicly Verifiable Secret Sharing Scheme and its Application to Electronic Voting> |
But rest assured, the key pair algorithm here is not my own invention and is safe. It just may not meet your needs. If you need to be faster, you can consider using libgmp acceleration. Because here modpow these operations are slower. hope these informations can help you. |
Fixes #6 Add support for Ed25519 key generation in the MPVSS implementation. * **src/mpvss.rs** - Import `ed25519_dalek` crate for Ed25519 key generation. - Add `KeyAlgorithm` enum to represent key generation algorithms. - Update `MPVSS` struct to include `key_algorithm` field. - Add `generate_ed25519_keypair` function to generate Ed25519 key pairs. - Update `generate_private_key` and `generate_public_key` functions to support both original and Ed25519 algorithms. * **README.md** - Update "Initialization" section to include Ed25519 key generation. - Add a note about Ed25519 key generation in the "In the futures" section. * **tests/mpvss_tests.rs** - Add `test_ed25519_key_generation` function to verify Ed25519 key generation. --- For more details, open the [Copilot Workspace session](https://copilot-workspace.githubnext.com/AlexiaChen/mpvss-rs/issues/6?shareId=XXXX-XXXX-XXXX-XXXX).
How are the public keys for the participants generated? Would it be possible to switch them to a new algorithm like Ed25519 for Public Key generation?
The text was updated successfully, but these errors were encountered: