diff --git a/pkg/crypto/keys/publickey.go b/pkg/crypto/keys/publickey.go index 311a7a207..876b044c2 100644 --- a/pkg/crypto/keys/publickey.go +++ b/pkg/crypto/keys/publickey.go @@ -143,29 +143,10 @@ func (p *PublicKey) getBytes(compressed bool) []byte { return []byte{0x00} } - var resLen = 1 + coordLen - if !compressed { - resLen += coordLen - } - var res = make([]byte, resLen) - var prefix byte - - xBytes := p.X.Bytes() - copy(res[1+coordLen-len(xBytes):], xBytes) if compressed { - if p.Y.Bit(0) == 0 { - prefix = 0x02 - } else { - prefix = 0x03 - } - } else { - prefix = 0x04 - yBytes := p.Y.Bytes() - copy(res[1+coordLen+coordLen-len(yBytes):], yBytes) + return elliptic.MarshalCompressed(p.Curve, p.X, p.Y) } - res[0] = prefix - - return res + return elliptic.Marshal(p.Curve, p.X, p.Y) } // Bytes returns byte array representation of the public key in compressed diff --git a/pkg/crypto/keys/publickey_test.go b/pkg/crypto/keys/publickey_test.go index d84f8c605..ce01217e4 100644 --- a/pkg/crypto/keys/publickey_test.go +++ b/pkg/crypto/keys/publickey_test.go @@ -223,3 +223,17 @@ func BenchmarkPublicEqual(t *testing.B) { _ = k11.Equal(k2) } } + +func BenchmarkPublicBytes(t *testing.B) { + k := getPubKey(t) + for n := 0; n < t.N; n++ { + _ = k.Bytes() + } +} + +func BenchmarkPublicUncompressedBytes(t *testing.B) { + k := getPubKey(t) + for n := 0; n < t.N; n++ { + _ = k.Bytes() + } +}