diff options
author | Felix Lange <fjl@users.noreply.github.com> | 2017-12-18 19:50:21 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-18 19:50:21 +0800 |
commit | 8c33ac10bff32d082facfd274188334a3236a4e7 (patch) | |
tree | 505b9b727642636dacc24f43429e559a1b33c7b8 /internal/ethapi | |
parent | 3b79bac05b6a7b9c3845919f274d6014c821ea4c (diff) | |
download | dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar.gz dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar.bz2 dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar.lz dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar.xz dexon-8c33ac10bff32d082facfd274188334a3236a4e7.tar.zst dexon-8c33ac10bff32d082facfd274188334a3236a4e7.zip |
internal/ethapi: support "input" in transaction args (#15640)
The tx data field is called "input" in returned objects and "data" in
argument objects. Make it so "input" can be used, but bail if both
are set.
Diffstat (limited to 'internal/ethapi')
-rw-r--r-- | internal/ethapi/api.go | 19 |
1 files changed, 16 insertions, 3 deletions
diff --git a/internal/ethapi/api.go b/internal/ethapi/api.go index 76a7306e4..d07b2e693 100644 --- a/internal/ethapi/api.go +++ b/internal/ethapi/api.go @@ -17,6 +17,7 @@ package ethapi import ( + "bytes" "context" "errors" "fmt" @@ -1070,8 +1071,11 @@ type SendTxArgs struct { Gas *hexutil.Big `json:"gas"` GasPrice *hexutil.Big `json:"gasPrice"` Value *hexutil.Big `json:"value"` - Data hexutil.Bytes `json:"data"` Nonce *hexutil.Uint64 `json:"nonce"` + // We accept "data" and "input" for backwards-compatibility reasons. "input" is the + // newer name and should be preferred by clients. + Data *hexutil.Bytes `json:"data"` + Input *hexutil.Bytes `json:"input"` } // setDefaults is a helper function that fills in default values for unspecified tx fields. @@ -1096,14 +1100,23 @@ func (args *SendTxArgs) setDefaults(ctx context.Context, b Backend) error { } args.Nonce = (*hexutil.Uint64)(&nonce) } + if args.Data != nil && args.Input != nil && !bytes.Equal(*args.Data, *args.Input) { + return errors.New(`Both "data" and "input" are set and not equal. Please use "input" to pass transaction call data.`) + } return nil } func (args *SendTxArgs) toTransaction() *types.Transaction { + var input []byte + if args.Data != nil { + input = *args.Data + } else if args.Input != nil { + input = *args.Input + } if args.To == nil { - return types.NewContractCreation(uint64(*args.Nonce), (*big.Int)(args.Value), (*big.Int)(args.Gas), (*big.Int)(args.GasPrice), args.Data) + return types.NewContractCreation(uint64(*args.Nonce), (*big.Int)(args.Value), (*big.Int)(args.Gas), (*big.Int)(args.GasPrice), input) } - return types.NewTransaction(uint64(*args.Nonce), *args.To, (*big.Int)(args.Value), (*big.Int)(args.Gas), (*big.Int)(args.GasPrice), args.Data) + return types.NewTransaction(uint64(*args.Nonce), *args.To, (*big.Int)(args.Value), (*big.Int)(args.Gas), (*big.Int)(args.GasPrice), input) } // submitTransaction is a helper function that submits tx to txPool and logs a message. |