/
encoding.go
56 lines (45 loc) · 1.76 KB
/
encoding.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
package app
import (
"github.com/jinxprotocol/v4-chain/protocol/app/basic_manager"
"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/codec"
"github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/std"
"github.com/cosmos/cosmos-sdk/x/auth/tx"
)
var encodingConfig = initEncodingConfig()
// EncodingConfig specifies the concrete encoding types to use for a given app.
// This is provided for compatibility between protobuf and amino implementations.
type EncodingConfig struct {
InterfaceRegistry types.InterfaceRegistry
Codec codec.Codec
TxConfig client.TxConfig
Amino *codec.LegacyAmino
}
// GetEncodingConfig returns the EncodingConfig.
func GetEncodingConfig() EncodingConfig {
return encodingConfig
}
// makeEncodingConfig creates an EncodingConfig for an amino based test configuration.
func makeEncodingConfig() EncodingConfig {
amino := codec.NewLegacyAmino()
interfaceRegistry := types.NewInterfaceRegistry()
codec := codec.NewProtoCodec(interfaceRegistry)
txCfg := tx.NewTxConfig(codec, tx.DefaultSignModes)
return EncodingConfig{
InterfaceRegistry: interfaceRegistry,
Codec: codec,
TxConfig: txCfg,
Amino: amino,
}
}
// initEncodingConfig initializes an EncodingConfig.
func initEncodingConfig() EncodingConfig {
encConfig := makeEncodingConfig()
// This is currently required in order to support various CLI commands such as the `jinxprotocold status` command.
std.RegisterLegacyAminoCodec(encConfig.Amino)
std.RegisterInterfaces(encConfig.InterfaceRegistry)
// Skipping `ModuleBasics.RegisterLegacyAminoCodec(encodingConfig.Amino)` because it's not needed.
basic_manager.ModuleBasics.RegisterInterfaces(encConfig.InterfaceRegistry)
return encConfig
}