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

Update spec to 1.4.15 #509

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion client/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ var (
ErrRetriable = errors.New("retriable http status code received")
)

// APIClient manages communication with the Rosetta API v1.4.12
// APIClient manages communication with the Rosetta API v1.4.13
potterbm-cb marked this conversation as resolved.
Show resolved Hide resolved
// In most cases there should be only one, shared, APIClient.
type APIClient struct {
cfg *Configuration
Expand Down
4 changes: 3 additions & 1 deletion codegen.sh
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ done
rm -rf tmp

# Download spec file from releases
ROSETTA_SPEC_VERSION=1.4.12
ROSETTA_SPEC_VERSION=1.4.15
curl -L https://github.com/coinbase/rosetta-specifications/releases/download/v${ROSETTA_SPEC_VERSION}/api.json -o api.json

# Generate client + types code
Expand Down Expand Up @@ -120,13 +120,15 @@ sed "${SED_IFLAG[@]}" 's/*Case/Case/g' client/* server/*

# Fix CurveTypes, SignatureTypes, CoinActions, ExemptionTypes, Direction, Case
sed "${SED_IFLAG[@]}" 's/SECP256K1/Secp256k1/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/Secp256k1_BIP340/Secp256k1Bip340/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/SECP256R1/Secp256r1/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/EDWARDS25519/Edwards25519/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/TWEEDLE/Tweedle/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/ECDSA_RECOVERY/EcdsaRecovery/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/ECDSA/Ecdsa/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/ED25519/Ed25519/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/SCHNORR_1/Schnorr1/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/SCHNORR_BIP340/SchnorrBip340/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/SCHNORR_POSEIDON/SchnorrPoseidon/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/PALLAS/Pallas/g' client/* server/*
sed "${SED_IFLAG[@]}" 's/CREATED/CoinCreated/g' client/* server/*
Expand Down
23 changes: 14 additions & 9 deletions types/curve_type.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,24 @@
package types

// CurveType CurveType is the type of cryptographic curve associated with a PublicKey. * secp256k1:
// SEC compressed - `33 bytes` (https://secg.org/sec1-v2.pdf#subsubsection.2.3.3) * secp256r1: SEC
// compressed - `33 bytes` (https://secg.org/sec1-v2.pdf#subsubsection.2.3.3) * edwards25519: `y
// (255-bits) || x-sign-bit (1-bit)` - `32 bytes` (https://ed25519.cr.yp.to/ed25519-20110926.pdf) *
// tweedle: 1st pk : Fq.t (32 bytes) || 2nd pk : Fq.t (32 bytes)
// SEC compressed - `33 bytes` (https://secg.org/sec1-v2.pdf#subsubsection.2.3.3) *
// secp256k1_bip340: x-only - `32 bytes` (implicitly even `Y` coord. Secp256k1 compressed keys may
// be repurposed by dropping the first byte.
// (https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki#Public_Key_Generation)) *
// secp256r1: SEC compressed - `33 bytes` (https://secg.org/sec1-v2.pdf#subsubsection.2.3.3) *
// edwards25519: `y (255-bits) || x-sign-bit (1-bit)` - `32 bytes`
// (https://ed25519.cr.yp.to/ed25519-20110926.pdf) * tweedle: 1st pk : Fq.t (32 bytes) || 2nd pk :
// Fq.t (32 bytes)
// (https://github.com/CodaProtocol/coda/blob/develop/rfcs/0038-rosetta-construction-api.md#marshal-keys)
// * pallas: `x (255 bits) || y-parity-bit (1-bit) - 32 bytes` (https://github.com/zcash/pasta)
type CurveType string

// List of CurveType
const (
Secp256k1 CurveType = "secp256k1"
Secp256r1 CurveType = "secp256r1"
Edwards25519 CurveType = "edwards25519"
Tweedle CurveType = "tweedle"
Pallas CurveType = "pallas"
Secp256k1 CurveType = "secp256k1"
Secp256k1Bip340 CurveType = "secp256k1_bip340"
Secp256r1 CurveType = "secp256r1"
Edwards25519 CurveType = "edwards25519"
Tweedle CurveType = "tweedle"
Pallas CurveType = "pallas"
)
2 changes: 1 addition & 1 deletion types/network_status_response.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,5 +33,5 @@ type NetworkStatusResponse struct {
GenesisBlockIdentifier *BlockIdentifier `json:"genesis_block_identifier"`
OldestBlockIdentifier *BlockIdentifier `json:"oldest_block_identifier,omitempty"`
SyncStatus *SyncStatus `json:"sync_status,omitempty"`
Peers []*Peer `json:"peers"`
Peers []*Peer `json:"peers,omitempty"`
}
11 changes: 7 additions & 4 deletions types/signature_type.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,10 +20,12 @@ package types
// (32-bytes)` - `64 bytes` * ecdsa_recovery: `r (32-bytes) || s (32-bytes) || v (1-byte)` - `65
// bytes` * ed25519: `R (32-byte) || s (32-bytes)` - `64 bytes` * schnorr_1: `r (32-bytes) || s
// (32-bytes)` - `64 bytes` (schnorr signature implemented by Zilliqa where both `r` and `s` are
// scalars encoded as `32-bytes` values, most significant byte first.) * schnorr_poseidon: `r
// (32-bytes) || s (32-bytes)` where s = Hash(1st pk || 2nd pk || r) - `64 bytes` (schnorr
// signature w/ Poseidon hash function implemented by O(1) Labs where both `r` and `s` are scalars
// encoded as `32-bytes` values, least significant byte first.
// scalars encoded as `32-bytes` values, most significant byte first.) * schnorr_bip340: `r
// (32-bytes) || s (32-bytes)` - `64 bytes` (sig = (bytes(R) || bytes((k + ed) mod n) where `r` is
// the `X` coordinate of a point `R` whose `Y` coordinate is even, most significant bytes first.) *
// schnorr_poseidon: `r (32-bytes) || s (32-bytes)` where s = Hash(1st pk || 2nd pk || r) - `64
// bytes` (schnorr signature w/ Poseidon hash function implemented by O(1) Labs where both `r` and
// `s` are scalars encoded as `32-bytes` values, least significant byte first.
// https://github.com/CodaProtocol/signer-reference/blob/master/schnorr.ml )
type SignatureType string

Expand All @@ -33,5 +35,6 @@ const (
EcdsaRecovery SignatureType = "ecdsa_recovery"
Ed25519 SignatureType = "ed25519"
Schnorr1 SignatureType = "schnorr_1"
SchnorrBip340 SignatureType = "schnorr_bip340"
Copy link
Contributor

Choose a reason for hiding this comment

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

Hi @sleepdefic1t , CAN I have more context of why we add it ?
if you wanna support a new type, you can test in at derive endpoint

Copy link
Author

Choose a reason for hiding this comment

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

@jingweicb

CAN I have more context of why we add it ?

The addition of these types is necessary because the construction and handling of BIP-340 signatures and public keys differ from other signature types.

To reiterate, all of this was previously discussed and approved here: coinbase/mesh-specifications#113


if you wanna support a new type, you can test in at derive endpoint

Perhaps I'm still misunderstanding.

This PR only adds the base signature and curve types as they relate to the specification, it's not intended to be a full or partial implementation of BIP-340.

It was discussed and agreed upon that a subsequent PR would handle the actual implementation of BIP-340, which would then utilise these new types.

Could you clarify where you propose adding a test? Without further implementation, testing doesn’t seem possible based solely on the spec update.

SchnorrPoseidon SignatureType = "schnorr_poseidon"
)
2 changes: 1 addition & 1 deletion types/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,5 @@ const (
// RosettaAPIVersion is the version of the Rosetta API
// specification used to generate code for this release
// of the SDK.
RosettaAPIVersion = "1.4.12"
RosettaAPIVersion = "1.4.15"
)