From 19537dc7196e7583894285cc9575cf03cd9daab8 Mon Sep 17 00:00:00 2001 From: Damian Nolan Date: Thu, 7 Apr 2022 15:01:22 +0200 Subject: [PATCH] refactoring to invoke distribution logic if fees are found, only calling ack and timeout cbs once --- modules/apps/29-fee/ibc_module.go | 26 ++++++++++---------------- 1 file changed, 10 insertions(+), 16 deletions(-) diff --git a/modules/apps/29-fee/ibc_module.go b/modules/apps/29-fee/ibc_module.go index 89d27b9f86f..e4dab034b04 100644 --- a/modules/apps/29-fee/ibc_module.go +++ b/modules/apps/29-fee/ibc_module.go @@ -233,15 +233,12 @@ func (im IBCModule) OnAcknowledgementPacket( packetID := channeltypes.NewPacketId(packet.SourceChannel, packet.SourcePort, packet.Sequence) feesInEscrow, found := im.keeper.GetFeesInEscrow(ctx, packetID) - if !found { - // return underlying callback if no fee found for given packetID - return im.app.OnAcknowledgementPacket(ctx, packet, ack.Result, relayer) - } - - im.keeper.DistributePacketFees(ctx, ack.ForwardRelayerAddress, relayer, feesInEscrow.PacketFees) + if found { + im.keeper.DistributePacketFees(ctx, ack.ForwardRelayerAddress, relayer, feesInEscrow.PacketFees) - // removes the fees from the store as fees are now paid - im.keeper.DeleteFeesInEscrow(ctx, packetID) + // removes the fees from the store as fees are now paid + im.keeper.DeleteFeesInEscrow(ctx, packetID) + } // call underlying callback return im.app.OnAcknowledgementPacket(ctx, packet, ack.Result, relayer) @@ -260,15 +257,12 @@ func (im IBCModule) OnTimeoutPacket( packetID := channeltypes.NewPacketId(packet.SourceChannel, packet.SourcePort, packet.Sequence) feesInEscrow, found := im.keeper.GetFeesInEscrow(ctx, packetID) - if !found { - // return underlying callback if fee not found for given packetID - return im.app.OnTimeoutPacket(ctx, packet, relayer) - } - - im.keeper.DistributePacketFeesOnTimeout(ctx, relayer, feesInEscrow.PacketFees) + if found { + im.keeper.DistributePacketFeesOnTimeout(ctx, relayer, feesInEscrow.PacketFees) - // removes the fee from the store as fee is now paid - im.keeper.DeleteFeesInEscrow(ctx, packetID) + // removes the fee from the store as fee is now paid + im.keeper.DeleteFeesInEscrow(ctx, packetID) + } // call underlying callback return im.app.OnTimeoutPacket(ctx, packet, relayer)