Some checks are pending
Build SimApp / build (amd64) (push) Waiting to run
Build SimApp / build (arm64) (push) Waiting to run
CodeQL / Analyze (push) Waiting to run
Build & Push / build (push) Waiting to run
Run Gosec / Gosec (push) Waiting to run
Lint / golangci-lint (push) Waiting to run
Checks dependencies and mocks generation / Check go mod tidy (push) Waiting to run
Checks dependencies and mocks generation / Check up to date mocks (push) Waiting to run
System Tests / setup (push) Waiting to run
System Tests / test-system (push) Blocked by required conditions
System Tests / test-system-legacy (push) Blocked by required conditions
Tests / Code Coverage / split-test-files (push) Waiting to run
Tests / Code Coverage / tests (00) (push) Blocked by required conditions
Tests / Code Coverage / tests (01) (push) Blocked by required conditions
Tests / Code Coverage / tests (02) (push) Blocked by required conditions
Tests / Code Coverage / tests (03) (push) Blocked by required conditions
Tests / Code Coverage / test-integration (push) Waiting to run
Tests / Code Coverage / test-e2e (push) Waiting to run
Tests / Code Coverage / repo-analysis (push) Blocked by required conditions
Tests / Code Coverage / test-sim-nondeterminism (push) Waiting to run
Tests / Code Coverage / test-clientv2 (push) Waiting to run
Tests / Code Coverage / test-core (push) Waiting to run
Tests / Code Coverage / test-depinject (push) Waiting to run
Tests / Code Coverage / test-errors (push) Waiting to run
Tests / Code Coverage / test-math (push) Waiting to run
Tests / Code Coverage / test-schema (push) Waiting to run
Tests / Code Coverage / test-collections (push) Waiting to run
Tests / Code Coverage / test-cosmovisor (push) Waiting to run
Tests / Code Coverage / test-confix (push) Waiting to run
Tests / Code Coverage / test-store (push) Waiting to run
Tests / Code Coverage / test-log (push) Waiting to run
Tests / Code Coverage / test-x-tx (push) Waiting to run
Tests / Code Coverage / test-x-nft (push) Waiting to run
Tests / Code Coverage / test-x-circuit (push) Waiting to run
Tests / Code Coverage / test-x-feegrant (push) Waiting to run
Tests / Code Coverage / test-x-evidence (push) Waiting to run
Tests / Code Coverage / test-x-upgrade (push) Waiting to run
Tests / Code Coverage / test-tools-benchmark (push) Waiting to run
101 lines
2.4 KiB
Go
101 lines
2.4 KiB
Go
package secp256r1
|
|
|
|
import (
|
|
"encoding/base64"
|
|
|
|
cmtcrypto "git.cw.tr/mukan-network/mukan-consensus/crypto"
|
|
"github.com/cosmos/gogoproto/proto"
|
|
|
|
ecdsa "git.cw.tr/mukan-network/mukan-sdk/crypto/keys/internal/ecdsa"
|
|
cryptotypes "git.cw.tr/mukan-network/mukan-sdk/crypto/types"
|
|
)
|
|
|
|
// customProtobufType is here to make sure that ecdsaPK and ecdsaSK implement the
|
|
// gogoproto customtype interface.
|
|
type customProtobufType interface {
|
|
Marshal() ([]byte, error)
|
|
MarshalTo(data []byte) (n int, err error)
|
|
Unmarshal(data []byte) error
|
|
Size() int
|
|
|
|
MarshalJSON() ([]byte, error)
|
|
UnmarshalJSON(data []byte) error
|
|
}
|
|
|
|
var _ customProtobufType = (*ecdsaPK)(nil)
|
|
|
|
// String implements proto.Message interface.
|
|
func (m *PubKey) String() string {
|
|
return m.Key.String(name)
|
|
}
|
|
|
|
// Bytes implements SDK PubKey interface.
|
|
func (m *PubKey) Bytes() []byte {
|
|
if m == nil {
|
|
return nil
|
|
}
|
|
return m.Key.Bytes()
|
|
}
|
|
|
|
// Equals implements SDK PubKey interface.
|
|
func (m *PubKey) Equals(other cryptotypes.PubKey) bool {
|
|
pk2, ok := other.(*PubKey)
|
|
if !ok {
|
|
return false
|
|
}
|
|
return m.Key.Equal(&pk2.Key.PublicKey)
|
|
}
|
|
|
|
// Address implements SDK PubKey interface.
|
|
func (m *PubKey) Address() cmtcrypto.Address {
|
|
return m.Key.Address(proto.MessageName(m))
|
|
}
|
|
|
|
// Type returns key type name. Implements SDK PubKey interface.
|
|
func (m *PubKey) Type() string {
|
|
return name
|
|
}
|
|
|
|
// VerifySignature implements SDK PubKey interface.
|
|
func (m *PubKey) VerifySignature(msg, sig []byte) bool {
|
|
return m.Key.VerifySignature(msg, sig)
|
|
}
|
|
|
|
type ecdsaPK struct {
|
|
ecdsa.PubKey
|
|
}
|
|
|
|
// Marshal implements customProtobufType.
|
|
func (pk ecdsaPK) Marshal() ([]byte, error) {
|
|
return pk.Bytes(), nil
|
|
}
|
|
|
|
// MarshalJSON implements customProtobufType.
|
|
func (pk ecdsaPK) MarshalJSON() ([]byte, error) {
|
|
b64 := base64.StdEncoding.EncodeToString(pk.Bytes())
|
|
return []byte("\"" + b64 + "\""), nil
|
|
}
|
|
|
|
// UnmarshalJSON implements customProtobufType.
|
|
func (pk *ecdsaPK) UnmarshalJSON(data []byte) error {
|
|
// the string is quoted so we need to remove them
|
|
bz, err := base64.StdEncoding.DecodeString(string(data[1 : len(data)-1]))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return pk.PubKey.Unmarshal(bz, secp256r1, pubKeySize)
|
|
}
|
|
|
|
// Size implements proto.Marshaler interface
|
|
func (pk *ecdsaPK) Size() int {
|
|
if pk == nil {
|
|
return 0
|
|
}
|
|
return pubKeySize
|
|
}
|
|
|
|
// Unmarshal implements proto.Marshaler interface
|
|
func (pk *ecdsaPK) Unmarshal(bz []byte) error {
|
|
return pk.PubKey.Unmarshal(bz, secp256r1, pubKeySize)
|
|
}
|