thirdweb 5.105.41 → 5.105.42-nightly-2d76cf904079cc74809f571b67ac746fad7aa04f-20250909000351
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/Executed.js +4 -2
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/Executed.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.js +3 -2
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.js +32 -0
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.js.map +1 -0
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/eip712Domain.js +7 -7
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/eip712Domain.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getCallPoliciesForSigner.js +20 -20
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getCallPoliciesForSigner.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getSessionExpirationForSigner.js +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getSessionExpirationForSigner.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getSessionStateForSigner.js +20 -20
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getSessionStateForSigner.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getTransferPoliciesForSigner.js +9 -9
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/getTransferPoliciesForSigner.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/isWildcardSigner.js +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/read/isWildcardSigner.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/createSessionWithSig.js +45 -45
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/createSessionWithSig.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/execute.js +14 -14
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/execute.js.map +1 -1
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/executeWithSig.js +18 -18
- package/dist/cjs/extensions/erc7702/__generated__/MinimalAccount/write/executeWithSig.js.map +1 -1
- package/dist/cjs/gas/fee-data.js +1 -1
- package/dist/cjs/gas/fee-data.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js +2 -6
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js.map +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectModalContent.js +1 -1
- package/dist/cjs/react/web/ui/ConnectWallet/Modal/ConnectModalContent.js.map +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js +1 -1
- package/dist/cjs/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.js.map +1 -1
- package/dist/cjs/wallets/in-app/core/eip7702/minimal-account.js +117 -10
- package/dist/cjs/wallets/in-app/core/eip7702/minimal-account.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/Executed.js +4 -2
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/Executed.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.js +3 -2
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.js +29 -0
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.js.map +1 -0
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/eip712Domain.js +7 -7
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/eip712Domain.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getCallPoliciesForSigner.js +20 -20
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getCallPoliciesForSigner.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getSessionExpirationForSigner.js +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getSessionExpirationForSigner.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getSessionStateForSigner.js +20 -20
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getSessionStateForSigner.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getTransferPoliciesForSigner.js +9 -9
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/getTransferPoliciesForSigner.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/isWildcardSigner.js +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/read/isWildcardSigner.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/createSessionWithSig.js +45 -45
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/createSessionWithSig.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/execute.js +14 -14
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/execute.js.map +1 -1
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/executeWithSig.js +18 -18
- package/dist/esm/extensions/erc7702/__generated__/MinimalAccount/write/executeWithSig.js.map +1 -1
- package/dist/esm/gas/fee-data.js +1 -1
- package/dist/esm/gas/fee-data.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js +2 -6
- package/dist/esm/react/web/ui/ConnectWallet/Modal/AllWalletsUI.js.map +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectModalContent.js +1 -1
- package/dist/esm/react/web/ui/ConnectWallet/Modal/ConnectModalContent.js.map +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js +1 -1
- package/dist/esm/react/web/wallets/in-app/WalletAuth.js.map +1 -1
- package/dist/esm/version.js +1 -1
- package/dist/esm/version.js.map +1 -1
- package/dist/esm/wallets/in-app/core/eip7702/minimal-account.js +117 -10
- package/dist/esm/wallets/in-app/core/eip7702/minimal-account.js.map +1 -1
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/Executed.d.ts +25 -8
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/Executed.d.ts.map +1 -1
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.d.ts +14 -4
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.d.ts.map +1 -1
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.d.ts +54 -0
- package/dist/types/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.d.ts.map +1 -0
- package/dist/types/react/web/ui/ConnectWallet/Modal/AllWalletsUI.d.ts +0 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/AllWalletsUI.d.ts.map +1 -1
- package/dist/types/react/web/ui/ConnectWallet/Modal/ConnectModalContent.d.ts.map +1 -1
- package/dist/types/react/web/wallets/in-app/WalletAuth.d.ts.map +1 -1
- package/dist/types/version.d.ts +1 -1
- package/dist/types/version.d.ts.map +1 -1
- package/dist/types/wallets/in-app/core/eip7702/minimal-account.d.ts +64 -0
- package/dist/types/wallets/in-app/core/eip7702/minimal-account.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/extensions/erc7702/__generated__/MinimalAccount/events/Executed.ts +17 -4
- package/src/extensions/erc7702/__generated__/MinimalAccount/events/SessionCreated.ts +11 -5
- package/src/extensions/erc7702/__generated__/MinimalAccount/events/ValueReceived.ts +47 -0
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/eip712Domain.ts +7 -7
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/getCallPoliciesForSigner.ts +20 -20
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/getSessionExpirationForSigner.ts +1 -1
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/getSessionStateForSigner.ts +20 -20
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/getTransferPoliciesForSigner.ts +9 -9
- package/src/extensions/erc7702/__generated__/MinimalAccount/read/isWildcardSigner.ts +1 -1
- package/src/extensions/erc7702/__generated__/MinimalAccount/write/createSessionWithSig.ts +47 -47
- package/src/extensions/erc7702/__generated__/MinimalAccount/write/execute.ts +16 -16
- package/src/extensions/erc7702/__generated__/MinimalAccount/write/executeWithSig.ts +20 -20
- package/src/extensions/erc7702/account/sessionkey.test.ts +2 -4
- package/src/gas/fee-data.ts +1 -1
- package/src/react/web/ui/ConnectWallet/Modal/AllWalletsUI.tsx +5 -12
- package/src/react/web/ui/ConnectWallet/Modal/ConnectModalContent.tsx +0 -1
- package/src/react/web/wallets/in-app/WalletAuth.tsx +0 -1
- package/src/version.ts +1 -1
- package/src/wallets/in-app/core/eip7702/minimal-account.ts +149 -10
- package/src/wallets/in-app/web/lib/in-app-gateway.test.ts +87 -103
- package/src/wallets/in-app/web/lib/in-app-integration.test.ts +1 -2
@@ -1,126 +1,110 @@
|
|
1
|
-
import {
|
1
|
+
import {
|
2
|
+
configure,
|
3
|
+
isSuccessResponse,
|
4
|
+
sendTransaction,
|
5
|
+
signMessage,
|
6
|
+
} from "@thirdweb-dev/engine";
|
2
7
|
import { beforeAll, describe, expect, it } from "vitest";
|
3
8
|
import { TEST_CLIENT } from "~test/test-clients.js";
|
4
9
|
import { sepolia } from "../../../../chains/chain-definitions/sepolia.js";
|
5
|
-
import { createThirdwebClient } from "../../../../client/client.js";
|
6
10
|
import { waitForTransactionHash } from "../../../../engine/wait-for-tx-hash.js";
|
7
|
-
import {
|
8
|
-
getThirdwebBaseUrl,
|
9
|
-
setThirdwebDomains,
|
10
|
-
} from "../../../../utils/domains.js";
|
11
|
-
import { getClientFetch } from "../../../../utils/fetch.js";
|
12
11
|
import { stringify } from "../../../../utils/json.js";
|
13
12
|
import type { Account } from "../../../interfaces/wallet.js";
|
14
13
|
import { inAppWallet } from "../in-app.js";
|
15
14
|
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
.skip("InAppWallet Gateway Tests", () => {
|
20
|
-
let account: Account;
|
21
|
-
let authToken: string | null | undefined;
|
22
|
-
const clientIdFetch = getClientFetch(
|
23
|
-
createThirdwebClient({
|
24
|
-
clientId: TEST_CLIENT.clientId,
|
25
|
-
}),
|
26
|
-
);
|
15
|
+
describe.runIf(process.env.TW_SECRET_KEY)("InAppWallet Gateway Tests", () => {
|
16
|
+
let account: Account;
|
17
|
+
let authToken: string | null | undefined;
|
27
18
|
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
inAppWallet: "embedded-wallet.thirdweb-dev.com",
|
33
|
-
rpc: "rpc.thirdweb-dev.com",
|
34
|
-
});
|
35
|
-
const wallet = inAppWallet();
|
36
|
-
account = await wallet.connect({
|
37
|
-
client: TEST_CLIENT,
|
38
|
-
strategy: "backend",
|
39
|
-
walletSecret: "test-secret",
|
40
|
-
});
|
41
|
-
authToken = wallet.getAuthToken();
|
42
|
-
expect(authToken).toBeDefined();
|
19
|
+
beforeAll(async () => {
|
20
|
+
configure({
|
21
|
+
clientId: TEST_CLIENT.clientId,
|
22
|
+
secretKey: TEST_CLIENT.secretKey,
|
43
23
|
});
|
24
|
+
const wallet = inAppWallet();
|
25
|
+
account = await wallet.connect({
|
26
|
+
client: TEST_CLIENT,
|
27
|
+
strategy: "backend",
|
28
|
+
walletSecret: "test-secret",
|
29
|
+
});
|
30
|
+
authToken = wallet.getAuthToken?.();
|
31
|
+
expect(authToken).toBeDefined();
|
32
|
+
});
|
44
33
|
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
});
|
49
|
-
|
50
|
-
// sign via api
|
51
|
-
const signResult = await signMessage({
|
52
|
-
baseUrl: getThirdwebBaseUrl("engineCloud"),
|
53
|
-
body: {
|
54
|
-
params: [
|
55
|
-
{
|
56
|
-
format: "text",
|
57
|
-
message: "Hello, world!",
|
58
|
-
},
|
59
|
-
],
|
60
|
-
signingOptions: {
|
61
|
-
from: account.address,
|
62
|
-
type: "EOA",
|
63
|
-
},
|
64
|
-
},
|
65
|
-
bodySerializer: stringify,
|
66
|
-
fetch: clientIdFetch,
|
67
|
-
headers: {
|
68
|
-
"x-wallet-access-token": authToken,
|
69
|
-
},
|
70
|
-
});
|
71
|
-
|
72
|
-
const signatureResult = signResult.data?.result[0];
|
73
|
-
if (signatureResult && "result" in signatureResult) {
|
74
|
-
expect(signatureResult.result.signature).toEqual(rawSignature);
|
75
|
-
} else {
|
76
|
-
throw new Error(
|
77
|
-
`Failed to sign message: ${stringify(signatureResult?.error) || "Unknown error"}`,
|
78
|
-
);
|
79
|
-
}
|
34
|
+
it("should sign a message with backend strategy", async () => {
|
35
|
+
const rawSignature = await account.signMessage({
|
36
|
+
message: "Hello, world!",
|
80
37
|
});
|
81
38
|
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
chainId: sepolia.id,
|
86
|
-
from: account.address,
|
87
|
-
type: "auto" as const,
|
88
|
-
},
|
39
|
+
// sign via api
|
40
|
+
const signResult = await signMessage({
|
41
|
+
body: {
|
89
42
|
params: [
|
90
43
|
{
|
91
|
-
|
92
|
-
|
93
|
-
value: "0",
|
44
|
+
format: "text",
|
45
|
+
message: "Hello, world!",
|
94
46
|
},
|
95
47
|
],
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
body,
|
100
|
-
bodySerializer: stringify,
|
101
|
-
fetch: clientIdFetch,
|
102
|
-
headers: {
|
103
|
-
"x-wallet-access-token": authToken,
|
48
|
+
signingOptions: {
|
49
|
+
from: account.address,
|
50
|
+
type: "EOA",
|
104
51
|
},
|
105
|
-
}
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
}
|
52
|
+
},
|
53
|
+
headers: {
|
54
|
+
"x-wallet-access-token": authToken,
|
55
|
+
},
|
56
|
+
});
|
111
57
|
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
throw new Error("No transaction ID found");
|
116
|
-
}
|
58
|
+
if (signResult.error) {
|
59
|
+
throw new Error(`Error signing message: ${stringify(signResult.error)}`);
|
60
|
+
}
|
117
61
|
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
62
|
+
const signatureResult = signResult.data?.result?.[0];
|
63
|
+
if (signatureResult && isSuccessResponse(signatureResult)) {
|
64
|
+
expect(signatureResult.result.signature).toEqual(rawSignature);
|
65
|
+
} else {
|
66
|
+
throw new Error(
|
67
|
+
`Failed to sign message: ${stringify(signatureResult?.error) || "Unknown error"}`,
|
68
|
+
);
|
69
|
+
}
|
70
|
+
});
|
122
71
|
|
123
|
-
|
124
|
-
|
72
|
+
it("should queue a 4337 transaction", async () => {
|
73
|
+
const body = {
|
74
|
+
executionOptions: {
|
75
|
+
chainId: sepolia.id,
|
76
|
+
from: account.address,
|
77
|
+
type: "auto" as const,
|
78
|
+
},
|
79
|
+
params: [
|
80
|
+
{
|
81
|
+
data: "0x",
|
82
|
+
to: account.address,
|
83
|
+
value: "0",
|
84
|
+
},
|
85
|
+
],
|
86
|
+
};
|
87
|
+
const result = await sendTransaction({
|
88
|
+
body,
|
89
|
+
headers: {
|
90
|
+
"x-wallet-access-token": authToken,
|
91
|
+
},
|
125
92
|
});
|
93
|
+
if (result.error) {
|
94
|
+
throw new Error(`Error sending transaction: ${stringify(result.error)}`);
|
95
|
+
}
|
96
|
+
|
97
|
+
const txId = result.data?.result.transactions[0]?.id;
|
98
|
+
if (!txId) {
|
99
|
+
throw new Error("No transaction ID found");
|
100
|
+
}
|
101
|
+
|
102
|
+
const tx = await waitForTransactionHash({
|
103
|
+
client: TEST_CLIENT,
|
104
|
+
transactionId: txId,
|
105
|
+
});
|
106
|
+
|
107
|
+
console.log(tx.transactionHash);
|
108
|
+
expect(tx.transactionHash).toBeDefined();
|
126
109
|
});
|
110
|
+
});
|
@@ -73,8 +73,7 @@ describe.runIf(process.env.TW_SECRET_KEY)(
|
|
73
73
|
if (!executedLog) {
|
74
74
|
throw new Error("No executed log found");
|
75
75
|
}
|
76
|
-
expect(executedLog.args.
|
77
|
-
expect(executedLog.args.value).toBe(0n);
|
76
|
+
expect(executedLog.args.user).toBe(account.address);
|
78
77
|
});
|
79
78
|
|
80
79
|
it("should sponsor gas for a 4337 smart account", async () => {
|