Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/develop' into ledgerinit
Browse files Browse the repository at this point in the history
* upstream/develop:
  `XRPFees`: Fee setting and handling improvements (XRPLF#4247)
  • Loading branch information
ximinez committed Feb 3, 2023
2 parents c72cf84 + e4b17d1 commit 4e93493
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 10 deletions.
2 changes: 1 addition & 1 deletion src/ripple/app/misc/FeeVoteImpl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -164,7 +164,7 @@ FeeVoteImpl::doValidation(
auto vote = [&v, this](
auto const current,
XRPAmount target,
auto convertCallback,
auto const& convertCallback,
const char* name,
auto const& sfield) {
if (current != target)
Expand Down
22 changes: 13 additions & 9 deletions src/ripple/app/tx/impl/Change.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -93,12 +93,16 @@ Change::preclaim(PreclaimContext const& ctx)
case ttFEE:
if (ctx.view.rules().enabled(featureXRPFees))
{
// The ttFEE transaction format defines these fields as
// optional, but once the XRPFees feature is enabled, they are
// required.
if (!ctx.tx.isFieldPresent(sfBaseFeeDrops) ||
!ctx.tx.isFieldPresent(sfReserveBaseDrops) ||
!ctx.tx.isFieldPresent(sfReserveIncrementDrops))
return temMALFORMED;
// The transaction should only have one set of fields or the
// other.
// The ttFEE transaction format defines these fields as
// optional, but once the XRPFees feature is enabled, they are
// forbidden.
if (ctx.tx.isFieldPresent(sfBaseFee) ||
ctx.tx.isFieldPresent(sfReferenceFeeUnits) ||
ctx.tx.isFieldPresent(sfReserveBase) ||
Expand All @@ -107,18 +111,18 @@ Change::preclaim(PreclaimContext const& ctx)
}
else
{
// The transaction format formerly enforced these fields as
// required. With featureXRPFees, those fields were made
// optional with the expectation that they won't be used once
// the feature is enabled. Since the feature hasn't yet
// been enabled, they should all still be here.
// The ttFEE transaction format formerly defined these fields
// as required. When the XRPFees feature was implemented, they
// were changed to be optional. Until the feature has been
// enabled, they are required.
if (!ctx.tx.isFieldPresent(sfBaseFee) ||
!ctx.tx.isFieldPresent(sfReferenceFeeUnits) ||
!ctx.tx.isFieldPresent(sfReserveBase) ||
!ctx.tx.isFieldPresent(sfReserveIncrement))
return temMALFORMED;
// The transaction should only have one or the other. If the new
// fields are present without the amendment, that's bad, too.
// The ttFEE transaction format defines these fields as
// optional, but without the XRPFees feature, they are
// forbidden.
if (ctx.tx.isFieldPresent(sfBaseFeeDrops) ||
ctx.tx.isFieldPresent(sfReserveBaseDrops) ||
ctx.tx.isFieldPresent(sfReserveIncrementDrops))
Expand Down

0 comments on commit 4e93493

Please sign in to comment.