Skip to content

Commit

Permalink
fix: sign message on keplr and ledger (#473)
Browse files Browse the repository at this point in the history
Co-authored-by: Hélcio Franco <[email protected]>
  • Loading branch information
luizstacio and helciofranco authored Feb 6, 2025
1 parent 918617d commit 5f9794e
Show file tree
Hide file tree
Showing 26 changed files with 771 additions and 677 deletions.
10 changes: 10 additions & 0 deletions .changeset/six-crabs-tell.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
"@fuel-connectors/walletconnect-connector": minor
"@fuel-connectors/solana-connector": minor
"@fuel-connectors/evm-predicates": minor
"@fuel-connectors/evm-connector": minor
"@fuels/react": minor
"docs": minor
---

Introduce custom `encodeTxId` methods for different predicate versions in EVM Connectors to fix wallet-specific signing limitations by using UTF-8 encoding.
2 changes: 1 addition & 1 deletion .github/workflows/setup-rust/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ name: 'Forc Setup'

inputs:
forc-components:
default: 'forc@0.65.2, fuel-core@0.39.0'
default: 'forc@0.66.5, fuel-core@0.40.4'

runs:
using: 'composite'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,6 @@ console.log(isSupportedNetwork);
```

#### Defined in
[packages/react/src/hooks/useIsSupportedNetwork.tsx:29](https://github.com/fuellabs/fuel-connectors/blob/main/packages/react/src/hooks/useIsSupportedNetwork.tsx#L29)
[packages/react/src/hooks/useIsSupportedNetwork.tsx:30](https://github.com/fuellabs/fuel-connectors/blob/main/packages/react/src/hooks/useIsSupportedNetwork.tsx#L30)

___
4 changes: 4 additions & 0 deletions packages/docs/src/guide/react-hooks/useProvider.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@ An object containing:
- `provider`: The provider data or `null`.
- [`...queryProps`](https://tanstack.com/query/latest/docs/framework/react/reference/useQuery): Destructured properties from `useQuery` result.

| Name | Type |
| :------ | :------ |
| `provider` | `undefined` \| `default` |

#### Examples

To get the current provider:
Expand Down
2 changes: 1 addition & 1 deletion packages/docs/src/guide/react-hooks/useWallet.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ const { wallet } = useWallet();
Use `useWallet({ account })` instead.

#### Defined in
[packages/react/src/hooks/useWallet.ts:53](https://github.com/fuellabs/fuel-connectors/blob/main/packages/react/src/hooks/useWallet.ts#L53)
[packages/react/src/hooks/useWallet.ts:54](https://github.com/fuellabs/fuel-connectors/blob/main/packages/react/src/hooks/useWallet.ts#L54)
26 changes: 23 additions & 3 deletions packages/evm-connector/src/EvmWalletConnector.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,12 @@ import {
getOrThrow,
getProviderUrl,
} from '@fuel-connectors/common';
import { PREDICATE_VERSIONS } from '@fuel-connectors/evm-predicates';
import { METAMASK_ICON, TESTNET_URL, WINDOW } from './constants';
import {
type EvmPredicateRoot,
PREDICATE_VERSIONS,
txIdEncoders,
} from '@fuel-connectors/evm-predicates';
import { METAMASK_ICON, WINDOW } from './constants';
import {
type EIP1193Provider,
type EVMWalletConnectorConfig,
Expand Down Expand Up @@ -234,9 +238,10 @@ export class EVMWalletConnector extends PredicateConnector {
const { request, transactionId, account, transactionRequest } =
await this.prepareTransaction(address, transaction);

const txId = this.encodeTxId(transactionId);
const signature = (await ethProvider?.request({
method: 'personal_sign',
params: [transactionId, account],
params: [txId, account],
})) as string;

const predicateSignatureIndex = getMockedSignatureIndex(
Expand Down Expand Up @@ -273,4 +278,19 @@ export class EVMWalletConnector extends PredicateConnector {
signature: signature as string,
};
}

private isValidPredicateAddress(
address: string,
): address is EvmPredicateRoot {
return address in txIdEncoders;
}

private encodeTxId(txId: string): string {
if (!this.isValidPredicateAddress(this.predicateAddress)) {
return txId;
}

const encoder = txIdEncoders[this.predicateAddress];
return encoder.encodeTxId(txId);
}
}
1 change: 0 additions & 1 deletion packages/evm-connector/src/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,5 @@ declare global {
}
const HAS_WINDOW = typeof window !== 'undefined';
export const WINDOW = HAS_WINDOW ? window : null;
export const TESTNET_URL = 'https://testnet.fuel.network/v1/graphql';
export const METAMASK_ICON =
'';
Loading

0 comments on commit 5f9794e

Please sign in to comment.