SignaturePair

The client may use any number of bytes from zero to the whole length of the public key for pubKeyPrefix. If zero bytes are used, then it must be that only one primitive key is required to sign the linked transaction; it will surely resolve to INVALID_SIGNATURE otherwise.

IMPORTANT: In the special case that a signature is being provided for a key used to authorize a precompiled contract, the pubKeyPrefix must contain the entire public key! That is, if the key is a Ed25519 key, the pubKeyPrefix should be 32 bytes long. If the key is a ECDSA(secp256k1) key, the pubKeyPrefix should be 33 bytes long, since we require the compressed form of the public key.

Only Ed25519 and ECDSA(secp256k1) keys and hence signatures are currently supported.

Field
Type
Description

pubKeyPrefix

First few bytes of the public key

signature

oneof

contract

smart contract virtual signature (always length zero)

ed25519

ed25519 signature

RSA_3072

RSA-3072 signature

ECDSA_384

ECDSA p-384 signature

ECDSA_secp256k1

ECDSA(secp256k1) signature

\

Last updated

#2591: #631 HashioDAO docs

Change request updated