Skip to content

Commit

Permalink
Merge branch 'develop' of https://github.com/zeta-chain/node into che…
Browse files Browse the repository at this point in the history
…rry-pick-v12.1.1
  • Loading branch information
ws4charlie committed Jan 30, 2024
2 parents 8dab3d3 + be1c040 commit 7575d8d
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 15 deletions.
6 changes: 5 additions & 1 deletion changelog.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,10 @@
## Unreleased

### Fixes

* [1642](https://github.com/zeta-chain/node/pull/1642) - Change WhitelistERC20 authorization from group1 to group2
* [1610](https://github.com/zeta-chain/node/issues/1610) - add pending outtx hash to tracker after monitoring for 10 minutes
* [1656](https://github.com/zeta-chain/node/issues/1656) - schedule bitcoin keysign with intervals to avoid keysign failures
* [1662](https://github.com/zeta-chain/node/issues/1662) - skip Goerli BlobTxType transactions introduced in Dencun upgrade
* [1663](https://github.com/zeta-chain/node/issues/1663) - skip Mumbai empty block if ethclient sanity check fails

Expand All @@ -13,7 +16,8 @@
* [1577](https://github.com/zeta-chain/node/pull/1577) - add chain header tests in E2E tests and fix admin tests

### Features
* [1658](https://github.com/zeta-chain/node/pull/1658) - modify emission distribution to use fixed block rewards
* [1658](https://github.com/zeta-chain/node/pull/1658) - modify emission distribution to use fixed block rewards

### Fixes
* [1535](https://github.com/zeta-chain/node/issues/1535) - Avoid voting on wrong ballots due to false blockNumber in EVM tx receipt
* [1588](https://github.com/zeta-chain/node/pull/1588) - fix chain params comparison logic
Expand Down
2 changes: 1 addition & 1 deletion x/crosschain/keeper/msg_server_whitelist_erc20.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import (
// Authorized: admin policy group 1.
func (k msgServer) WhitelistERC20(goCtx context.Context, msg *types.MsgWhitelistERC20) (*types.MsgWhitelistERC20Response, error) {
ctx := sdk.UnwrapSDKContext(goCtx)
if msg.Creator != k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(zetaObserverTypes.Policy_Type_group1) {
if msg.Creator != k.zetaObserverKeeper.GetParams(ctx).GetAdminPolicyAccount(zetaObserverTypes.Policy_Type_group2) {
return nil, errorsmod.Wrap(sdkerrors.ErrUnauthorized, "Deploy can only be executed by the correct policy account")
}
erc20Addr := ethcommon.HexToAddress(msg.Erc20Address)
Expand Down
11 changes: 0 additions & 11 deletions zetaclient/btc_signer.go
Original file line number Diff line number Diff line change
Expand Up @@ -275,18 +275,7 @@ func (signer *BTCSigner) TryProcessOutTx(
return
}
myid := zetaBridge.GetKeys().GetAddress()
// Early return if the send is already processed
// FIXME: handle revert case
outboundTxTssNonce := params.OutboundTxTssNonce
included, confirmed, err := btcClient.IsSendOutTxProcessed(cctx.Index, outboundTxTssNonce, common.CoinType_Gas, logger)
if err != nil {
logger.Error().Err(err).Msgf("cannot check if send %s is processed", cctx.Index)
return
}
if included || confirmed {
logger.Info().Msgf("CCTX %s already processed; exit signer", outTxID)
return
}

sizelimit := params.OutboundTxGasLimit
gasprice, ok := new(big.Int).SetString(params.OutboundTxGasPrice, 10)
Expand Down
17 changes: 15 additions & 2 deletions zetaclient/zetacore_observer.go
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ func (co *CoreObserver) scheduleCctxEVM(
// try confirming the outtx
included, _, err := ob.IsSendOutTxProcessed(cctx.Index, params.OutboundTxTssNonce, params.CoinType, co.logger.ZetaChainWatcher)
if err != nil {
co.logger.ZetaChainWatcher.Error().Err(err).Msgf("scheduleCctxEVM: IsSendOutTxProcessed faild for chain %d", chainID)
co.logger.ZetaChainWatcher.Error().Err(err).Msgf("scheduleCctxEVM: IsSendOutTxProcessed faild for chain %d nonce %d", chainID, nonce)
continue
}
if included {
Expand Down Expand Up @@ -320,6 +320,8 @@ func (co *CoreObserver) scheduleCctxBTC(
co.logger.ZetaChainWatcher.Error().Msgf("scheduleCctxBTC: chain client is not a bitcoin client")
return
}
// #nosec G701 positive
interval := uint64(ob.GetChainParams().OutboundTxScheduleInterval)
lookahead := ob.GetChainParams().OutboundTxScheduleLookahead

// schedule at most one keysign per ticker
Expand All @@ -332,6 +334,17 @@ func (co *CoreObserver) scheduleCctxBTC(
co.logger.ZetaChainWatcher.Error().Msgf("scheduleCctxBTC: outtx %s chainid mismatch: want %d, got %d", outTxID, chainID, params.ReceiverChainId)
continue
}
// try confirming the outtx
included, confirmed, err := btcClient.IsSendOutTxProcessed(cctx.Index, nonce, params.CoinType, co.logger.ZetaChainWatcher)
if err != nil {
co.logger.ZetaChainWatcher.Error().Err(err).Msgf("scheduleCctxBTC: IsSendOutTxProcessed faild for chain %d nonce %d", chainID, nonce)
continue
}
if included || confirmed {
co.logger.ZetaChainWatcher.Info().Msgf("scheduleCctxBTC: outtx %s already included; do not schedule keysign", outTxID)
return
}

// stop if the nonce being processed is higher than the pending nonce
if nonce > btcClient.GetPendingNonce() {
break
Expand All @@ -342,7 +355,7 @@ func (co *CoreObserver) scheduleCctxBTC(
break
}
// try confirming the outtx or scheduling a keysign
if !outTxMan.IsOutTxActive(outTxID) {
if nonce%interval == zetaHeight%interval && !outTxMan.IsOutTxActive(outTxID) {
outTxMan.StartTryProcess(outTxID)
co.logger.ZetaChainWatcher.Debug().Msgf("scheduleCctxBTC: sign outtx %s with value %d\n", outTxID, params.Amount)
go signer.TryProcessOutTx(cctx, outTxMan, outTxID, ob, co.bridge, zetaHeight)
Expand Down

0 comments on commit 7575d8d

Please sign in to comment.