wormhole/node/pkg/wormconn/send_tx.go

97 lines
2.6 KiB
Go
Raw Normal View History

Node: Initial guardiand changes for accounting (#2181) * node: guardiand support for accounting Change-Id: I97fe1f6d6d71a5803881ff4c793e3c30f22b14d8 * Node: Tie accounting into the guardian Change-Id: I31600d18176f516b75b3eb046fd7ac6e54e1b133 * Node: accounting tests and metrics Change-Id: Ieb139772edf464ed1ab202861babeaf0f857ad6b * Node: minor tweak to accounting metrics Change-Id: Iad2b7e34870734f0c5e5d538c0ac86269a9a4728 * Node: load accounting key Change-Id: I228ce23e63b556d751000b97097202eda48650aa * More work in progress Change-Id: I85088d26c05cf02d26043cf6ee8c67efd13f2ea4 * Node: send observations to accounting contract Change-Id: Ib90909c2ee705d5e2a7e6cf3a6ec4ba7519e2eb1 * Node: Fix lint error in accounting tests Change-Id: Id73397cf45107243a9f68ba82bed3ccf2b0299b5 * Node: Need to copy libwasmvm.so Change-Id: I2856c8964ca082f1f4014d6db9fb1b2dc4e64409 * Node: Rename wormchain to wormconn Change-Id: I6782be733ebdd92b908228d3984a906aa4c795f7 * Node: moving accounting check after governor Change-Id: I064c77d30514715c6f8b6b5da50806a5e1adf657 * Node: Add accounting status to heartbeat Change-Id: I0ae3e476386cfaccc5c877ee1351dbe41c0358c7 * Node: start of accounting integration work Change-Id: I8ad206eb7fc07aa9e1a2ebc321f2c490ec36b51e * Node: More broadcast tx stuff Change-Id: Id2cc83df859310c013665eaa9c6ce3033bb1d9c5 * Node: Can actually send a request to accounting Change-Id: I6af5d59c53939f58b2f13ae501914bef260592f2 * Node: More accounting tx broadcast stuff Change-Id: If758e49f8928807e87053320e9330c7208aad490 * Node: config changes for accounting Change-Id: I2803cceb188d04c557a52aa9aa8ba7296da8879f * Node: More accounting changes Change-Id: Id979af0ec6ab8484bc094072f3febf39355351ca * Node/Acct: Use new observation request format * Node/acct: use new contract interface * Node/acct: fix minor copy/paste error * Node: Clean up comments and lint errors * Node: disable accounting in dev by default * Node: Fix test failure * Remove test code * Switch messages to debug, rename Run() * check for "out of gas" * Use worker routine to submit observations * Rename mutex to reflect what it protects * Create handleEvents func * Remove FinalizeObservation * Node/Acct: Trying to use tm library for watcher * Node/acct: switch watcher to use tm library * Node/Acct: Need separate WS parm for accounting * Node/Acct: Fix compile error in tests * Node/Acct: Minor rework * Node: add wormchain as a dep to remove stale code * Node/Acct: GS index is not correct in requests * Node/Acct: Peg connection error metric * Node/Acct: Add wormchain to node docker file * Node/Acct: Fix for double base64 decode * Node/Acct: Change public key to sender address * Node/Acct: Fix lint error * Node/Acct: key pass phrase change * Node/Acct: Pass guardian index in obs req * Node/Acct: No go on submit observation * Node/Acct: Don't double encode tx_hash * Node/Acct: Remove unneeded base64 encoding * Node/Acct: handle submit channel overflow * Node/Acct: Added a TODO to document a review issue * Node/Acct: Fix for checking if channel is full Co-authored-by: Conor Patrick <conorpp94@gmail.com>
2023-01-16 04:33:01 -08:00
package wormconn
import (
"context"
"fmt"
txclient "github.com/cosmos/cosmos-sdk/client/tx"
sdktypes "github.com/cosmos/cosmos-sdk/types"
sdktx "github.com/cosmos/cosmos-sdk/types/tx"
"github.com/cosmos/cosmos-sdk/types/tx/signing"
authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing"
auth "github.com/cosmos/cosmos-sdk/x/auth/types"
)
func (c *ClientConn) SignAndBroadcastTx(ctx context.Context, msg sdktypes.Msg) (*sdktx.BroadcastTxResponse, error) {
// Lock to protect the wallet sequence number.
c.mutex.Lock()
defer c.mutex.Unlock()
authClient := auth.NewQueryClient(c.c)
accountQuery := &auth.QueryAccountRequest{
Address: c.senderAddress,
}
resp, err := authClient.Account(ctx, accountQuery)
if err != nil {
return nil, fmt.Errorf("failed to fetch account: %w", err)
}
var account auth.AccountI
if err := c.encCfg.InterfaceRegistry.UnpackAny(resp.Account, &account); err != nil {
return nil, fmt.Errorf("failed to unmarshal account info: %w", err)
}
builder := c.encCfg.TxConfig.NewTxBuilder()
if err := builder.SetMsgs(msg); err != nil {
return nil, fmt.Errorf("failed to add message to builder: %w", err)
}
builder.SetGasLimit(2000000) // TODO: Maybe simulate and use the result
// The tx needs to be signed in 2 passes: first we populate the SignerInfo
// inside the TxBuilder and then sign the payload.
sequence := account.GetSequence()
sig := signing.SignatureV2{
PubKey: c.privateKey.PubKey(),
Data: &signing.SingleSignatureData{
SignMode: c.encCfg.TxConfig.SignModeHandler().DefaultMode(),
Signature: nil,
},
Sequence: sequence,
}
if err := builder.SetSignatures(sig); err != nil {
return nil, fmt.Errorf("failed to set SignerInfo: %w", err)
}
signerData := authsigning.SignerData{
ChainID: "wormchain",
AccountNumber: account.GetAccountNumber(),
Sequence: sequence,
}
sig, err = txclient.SignWithPrivKey(
c.encCfg.TxConfig.SignModeHandler().DefaultMode(),
signerData,
builder,
c.privateKey,
c.encCfg.TxConfig,
sequence,
)
if err != nil {
return nil, fmt.Errorf("failed to sign tx: %w", err)
}
if err := builder.SetSignatures(sig); err != nil {
return nil, fmt.Errorf("failed to update tx signature: %w", err)
}
txBytes, err := c.encCfg.TxConfig.TxEncoder()(builder.GetTx())
if err != nil {
return nil, fmt.Errorf("failed to marshal tx: %w", err)
}
client := sdktx.NewServiceClient(c.c)
// Returns *BroadcastTxResponse
txResp, err := client.BroadcastTx(
ctx,
&sdktx.BroadcastTxRequest{
Mode: sdktx.BroadcastMode_BROADCAST_MODE_BLOCK,
TxBytes: txBytes,
},
)
if err != nil {
return nil, fmt.Errorf("failed to broadcast tx: %w", err)
}
return txResp, nil
}