Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor!: use x/tx/signing in client.TxConfig #15822

Merged
merged 66 commits into from
Apr 20, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
66 commits
Select commit Hold shift + click to select a range
db53c1d
Hard break client.TxConfig
kocubinski Apr 12, 2023
0019cb9
incorporate changes from #15713
kocubinski Apr 12, 2023
f44fee6
Hard fixing
kocubinski Apr 12, 2023
49c18df
Merge branch 'main' into kocubinski/tx-config-break
kocubinski Apr 12, 2023
14539c4
go mod tidy
kocubinski Apr 12, 2023
5f2b4de
fix breakage in codec from latest main
kocubinski Apr 12, 2023
02c2340
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 13, 2023
147cbdf
remove replace for x/tx
kocubinski Apr 13, 2023
55e1d36
revert codec/ compat for x/tx 0.6.0
kocubinski Apr 13, 2023
55acfe3
x/tx v0.5.1
kocubinski Apr 13, 2023
bedd4b9
add err handling
kocubinski Apr 13, 2023
21927ef
checkpoint, proto gen
kocubinski Apr 13, 2023
623bacf
adjust lots of tests
kocubinski Apr 13, 2023
43ea1b4
fixed ante tests
kocubinski Apr 13, 2023
e32f007
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 13, 2023
bff8090
merged fix
kocubinski Apr 13, 2023
0a25910
revert (temporarily) x/tx to 0.5.1
kocubinski Apr 13, 2023
3f0a4f2
rm files
kocubinski Apr 13, 2023
d24dbc2
fix tx_test
kocubinski Apr 13, 2023
2e62758
revert x/tx
kocubinski Apr 13, 2023
2c9bd78
comment
kocubinski Apr 14, 2023
863c869
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 14, 2023
e0cecb1
maybe some fixes
kocubinski Apr 14, 2023
d0317b3
fix more test/build failures
kocubinski Apr 14, 2023
8365099
use x/tx 0.5.3
kocubinski Apr 14, 2023
ec82685
Merge branch 'main' into kocubinski/tx-config-break
kocubinski Apr 14, 2023
dc0d717
update rosetta go.mod
kocubinski Apr 14, 2023
c4c4cdd
Merge branch 'kocubinski/tx-config-break' of github.com:cosmos/cosmos…
kocubinski Apr 14, 2023
6e691fc
liniting
kocubinski Apr 14, 2023
0010ceb
linting fixes
kocubinski Apr 14, 2023
0b9eb03
lint fix
kocubinski Apr 14, 2023
4843d63
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 17, 2023
caf6987
clean up config
kocubinski Apr 17, 2023
a246afc
go mod tidy
kocubinski Apr 17, 2023
c6f2033
tidy rosetta
kocubinski Apr 17, 2023
978f4f4
rwmutex
kocubinski Apr 17, 2023
a8069dc
lint fix
kocubinski Apr 17, 2023
3851398
proper lazy init with sync.once
kocubinski Apr 17, 2023
6c363f5
clean up todos
kocubinski Apr 18, 2023
c66aefd
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 18, 2023
8fc3108
clean up, comments
kocubinski Apr 18, 2023
7364f41
attempt remove redundant arg
kocubinski Apr 18, 2023
a0acb58
move lazy registry
kocubinski Apr 18, 2023
f04a10c
store init error
kocubinski Apr 18, 2023
59ab3ce
test fixes
kocubinski Apr 18, 2023
ae3fe65
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 18, 2023
79c0f89
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 18, 2023
d4bb593
handle default sign mode todos
kocubinski Apr 18, 2023
96a693d
x/tx 0.5.5
kocubinski Apr 18, 2023
0796a6c
go mod tidy
kocubinski Apr 18, 2023
ad658b5
rm more todos
kocubinski Apr 18, 2023
c270393
lint fix
kocubinski Apr 18, 2023
4ad00c5
clean up handler creation API
kocubinski Apr 18, 2023
8e516b2
fix more test bugs
kocubinski Apr 18, 2023
f138251
finish simd/root command
kocubinski Apr 18, 2023
8973802
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 18, 2023
76c6363
a little clean up
kocubinski Apr 19, 2023
dd3cd93
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 19, 2023
05d52af
Add CHANGELOG entries for API breaks
kocubinski Apr 19, 2023
f3211b8
Add UPGRADING entries
kocubinski Apr 19, 2023
147dc83
Merge branch 'main' into kocubinski/tx-config-break
kocubinski Apr 19, 2023
d1af44c
PR fixes
kocubinski Apr 19, 2023
e8398d2
Merge branch 'main' of github.com:cosmos/cosmos-sdk into kocubinski/t…
kocubinski Apr 19, 2023
cd4f11f
lint fix
kocubinski Apr 19, 2023
2bb6750
Refactor NewTxConfig
kocubinski Apr 20, 2023
3bcaa98
lazy loading won't work in InterfaceRegistry ctr won't work yet.
kocubinski Apr 20, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
revert x/tx
  • Loading branch information
