Skip to content

Commit

Permalink
fix(llm): 🐛 fix long Memo Tag issue on Stacks (#8604)
Browse files Browse the repository at this point in the history
* fix(llm): fix long Memo Tag issue in Stacks

* chore: update change log

* chore: update unimported

* fix(llm): use `truncateUtf8` instead of `Array.slice`

* chore(llm): use `maxLength` instead of `Array.slice` on Algorand

* fix(llm): validate the memo bytes length instead of the js string length
  • Loading branch information
thesan authored Dec 6, 2024
1 parent 2146905 commit dfe2636
Show file tree
Hide file tree
Showing 7 changed files with 25 additions and 2 deletions.
7 changes: 7 additions & 0 deletions .changeset/rude-bats-fold.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
"@ledgerhq/coin-stacks": minor
"live-mobile": minor
"@ledgerhq/live-common": minor
---

Truncate Stacks memos in the input to prevent the transaction validation from failing
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { GenericMemoTagInput } from "LLM/features/MemoTag/components/GenericMemo
export default (props: MemoTagInputProps<AlgorandTransaction>) => (
<GenericMemoTagInput
{...props}
textToValue={text => text.slice(0, ALGORAND_MAX_MEMO_SIZE)}
maxLength={ALGORAND_MAX_MEMO_SIZE}
valueToTxPatch={value => tx => ({ ...tx, memo: value || undefined })}
/>
);
9 changes: 9 additions & 0 deletions apps/ledger-live-mobile/src/families/stacks/MemoTagInput.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,21 @@
import React from "react";

import { STACKS_MAX_MEMO_SIZE } from "@ledgerhq/live-common/families/stacks/constants";
import type { Transaction as StacksTransaction } from "@ledgerhq/live-common/families/stacks/types";
import type { MemoTagInputProps } from "LLM/features/MemoTag/types";
import { GenericMemoTagInput } from "LLM/features/MemoTag/components/GenericMemoTagInput";
import { truncateUtf8 } from "LLM/utils/truncateUtf8";

// `TextInputProps.maxLength` can not be used here because it counts the length of the string instead of the byte size.
// E.g.
// Javascript will evaluate a 16👍 emojis string as 34 characters.
// While this string is in fact encoded in 68B in UTF8 which is well above STX limit.
// `truncateUtf8` will truncate the string correctly, which is 8👍 with 2 characters to spare.

export default (props: MemoTagInputProps<StacksTransaction>) => (
<GenericMemoTagInput
{...props}
textToValue={text => truncateUtf8(text, STACKS_MAX_MEMO_SIZE)}
valueToTxPatch={value => tx => ({ ...tx, memo: value || undefined })}
/>
);
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import {
} from "@ledgerhq/errors";
import { AccountBridge } from "@ledgerhq/types-live";
import BigNumber from "bignumber.js";
import { STACKS_MAX_MEMO_SIZE } from "../contants";
import { StacksMemoTooLong } from "../errors";
import { Transaction, TransactionStatus } from "../types";
import { validateAddress } from "./utils/addresses";
Expand Down Expand Up @@ -44,7 +45,9 @@ export const getTransactionStatus: AccountBridge<Transaction>["getTransactionSta

if (amount.lte(0)) errors.amount = new AmountRequired();
if (totalSpent.gt(spendableBalance)) errors.amount = new NotEnoughBalance();
if (memo && memo.length > 34) errors.transaction = new StacksMemoTooLong();

const memoBytesLength = Buffer.from(memo ?? "", "utf-8").byteLength;
if (memoBytesLength > STACKS_MAX_MEMO_SIZE) errors.transaction = new StacksMemoTooLong();

return {
errors,
Expand Down
1 change: 1 addition & 0 deletions libs/coin-modules/coin-stacks/src/contants.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
export const STACKS_MAX_MEMO_SIZE = 34;
1 change: 1 addition & 0 deletions libs/ledger-live-common/.unimportedrc.json
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,7 @@
"src/families/solana/react.ts",
"src/families/solana/staking.ts",
"src/families/solana/types.ts",
"src/families/stacks/constants.ts",
"src/families/stacks/deviceTransactionConfig.ts",
"src/families/stacks/types.ts",
"src/families/stellar/types.ts",
Expand Down
2 changes: 2 additions & 0 deletions libs/ledger-live-common/src/families/stacks/constants.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
// Encapsulate for LLD & LLM
export * from "@ledgerhq/coin-stacks/contants";

0 comments on commit dfe2636

Please sign in to comment.