From 58bcd21d6318be5de0fc147974e5865dacc04861 Mon Sep 17 00:00:00 2001 From: Dominik Guzei Date: Mon, 11 Nov 2024 18:52:10 +0100 Subject: [PATCH] fix: Catch send error for staking conway wallets which have not registered voting rights yet [LW-11518] Signed-off-by: Dominik Guzei --- CHANGELOG.md | 4 ++++ source/renderer/app/api/api.ts | 3 +++ source/renderer/app/api/errors.ts | 6 ++++++ .../dialogs/send-confirmation/SendConfirmation.view.tsx | 3 ++- source/renderer/app/i18n/locales/defaultMessages.json | 5 +++++ source/renderer/app/i18n/locales/en-US.json | 1 + source/renderer/app/i18n/locales/ja-JP.json | 1 + source/renderer/app/stores/WalletsStore.ts | 8 +++++++- storybook/stories/wallets/send/WalletSend.stories.tsx | 8 +++++++- translations/messages.json | 5 +++++ 10 files changed, 41 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index eb39c21eb7..f32764fc30 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,10 @@ - Update `cardano-node` to 10.1.1 via `cardano-wallet` [`ba7d3340968`](https://github.com/cardano-foundation/cardano-wallet/commit/ba7d33409680f4e75ef260add8744dcf71f40a77) ([PR 3229](https://github.com/input-output-hk/daedalus/pull/3229)) +### Fixes + +- Handle createTransaction error when Conway era wallet has staking rewards but has not participated in governance yet ([PR 3237](https://github.com/input-output-hk/daedalus/pull/3237) + ## 6.0.2 ### Fixes diff --git a/source/renderer/app/api/api.ts b/source/renderer/app/api/api.ts index 116e92933a..d533febfe9 100644 --- a/source/renderer/app/api/api.ts +++ b/source/renderer/app/api/api.ts @@ -1016,6 +1016,9 @@ export default class AdaApi { .set('wrongEncryptionPassphrase') .where('code', 'bad_request') .inc('message', 'passphrase is too short') + .set('conwayWalletNotDelegatedToDRep') + .where('code', 'created_invalid_transaction') + .inc('message', 'ConwayWdrlNotDelegatedToDRep') .set('transactionIsTooBig', true, { linkLabel: 'tooBigTransactionErrorLinkLabel', linkURL: 'tooBigTransactionErrorLinkURL', diff --git a/source/renderer/app/api/errors.ts b/source/renderer/app/api/errors.ts index acac84ba15..1146da01bc 100644 --- a/source/renderer/app/api/errors.ts +++ b/source/renderer/app/api/errors.ts @@ -121,6 +121,12 @@ export const messages = defineMessages({ description: '"Balance after transaction would not leave enough ada in the wallet to support tokens remaining in wallet', }, + conwayWalletNotDelegatedToDRep: { + id: 'api.errors.conwayWalletNotDelegatedToDRep', + defaultMessage: '!!!conwayWalletNotDelegatedToDRep', + description: + 'Error message shown when conway era wallet has staking rewards but has not participated in governance yet.', + }, }); type Balances = { diff --git a/source/renderer/app/containers/wallet/dialogs/send-confirmation/SendConfirmation.view.tsx b/source/renderer/app/containers/wallet/dialogs/send-confirmation/SendConfirmation.view.tsx index 37fddf1d35..c8a786b7aa 100644 --- a/source/renderer/app/containers/wallet/dialogs/send-confirmation/SendConfirmation.view.tsx +++ b/source/renderer/app/containers/wallet/dialogs/send-confirmation/SendConfirmation.view.tsx @@ -89,7 +89,8 @@ function View({ !isPasswordValid({ isHardwareWallet, isValid: passphraseField.isValid, - }), + }) || + !!error, }, ]; diff --git a/source/renderer/app/i18n/locales/defaultMessages.json b/source/renderer/app/i18n/locales/defaultMessages.json index a219ce8f39..1e8322ce0b 100644 --- a/source/renderer/app/i18n/locales/defaultMessages.json +++ b/source/renderer/app/i18n/locales/defaultMessages.json @@ -95,6 +95,11 @@ "defaultMessage": "!!!Insufficient funds to support tokens. You need at least an additional {adaAmount} ADA in your wallet to process this transaction.", "description": "\"Balance after transaction would not leave enough ada in the wallet to support tokens remaining in wallet", "id": "api.errors.NotEnoughFundsForTransactionFeesErrorWithTokens" + }, + { + "defaultMessage": "!!!conwayWalletNotDelegatedToDRep", + "description": "Error message shown when conway era wallet has staking rewards but has not participated in governance yet.", + "id": "api.errors.conwayWalletNotDelegatedToDRep" } ], "path": "source/renderer/app/api/errors.ts" diff --git a/source/renderer/app/i18n/locales/en-US.json b/source/renderer/app/i18n/locales/en-US.json index 16db52caa1..005021c4b6 100755 --- a/source/renderer/app/i18n/locales/en-US.json +++ b/source/renderer/app/i18n/locales/en-US.json @@ -34,6 +34,7 @@ "api.errors.WalletAlreadyImportedError": "Wallet you are trying to import already exists.", "api.errors.WalletAlreadyRestoredError": "Wallet you are trying to restore already exists.", "api.errors.WalletFileImportError": "Wallet could not be imported, please make sure you are providing a correct file.", + "api.errors.conwayWalletNotDelegatedToDRep": "Daedalus cannot process this transaction because of blocked staking rewards. To unblock your rewards go to the Cardano voting power delegation tab and delegate your voting power", "api.errors.inputsDepleted": "Your wallet contains only reward funds.
Please send at least 1 ADA to your wallet so that you can spend the funds.", "api.errors.invalidAddress": "Please enter a valid address.", "api.errors.invalidSmashServer": "This URL is not a valid SMASH server", diff --git a/source/renderer/app/i18n/locales/ja-JP.json b/source/renderer/app/i18n/locales/ja-JP.json index a98f6aa8b0..a51124883a 100755 --- a/source/renderer/app/i18n/locales/ja-JP.json +++ b/source/renderer/app/i18n/locales/ja-JP.json @@ -34,6 +34,7 @@ "api.errors.WalletAlreadyImportedError": "インポートしようとしているウォレットは既に存在します。", "api.errors.WalletAlreadyRestoredError": "復元しようとしているウォレットは既に存在します。", "api.errors.WalletFileImportError": "ウォレットをインポートできませんでした。有効なファイルを指定していることを確認してください。", + "api.errors.conwayWalletNotDelegatedToDRep": "ステーキング報酬がブロックされているため、このトランザクションを処理できません。報酬のブロックを解除するには、Cardano投票権の委任タブに移動し、投票権を委任してください。", "api.errors.inputsDepleted": "このウォレットには報酬として得られた資金しか入っていません。
資金を使用するには1ADA以上をウォレットに入金してください。", "api.errors.invalidAddress": "有効なアドレスを入力してください。", "api.errors.invalidSmashServer": "このURLは有効なSMASHサーバーではありません", diff --git a/source/renderer/app/stores/WalletsStore.ts b/source/renderer/app/stores/WalletsStore.ts index 2c29904715..4cb40dfa45 100644 --- a/source/renderer/app/stores/WalletsStore.ts +++ b/source/renderer/app/stores/WalletsStore.ts @@ -837,7 +837,12 @@ export default class WalletsStore extends Store { : null; const wallet = this.active; if (!wallet) throw new Error('Active wallet required before sending.'); - // @ts-ignore ts-migrate(1320) FIXME: Type of 'await' operand must either be a valid pro... Remove this comment to see the full error message + + /** + * Do not try to catch the request error here, its intended to throw + * a localized error created in app/api/api.ts + */ + // @ts-ignore await this.sendMoneyRequest.execute({ address: receiver, amount: parseInt(amount, 10), @@ -847,6 +852,7 @@ export default class WalletsStore extends Store { assets: formattedAssets, hasAssetsRemainingAfterTransaction, }); + // The following code will not be executed if the request above fails this.analytics.sendEvent( EventCategories.WALLETS, 'Transaction made', diff --git a/storybook/stories/wallets/send/WalletSend.stories.tsx b/storybook/stories/wallets/send/WalletSend.stories.tsx index 89716a8f01..653fdcf3f1 100644 --- a/storybook/stories/wallets/send/WalletSend.stories.tsx +++ b/storybook/stories/wallets/send/WalletSend.stories.tsx @@ -15,11 +15,13 @@ import { NUMBER_OPTIONS } from '../../../../source/renderer/app/config/profileCo import Wallet, { HwDeviceStatuses, } from '../../../../source/renderer/app/domains/Wallet'; +import { messages } from '../../../../source/renderer/app/api/errors'; // Screens import WalletSendForm from '../../../../source/renderer/app/components/wallet/WalletSendForm'; import type { WalletTokens } from '../../../../source/renderer/app/api/assets/types'; import { WalletSendConfirmationDialogView } from '../../../../source/renderer/app/containers/wallet/dialogs/send-confirmation/SendConfirmation.view'; import { noopAnalyticsTracker as analyticsTracker } from '../../../../source/renderer/app/analytics'; +import LocalizableError from '../../../../source/renderer/app/i18n/LocalizableError'; const allAssets = [ generateAssetToken( @@ -470,7 +472,11 @@ storiesOf('Wallets / Send', module) isSubmitting={boolean('isSubmitting', false)} isHardwareWallet={boolean('isHardwareWallet', false)} formattedTotalAmount="21.000000" - error={null} + error={ + new LocalizableError({ + ...messages.conwayWalletNotDelegatedToDRep, + }) + } onCancel={action('onCancel')} onSubmitCb={action('onSubmitCb')} onTermsCheckboxClick={action('onTermsCheckboxClick')} diff --git a/translations/messages.json b/translations/messages.json index a70cb0e594..fa50b46a69 100644 --- a/translations/messages.json +++ b/translations/messages.json @@ -95,6 +95,11 @@ "defaultMessage": "!!!Insufficient funds to support tokens. You need at least an additional {adaAmount} ADA in your wallet to process this transaction.", "description": "\"Balance after transaction would not leave enough ada in the wallet to support tokens remaining in wallet", "id": "api.errors.NotEnoughFundsForTransactionFeesErrorWithTokens" + }, + { + "defaultMessage": "!!!conwayWalletNotDelegatedToDRep", + "description": "Error message shown when conway era wallet has staking rewards but has not participated in governance yet.", + "id": "api.errors.conwayWalletNotDelegatedToDRep" } ], "path": "source/renderer/app/api/errors.ts"