cosmos-sdk/types/tx_msg.go

98 lines
2.7 KiB
Go
Raw Normal View History

package types
2018-03-04 00:15:26 -08:00
import "encoding/json"
2018-02-04 16:59:11 -08:00
// Transactions messages must fulfill the Msg
type Msg interface {
// Return the message type.
// Must be alphanumeric or empty.
Type() string
// Get some property of the Msg.
Get(key interface{}) (value interface{})
// Get the canonical byte representation of the Msg.
2018-01-10 20:11:44 -08:00
GetSignBytes() []byte
// ValidateBasic does a simple validation check that
// doesn't require access to any other information.
2018-01-26 04:19:33 -08:00
ValidateBasic() Error
// Signers returns the addrs of signers that must sign.
// CONTRACT: All signatures must be present to be valid.
// CONTRACT: Returns addrs in some deterministic order.
2018-03-01 23:49:07 -08:00
GetSigners() []Address
}
2018-03-02 09:21:49 -08:00
//__________________________________________________________
2018-02-04 16:59:11 -08:00
// Transactions objects must fulfill the Tx
type Tx interface {
2018-01-26 06:22:56 -08:00
// Gets the Msg.
GetMsg() Msg
// The address that pays the base fee for this message. The fee is
// deducted before the Msg is processed.
2018-03-01 23:49:07 -08:00
GetFeePayer() Address
// Signatures returns the signature of signers who signed the Msg.
// CONTRACT: Length returned is same as length of
// pubkeys returned from MsgKeySigners, and the order
// matches.
// CONTRACT: If the signature is missing (ie the Msg is
// invalid), then the corresponding signature is
// .Empty().
GetSignatures() []StdSignature
}
2018-01-14 19:49:57 -08:00
var _ Tx = (*StdTx)(nil)
2018-02-17 13:19:34 -08:00
// StdTx is a standard way to wrap a Msg with Signatures.
// NOTE: the first signature is the FeePayer (Signatures must not be nil).
type StdTx struct {
Msg `json:"msg"`
Signatures []StdSignature `json:"signatures"`
}
2018-02-17 13:19:34 -08:00
func NewStdTx(msg Msg, sigs []StdSignature) StdTx {
return StdTx{
Msg: msg,
Signatures: sigs,
}
}
2018-02-04 16:59:11 -08:00
//nolint
2018-01-26 06:22:56 -08:00
func (tx StdTx) GetMsg() Msg { return tx.Msg }
2018-03-01 23:49:07 -08:00
func (tx StdTx) GetFeePayer() Address { return tx.Signatures[0].PubKey.Address() } // XXX but PubKey is optional!
2018-01-14 19:49:57 -08:00
func (tx StdTx) GetSignatures() []StdSignature { return tx.Signatures }
2018-03-03 23:36:10 -08:00
// StdSignDoc is replay-prevention structure.
// It includes the result of msg.GetSignBytes(),
// as well as the ChainID (prevent cross chain replay)
// and the Sequence (prevent inchain replay).
type StdSignDoc struct {
ChainID string `json:"chain_id"`
Sequence int64 `json:"sequence"`
MsgBytes []byte `json:"msg_bytes"`
AltBytes []byte `json:"alt_bytes"` // TODO: do we really want this ?
}
2018-03-04 00:15:26 -08:00
func StdSignBytes(chainID string, sequence int64, msg Msg) []byte {
bz, err := json.Marshal(StdSignDoc{
ChainID: chainID,
Sequence: sequence,
MsgBytes: msg.GetSignBytes(),
})
if err != nil {
panic(err)
}
return bz
}
2018-03-03 23:36:10 -08:00
//-------------------------------------
2018-02-04 16:59:11 -08:00
// Application function variable used to unmarshal transaction bytes
2018-01-26 04:19:33 -08:00
type TxDecoder func(txBytes []byte) (Tx, Error)