Skip to content

Commit

Permalink
fix: invalid balance coin should trigger an error
Browse files Browse the repository at this point in the history
By rejecting the trace during the processing phrase, we allow an
other processor to handle it, and we also prevent a database error
that occurs during the insert when the unmarshaled coin contains invalid
UTF-8 characters (see EmerisHQ/demeris-backend#794).
  • Loading branch information
tbruyelle committed May 30, 2022
1 parent edef1fc commit 8c0c7df
Show file tree
Hide file tree
Showing 2 changed files with 5 additions and 4 deletions.
4 changes: 2 additions & 2 deletions tracelistener/processor/datamarshaler/impl_v44.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,14 +79,14 @@ func (d DataMarshaler) Bank(data tracelistener.TraceOperation) (models.BalanceRo
// (picture someone who sends all their balance to another address).
// To work around this issue, we don't return when coin is invalid when data.Operation is "delete",
// and we set balance == 0 instead.
if !coins.IsValid() {
if err := coins.Validate(); err != nil {
if data.Operation == tracelistener.DeleteOp.String() {
// rawAddress still contains the length prefix, so we have to jump it by
// reading 1 byte after len(addrBytes)
denom := rawAddress[len(addrBytes)+1:]
coins.Denom = string(denom)
} else {
return models.BalanceRow{}, nil
return models.BalanceRow{}, fmt.Errorf("invalid balance coin: %w", err)
}
}

Expand Down
5 changes: 3 additions & 2 deletions tracelistener/processor/datamarshaler/impl_v44_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,12 +46,12 @@ func TestDataMarshalerBank(t *testing.T) {
expectedError: "cannot parse address from balance store key, invalid key",
},
{
name: "ok: value is empty",
name: "fail: value is empty",
tr: tracelistener.TraceOperation{
Operation: tracelistener.WriteOp.String(),
Key: append(types.BalancesPrefix, []byte{3, 'a', 'd', 'd'}...),
},
expectedBalanceRow: models.BalanceRow{},
expectedError: "invalid balance coin: invalid denom: ",
},
{
name: "ok: value is not a valid coin",
Expand All @@ -60,6 +60,7 @@ func TestDataMarshalerBank(t *testing.T) {
Key: append(types.BalancesPrefix, []byte{3, 'a', 'd', 'd'}...),
Value: []byte("\n$\n\x05uiris\x12\x1b509625143506063788050678455"),
},
expectedError: "invalid balance coin: invalid denom: \n\x05uiris\x12\x1b509625143506063788050678455",
},
{
name: "ok: value is not a valid coin but operation is delete",
Expand Down

0 comments on commit 8c0c7df

Please sign in to comment.