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

Add support for secp256r1 #987

Closed
0xknwn opened this issue May 9, 2024 · 0 comments · Fixed by #1189
Closed

Add support for secp256r1 #987

0xknwn opened this issue May 9, 2024 · 0 comments · Fixed by #1189
Assignees
Milestone

Comments

@0xknwn
Copy link

0xknwn commented May 9, 2024

🧐 Motivation

OpenZeppelin/cairo-contracts includes a number of utils to support secp256k1:

  • types for publickey and signature
  • traits for serialization, debug, eq
  • a store to save the secp256k1 public keys in a contract in a packed format
  • is_valid_eth_signature to check a secp256k1 signature is valid
  • a collection of Cairo tests and a data set to validate the implementation of the above

These tools are used internally in OpenZeppelin/cairo-contracts to implement the Eth Account. They are also available for third party projects that uses your project as a library. We use them in our starknet-modular-account project.

We have implemented the same set of tools for secp256r1 that is also supported by the starknet corelib. We would like to submit a PR that them so that we can rely on them the same way we rely on your secp256k1 implementation.

📝 Details

See PR #988 for details about the implementation. We've done the adaptation from secp256k1 to secp256r1 but, except for the mapping between the functions and features the implementation is the same.

@github-project-automation github-project-automation bot moved this to 📋 Backlog in Contracts for Cairo Aug 3, 2024
@andrew-fleming andrew-fleming added this to the 3. after milestone Sep 17, 2024
@ericnordelo ericnordelo changed the title Add trait (Serde, Debug, Eq), store and is_valid_xxx_signature and tests for secp256r1 Add support for secp256r1 Sep 24, 2024
@andrew-fleming andrew-fleming modified the milestones: 2. next, 1. current Oct 18, 2024
@github-project-automation github-project-automation bot moved this from 📋 Backlog to ✅ Resolved in Contracts for Cairo Oct 29, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Archived in project
3 participants