kocubinski committed Apr 13, 2023
commit 2e627584cefcdee0cafa591ebd59ed8cc1c163f7
1 change: 0 additions & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -172,7 +172,6 @@ replace (
github.com/gin-gonic/gin => github.com/gin-gonic/gin v1.8.1
// Downgraded to avoid bugs in following commits which caused simulations to fail.
github.com/syndtr/goleveldb => github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7
cosmossdk.io/x/tx => ./x/tx
)

retract (
Expand Down
4 changes: 3 additions & 1 deletion x/group/client/cli/tx_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,12 +10,14 @@ import (
"strings"
"testing"

sdkmath "cosmossdk.io/math"
abci "github.com/cometbft/cometbft/abci/types"
rpcclientmock "github.com/cometbft/cometbft/rpc/client/mock"
"github.com/cosmos/gogoproto/proto"
"github.com/stretchr/testify/suite"

_ "cosmossdk.io/api/cosmos/group/v1"
sdkmath "cosmossdk.io/math"

"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/client/flags"
"github.com/cosmos/cosmos-sdk/crypto/hd"
Expand Down
12 changes: 12 additions & 0 deletions x/tx/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,22 @@ Ref: https://keepachangelog.com/en/1.0.0/

## Unreleased

### API Breaking

* [#15709](https://github.com/cosmos/cosmos-sdk/pull/15709):
* `GetSignersContext` has been renamed to `signing.Context`
* `GetSigners` now returns `[][]byte` instead of `[]string`
* `GetSignersOptions` has been renamed to `signing.Options` and requires `address.Codec`s for account and validator addresses
* `GetSignersOptions.ProtoFiles` has been renamed to `signing.Options.FileResolver`

## v0.5.1

### Features

* [#15414](https://github.com/cosmos/cosmos-sdk/pull/15414) Add basic transaction decoding support.

## v0.5.0

### API Breaking

* [#15581](https://github.com/cosmos/cosmos-sdk/pull/15581) `GetSignersOptions` and `directaux.SignModeHandlerOptions` now
Expand Down
55 changes: 17 additions & 38 deletions x/tx/decode/decode.go
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
package decode

import (
"github.com/cosmos/cosmos-proto/anyutil"
"google.golang.org/protobuf/proto"
"google.golang.org/protobuf/reflect/protoregistry"
"fmt"

v1beta1 "cosmossdk.io/api/cosmos/tx/v1beta1"
"cosmossdk.io/errors"
"github.com/cosmos/cosmos-proto/anyutil"
"google.golang.org/protobuf/proto"

"cosmossdk.io/x/tx/signing"
)

Expand All @@ -15,51 +16,28 @@ type DecodedTx struct {
Messages []proto.Message
Tx *v1beta1.Tx
TxRaw *v1beta1.TxRaw
Signers []string
Signers [][]byte
TxBodyHasUnknownNonCriticals bool
}

// Decoder contains the dependencies required for decoding transactions.
type Decoder struct {
getSignersCtx *signing.GetSignersContext
typeResolver protoregistry.MessageTypeResolver
protoFiles *protoregistry.Files
signingCtx *signing.Context
}

// Options are options for creating a Decoder.
type Options struct {
// ProtoFiles are the protobuf files to use for resolving message descriptors.
// If it is nil, the global protobuf registry will be used.
ProtoFiles *protoregistry.Files
TypeResolver protoregistry.MessageTypeResolver
SigningContext *signing.GetSignersContext
SigningContext *signing.Context
}

// NewDecoder creates a new Decoder for decoding transactions.
func NewDecoder(options Options) (*Decoder, error) {
if options.ProtoFiles == nil {
options.ProtoFiles = protoregistry.GlobalFiles
}

if options.TypeResolver == nil {
options.TypeResolver = protoregistry.GlobalTypes
}

getSignersCtx := options.SigningContext
if getSignersCtx == nil {
var err error
getSignersCtx, err = signing.NewGetSignersContext(signing.GetSignersOptions{
ProtoFiles: options.ProtoFiles,
})
if err != nil {
return nil, err
}
if options.SigningContext == nil {
return nil, fmt.Errorf("signing context is required")
}

return &Decoder{
getSignersCtx: getSignersCtx,
protoFiles: options.ProtoFiles,
typeResolver: options.TypeResolver,
signingCtx: options.SigningContext,
}, nil
}

Expand All @@ -74,7 +52,8 @@ func (d *Decoder) Decode(txBytes []byte) (*DecodedTx, error) {
var raw v1beta1.TxRaw

// reject all unknown proto fields in the root TxRaw
err = RejectUnknownFieldsStrict(txBytes, raw.ProtoReflect().Descriptor(), d.protoFiles)
fileResolver := d.signingCtx.FileResolver()
err = RejectUnknownFieldsStrict(txBytes, raw.ProtoReflect().Descriptor(), fileResolver)
if err != nil {
return nil, errors.Wrap(ErrTxDecode, err.Error())
}
Expand All @@ -87,7 +66,7 @@ func (d *Decoder) Decode(txBytes []byte) (*DecodedTx, error) {
var body v1beta1.TxBody

// allow non-critical unknown fields in TxBody
txBodyHasUnknownNonCriticals, err := RejectUnknownFields(raw.BodyBytes, body.ProtoReflect().Descriptor(), true, d.protoFiles)
txBodyHasUnknownNonCriticals, err := RejectUnknownFields(raw.BodyBytes, body.ProtoReflect().Descriptor(), true, fileResolver)
if err != nil {
return nil, errors.Wrap(ErrTxDecode, err.Error())
}
Expand All @@ -100,7 +79,7 @@ func (d *Decoder) Decode(txBytes []byte) (*DecodedTx, error) {
var authInfo v1beta1.AuthInfo

// reject all unknown proto fields in AuthInfo
err = RejectUnknownFieldsStrict(raw.AuthInfoBytes, authInfo.ProtoReflect().Descriptor(), d.protoFiles)
err = RejectUnknownFieldsStrict(raw.AuthInfoBytes, authInfo.ProtoReflect().Descriptor(), fileResolver)
if err != nil {
return nil, errors.Wrap(ErrTxDecode, err.Error())
}
Expand All @@ -116,15 +95,15 @@ func (d *Decoder) Decode(txBytes []byte) (*DecodedTx, error) {
Signatures: raw.Signatures,
}

var signers []string
var signers [][]byte
var msgs []proto.Message
for _, anyMsg := range body.Messages {
msg, signerErr := anyutil.Unpack(anyMsg, d.protoFiles, d.typeResolver)
msg, signerErr := anyutil.Unpack(anyMsg, fileResolver, d.signingCtx.TypeResolver())
if signerErr != nil {
return nil, errors.Wrap(ErrTxDecode, signerErr.Error())
}
msgs = append(msgs, msg)
ss, signerErr := d.getSignersCtx.GetSigners(msg)
ss, signerErr := d.signingCtx.GetSigners(msg)
if signerErr != nil {
return nil, errors.Wrap(ErrTxDecode, signerErr.Error())
}
Expand Down
26 changes: 23 additions & 3 deletions x/tx/decode/decode_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package decode_test

import (
"encoding/hex"
"fmt"
"testing"

Expand All @@ -9,8 +10,10 @@ import (
"cosmossdk.io/api/cosmos/crypto/secp256k1"
signingv1beta1 "cosmossdk.io/api/cosmos/tx/signing/v1beta1"
txv1beta1 "cosmossdk.io/api/cosmos/tx/v1beta1"

"cosmossdk.io/x/tx/decode"
"cosmossdk.io/x/tx/internal/testpb"
"cosmossdk.io/x/tx/signing"

"github.com/cosmos/cosmos-proto/anyutil"
"github.com/stretchr/testify/require"
Expand All @@ -36,6 +39,16 @@ func TestDecode(t *testing.T) {
Sequence: accSeq,
})

signingCtx, err := signing.NewContext(signing.Options{
AddressCodec: dummyAddressCodec{},
ValidatorAddressCodec: dummyAddressCodec{},
})
require.NoError(t, err)
decoder, err := decode.NewDecoder(decode.Options{
SigningContext: signingCtx,
})
require.NoError(t, err)

testCases := []struct {
name string
msg proto.Message
Expand Down Expand Up @@ -83,9 +96,6 @@ func TestDecode(t *testing.T) {
txBytes, err := proto.Marshal(tx)
require.NoError(t, err)

decoder, err := decode.NewDecoder(decode.Options{})
require.NoError(t, err)

decodeTx, err := decoder.Decode(txBytes)
if tc.error != "" {
require.EqualError(t, err, tc.error)
Expand All @@ -99,3 +109,13 @@ func TestDecode(t *testing.T) {
})
}
}

type dummyAddressCodec struct{}

func (d dummyAddressCodec) StringToBytes(text string) ([]byte, error) {
return hex.DecodeString(text)
}

func (d dummyAddressCodec) BytesToString(bz []byte) (string, error) {
return hex.EncodeToString(bz), nil
}
7 changes: 7 additions & 0 deletions x/tx/internal/testpb/signers.proto
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
syntax = "proto3";

import "cosmos/msg/v1/msg.proto";
import "cosmos_proto/cosmos.proto";

option go_package = "cosmossdk.io/x/tx/internal/testpb";

Expand Down Expand Up @@ -58,6 +59,12 @@ message BadSigner {
option (cosmos.msg.v1.signer) = "signer";
bytes signer = 1;
}

message NoSignerOption {
bytes signer = 1;
}

message ValidatorSigner {
option (cosmos.msg.v1.signer) = "signer";
string signer = 1 [(cosmos_proto.scalar) = "cosmos.ValidatorAddressString"];
}
Loading