Commit fa2f9a1
authored
fix: Make fiat enabled transaction types remotely configurable (MetaMask#9050)
## Explanation
This PR makes the set of fiat-eligible transaction types remotely
configurable via feature flags, enabling updates without code releases.
## Changes
### Source changes
- **`constants.ts`**: Added `moneyAccountDeposit` as a fiat-eligible
type (mapped to `ETH_MAINNET_FIAT_ASSET`), removed
`perpsDepositAndOrder`, and added a `FIAT_ENABLED_TYPES` array as the
hardcoded default.
- **`utils.ts`**: Updated `deriveFiatAssetForFiatPayment` and
`resolveTransactionType` to read enabled types from feature flags via
`getFiatEnabledTypes()` instead of using the static
`FIAT_ASSET_ID_BY_TX_TYPE` map. When resolving batch transactions, falls
back to the batch transaction's own type instead of `undefined`.
- **`feature-flags.ts`**: Added `enabledTransactionTypes` to `FiatFlags`
type and added `getFiatEnabledTypes()` function that reads from
`RemoteFeatureFlagController`, falling back to `FIAT_ENABLED_TYPES`.
### Test changes
- Added tests for `getFiatEnabledTypes` covering default fallback,
missing flag, and remote override scenarios.
- Added tests for feature-flag-driven batch transaction type resolution.
- Added test for `getFiatAssetPerTransactionType` with `undefined`
transaction type to maintain 100% coverage.
## References
N/A
<!-- CURSOR_SUMMARY -->
---
> [!NOTE]
> **Medium Risk**
> Changes which transaction types and batch nested legs qualify for fiat
pay and asset selection; incorrect flag values could enable/disable fiat
flows without a release.
>
> **Overview**
> Fiat-eligible transaction types can now be driven remotely via
**`confirmations_pay_fiat.enabledTransactionTypes`**, with
**`getFiatEnabledTypes()`** falling back to a new
**`FIAT_ENABLED_TYPES`** default list.
>
> **Batch fiat asset resolution** no longer keys off “has a fiat asset
mapping”; it picks the first nested child whose type is in the enabled
list, and if none match it keeps the **batch** type (then the usual
asset lookup / ETH mainnet fallback).
>
> **Default eligibility** shifts: **`moneyAccountDeposit`** is added to
the asset map and enabled defaults; **`perpsDepositAndOrder`** is
removed from the static asset map (still covered only if the remote flag
includes it).
>
> <sup>Reviewed by [Cursor Bugbot](https://cursor.com/bugbot) for commit
88c7d3e. Bugbot is set up for automated
code reviews on this repo. Configure
[here](https://www.cursor.com/dashboard/bugbot).</sup>
<!-- /CURSOR_SUMMARY -->1 parent db968e7 commit fa2f9a1
6 files changed
Lines changed: 139 additions & 7 deletions
File tree
- packages/transaction-pay-controller
- src
- strategy/fiat
- utils
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
10 | 14 | | |
11 | 15 | | |
12 | 16 | | |
| |||
Lines changed: 8 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
33 | 33 | | |
34 | 34 | | |
35 | 35 | | |
36 | | - | |
| 36 | + | |
37 | 37 | | |
38 | | - | |
| 38 | + | |
39 | 39 | | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
Lines changed: 45 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
197 | 197 | | |
198 | 198 | | |
199 | 199 | | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
200 | 245 | | |
201 | 246 | | |
202 | 247 | | |
| |||
Lines changed: 11 additions & 5 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
11 | 14 | | |
12 | 15 | | |
13 | 16 | | |
14 | 17 | | |
15 | | - | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
19 | 21 | | |
20 | 22 | | |
21 | 23 | | |
22 | 24 | | |
23 | | - | |
| 25 | + | |
| 26 | + | |
24 | 27 | | |
25 | 28 | | |
26 | 29 | | |
27 | 30 | | |
28 | 31 | | |
29 | 32 | | |
| 33 | + | |
30 | 34 | | |
31 | 35 | | |
32 | 36 | | |
33 | 37 | | |
34 | 38 | | |
35 | | - | |
36 | | - | |
| 39 | + | |
| 40 | + | |
37 | 41 | | |
| 42 | + | |
| 43 | + | |
38 | 44 | | |
39 | 45 | | |
40 | 46 | | |
| |||
Lines changed: 52 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
17 | 18 | | |
18 | 19 | | |
19 | 20 | | |
| 21 | + | |
20 | 22 | | |
21 | 23 | | |
22 | 24 | | |
| |||
1423 | 1425 | | |
1424 | 1426 | | |
1425 | 1427 | | |
| 1428 | + | |
| 1429 | + | |
| 1430 | + | |
| 1431 | + | |
| 1432 | + | |
| 1433 | + | |
| 1434 | + | |
| 1435 | + | |
| 1436 | + | |
1426 | 1437 | | |
1427 | 1438 | | |
1428 | 1439 | | |
| |||
1518 | 1529 | | |
1519 | 1530 | | |
1520 | 1531 | | |
| 1532 | + | |
| 1533 | + | |
| 1534 | + | |
| 1535 | + | |
| 1536 | + | |
| 1537 | + | |
| 1538 | + | |
| 1539 | + | |
| 1540 | + | |
| 1541 | + | |
| 1542 | + | |
| 1543 | + | |
| 1544 | + | |
| 1545 | + | |
| 1546 | + | |
| 1547 | + | |
| 1548 | + | |
| 1549 | + | |
| 1550 | + | |
| 1551 | + | |
| 1552 | + | |
| 1553 | + | |
| 1554 | + | |
| 1555 | + | |
| 1556 | + | |
| 1557 | + | |
| 1558 | + | |
| 1559 | + | |
| 1560 | + | |
| 1561 | + | |
| 1562 | + | |
| 1563 | + | |
| 1564 | + | |
| 1565 | + | |
| 1566 | + | |
| 1567 | + | |
| 1568 | + | |
| 1569 | + | |
| 1570 | + | |
| 1571 | + | |
| 1572 | + | |
1521 | 1573 | | |
1522 | 1574 | | |
1523 | 1575 | | |
| |||
Lines changed: 19 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
12 | 13 | | |
13 | 14 | | |
14 | 15 | | |
| |||
94 | 95 | | |
95 | 96 | | |
96 | 97 | | |
| 98 | + | |
97 | 99 | | |
98 | 100 | | |
99 | 101 | | |
| |||
826 | 828 | | |
827 | 829 | | |
828 | 830 | | |
| 831 | + | |
| 832 | + | |
| 833 | + | |
| 834 | + | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
| 840 | + | |
| 841 | + | |
| 842 | + | |
| 843 | + | |
| 844 | + | |
| 845 | + | |
| 846 | + | |
| 847 | + | |
829 | 848 | | |
830 | 849 | | |
831 | 850 | | |
| |||
0 commit comments