Skip to content

Commit

Permalink
Update bugs related to transaction fees (#279)
Browse files Browse the repository at this point in the history
* Update bugs related to transaction fees
  • Loading branch information
chowbao authored Aug 28, 2024
1 parent 0c9afe9 commit e82c6e5
Showing 1 changed file with 12 additions and 4 deletions.
16 changes: 12 additions & 4 deletions internal/transform/transaction.go
Original file line number Diff line number Diff line change
Expand Up @@ -144,13 +144,17 @@ func TransformTransaction(transaction ingest.LedgerTransaction, lhe xdr.LedgerHe
var outputTotalNonRefundableResourceFeeCharged int64
var outputTotalRefundableResourceFeeCharged int64
var outputRentFeeCharged int64
var feeAccountAddress string

// Soroban data can exist in V1 and FeeBump transactionEnvelopes
switch transaction.Envelope.Type {
case xdr.EnvelopeTypeEnvelopeTypeTx:
sorobanData, hasSorobanData = transaction.Envelope.V1.Tx.Ext.GetSorobanData()
feeAccountAddress = sourceAccount.Address()
case xdr.EnvelopeTypeEnvelopeTypeTxFeeBump:
sorobanData, hasSorobanData = transaction.Envelope.FeeBump.Tx.InnerTx.V1.Tx.Ext.GetSorobanData()
feeBumpAccount := transaction.Envelope.FeeBumpAccount()
feeAccountAddress = feeBumpAccount.Address()
}

if hasSorobanData {
Expand All @@ -160,13 +164,13 @@ func TransformTransaction(transaction ingest.LedgerTransaction, lhe xdr.LedgerHe
outputSorobanResourcesWriteBytes = uint32(sorobanData.Resources.WriteBytes)
outputInclusionFeeBid = int64(transaction.Envelope.Fee()) - outputResourceFee

accountBalanceStart, accountBalanceEnd := getAccountBalanceFromLedgerEntryChanges(transaction.FeeChanges, sourceAccount.Address())
accountBalanceStart, accountBalanceEnd := getAccountBalanceFromLedgerEntryChanges(transaction.FeeChanges, feeAccountAddress)
initialFeeCharged := accountBalanceStart - accountBalanceEnd
outputInclusionFeeCharged = initialFeeCharged - outputResourceFee

meta, ok := transaction.UnsafeMeta.GetV3()
if ok {
accountBalanceStart, accountBalanceEnd := getAccountBalanceFromLedgerEntryChanges(meta.TxChangesAfter, sourceAccount.Address())
accountBalanceStart, accountBalanceEnd := getAccountBalanceFromLedgerEntryChanges(meta.TxChangesAfter, feeAccountAddress)
outputResourceFeeRefund = accountBalanceEnd - accountBalanceStart
if meta.SorobanMeta != nil {
extV1, ok := meta.SorobanMeta.Ext.GetV1()
Expand All @@ -178,8 +182,12 @@ func TransformTransaction(transaction ingest.LedgerTransaction, lhe xdr.LedgerHe
}
}

// TODO: FeeCharged is calculated incorrectly in protocol 20. Remove when protocol is updated and the bug is fixed
outputFeeCharged = outputResourceFee - outputResourceFeeRefund + outputInclusionFeeCharged
// Protocol 20 contained a bug where the feeCharged was incorrectly calculated but was fixed for
// Protocol 21 with https://github.com/stellar/stellar-core/issues/4188
// Any Soroban Fee Bump transactions before P21 will need the below logic to calculate the correct feeCharged
if ledgerHeader.LedgerVersion < 21 && transaction.Envelope.Type == xdr.EnvelopeTypeEnvelopeTypeTxFeeBump {
outputFeeCharged = outputResourceFee - outputResourceFeeRefund + outputInclusionFeeCharged
}
}

outputCloseTime, err := utils.TimePointToUTCTimeStamp(ledgerHeader.ScpValue.CloseTime)
Expand Down

0 comments on commit e82c6e5

Please # to comment.