thirdweb 5.53.0 → 5.53.1-nightly-865c5e3b16af70c3660f30ba8cffc5d6e360a389-20240911000352
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/contract/deployment/utils/bootstrap.js +1 -1
- package/dist/cjs/contract/deployment/utils/bootstrap.js.map +1 -1
- package/dist/cjs/exports/contract.js +4 -1
- package/dist/cjs/exports/contract.js.map +1 -1
- package/dist/cjs/exports/deploys.js +2 -1
- package/dist/cjs/exports/deploys.js.map +1 -1
- package/dist/cjs/exports/extensions/erc721.js +4 -2
- package/dist/cjs/exports/extensions/erc721.js.map +1 -1
- package/dist/cjs/extensions/erc721/lazyMinting/read/getBatchesToReveal.js +14 -16
- package/dist/cjs/extensions/erc721/lazyMinting/read/getBatchesToReveal.js.map +1 -1
- package/dist/cjs/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js +19 -0
- package/dist/cjs/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js.map +1 -1
- package/dist/cjs/extensions/erc721/lazyMinting/write/reveal.js +3 -20
- package/dist/cjs/extensions/erc721/lazyMinting/write/reveal.js.map +1 -1
- package/dist/cjs/extensions/prebuilts/deploy-published.js +30 -14
- package/dist/cjs/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/cjs/react/core/hooks/others/useProfiles.js +1 -1
- package/dist/cjs/react/core/utils/walletIcon.js +5 -1
- package/dist/cjs/react/core/utils/walletIcon.js.map +1 -1
- package/dist/cjs/react/native/ui/components/WalletImage.js +2 -0
- package/dist/cjs/react/native/ui/components/WalletImage.js.map +1 -1
- package/dist/cjs/react/native/ui/connect/InAppWalletUI.js +1 -0
- package/dist/cjs/react/native/ui/connect/InAppWalletUI.js.map +1 -1
- package/dist/cjs/react/native/ui/icons/svgs.js +2 -1
- package/dist/cjs/react/native/ui/icons/svgs.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
- package/dist/cjs/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/cjs/react/web/wallets/shared/oauthSignIn.js +1 -0
- package/dist/cjs/react/web/wallets/shared/oauthSignIn.js.map +1 -1
- package/dist/cjs/utils/any-evm/compute-published-contract-address.js +0 -4
- package/dist/cjs/utils/any-evm/compute-published-contract-address.js.map +1 -1
- package/dist/cjs/utils/any-evm/compute-published-contract-deploy-info.js +2 -3
- package/dist/cjs/utils/any-evm/compute-published-contract-deploy-info.js.map +1 -1
- package/dist/cjs/utils/any-evm/deploy-metadata.js +0 -19
- package/dist/cjs/utils/any-evm/deploy-metadata.js.map +1 -1
- package/dist/cjs/utils/domains.js +1 -1
- package/dist/cjs/utils/domains.js.map +1 -1
- package/dist/cjs/utils/ipfs.js +2 -0
- package/dist/cjs/utils/ipfs.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/authentication/types.js +1 -0
- package/dist/cjs/wallets/in-app/core/authentication/types.js.map +1 -1
- package/dist/cjs/wallets/in-app/native/native-connector.js +2 -0
- package/dist/cjs/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/in-app.js +2 -0
- package/dist/cjs/wallets/in-app/web/in-app.js.map +1 -1
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js +2 -0
- package/dist/cjs/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/cjs/wallets/types.js +1 -0
- package/dist/cjs/wallets/types.js.map +1 -1
- package/dist/esm/contract/deployment/utils/bootstrap.js +1 -1
- package/dist/esm/contract/deployment/utils/bootstrap.js.map +1 -1
- package/dist/esm/exports/contract.js +2 -0
- package/dist/esm/exports/contract.js.map +1 -1
- package/dist/esm/exports/deploys.js +1 -1
- package/dist/esm/exports/deploys.js.map +1 -1
- package/dist/esm/exports/extensions/erc721.js +3 -3
- package/dist/esm/exports/extensions/erc721.js.map +1 -1
- package/dist/esm/extensions/erc721/lazyMinting/read/getBatchesToReveal.js +13 -15
- package/dist/esm/extensions/erc721/lazyMinting/read/getBatchesToReveal.js.map +1 -1
- package/dist/esm/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js +21 -3
- package/dist/esm/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.js.map +1 -1
- package/dist/esm/extensions/erc721/lazyMinting/write/reveal.js +1 -20
- package/dist/esm/extensions/erc721/lazyMinting/write/reveal.js.map +1 -1
- package/dist/esm/extensions/prebuilts/deploy-published.js +29 -14
- package/dist/esm/extensions/prebuilts/deploy-published.js.map +1 -1
- package/dist/esm/react/core/hooks/others/useProfiles.js +1 -1
- package/dist/esm/react/core/utils/walletIcon.js +4 -0
- package/dist/esm/react/core/utils/walletIcon.js.map +1 -1
- package/dist/esm/react/native/ui/components/WalletImage.js +3 -1
- package/dist/esm/react/native/ui/components/WalletImage.js.map +1 -1
- package/dist/esm/react/native/ui/connect/InAppWalletUI.js +2 -1
- package/dist/esm/react/native/ui/connect/InAppWalletUI.js.map +1 -1
- package/dist/esm/react/native/ui/icons/svgs.js +1 -0
- package/dist/esm/react/native/ui/icons/svgs.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js +1 -0
- package/dist/esm/react/web/wallets/shared/ConnectWalletSocialOptions.js.map +1 -1
- package/dist/esm/react/web/wallets/shared/oauthSignIn.js +1 -0
- package/dist/esm/react/web/wallets/shared/oauthSignIn.js.map +1 -1
- package/dist/esm/utils/any-evm/compute-published-contract-address.js +0 -4
- package/dist/esm/utils/any-evm/compute-published-contract-address.js.map +1 -1
- package/dist/esm/utils/any-evm/compute-published-contract-deploy-info.js +2 -3
- package/dist/esm/utils/any-evm/compute-published-contract-deploy-info.js.map +1 -1
- package/dist/esm/utils/any-evm/deploy-metadata.js +0 -19
- package/dist/esm/utils/any-evm/deploy-metadata.js.map +1 -1
- package/dist/esm/utils/domains.js +1 -1
- package/dist/esm/utils/domains.js.map +1 -1
- package/dist/esm/utils/ipfs.js +2 -0
- package/dist/esm/utils/ipfs.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/authentication/types.js +1 -0
- package/dist/esm/wallets/in-app/core/authentication/types.js.map +1 -1
- package/dist/esm/wallets/in-app/native/native-connector.js +2 -0
- package/dist/esm/wallets/in-app/native/native-connector.js.map +1 -1
- package/dist/esm/wallets/in-app/web/in-app.js +2 -0
- package/dist/esm/wallets/in-app/web/in-app.js.map +1 -1
- package/dist/esm/wallets/in-app/web/lib/web-connector.js +2 -0
- package/dist/esm/wallets/in-app/web/lib/web-connector.js.map +1 -1
- package/dist/esm/wallets/types.js +1 -0
- package/dist/esm/wallets/types.js.map +1 -1
- package/dist/types/contract/actions/compiler-metadata.d.ts +2 -2
- package/dist/types/contract/actions/compiler-metadata.d.ts.map +1 -1
- package/dist/types/contract/actions/get-compiler-metadata.d.ts +1 -1
- package/dist/types/contract/actions/get-compiler-metadata.d.ts.map +1 -1
- package/dist/types/contract/verification/source-files.d.ts +2 -2
- package/dist/types/contract/verification/source-files.d.ts.map +1 -1
- package/dist/types/exports/contract.d.ts +1 -0
- package/dist/types/exports/contract.d.ts.map +1 -1
- package/dist/types/exports/deploys.d.ts +1 -1
- package/dist/types/exports/deploys.d.ts.map +1 -1
- package/dist/types/exports/extensions/erc721.d.ts +3 -3
- package/dist/types/exports/extensions/erc721.d.ts.map +1 -1
- package/dist/types/extensions/erc721/lazyMinting/read/getBatchesToReveal.d.ts +1 -1
- package/dist/types/extensions/erc721/lazyMinting/read/getBatchesToReveal.d.ts.map +1 -1
- package/dist/types/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.d.ts +12 -0
- package/dist/types/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.d.ts.map +1 -1
- package/dist/types/extensions/erc721/lazyMinting/write/reveal.d.ts +1 -0
- package/dist/types/extensions/erc721/lazyMinting/write/reveal.d.ts.map +1 -1
- package/dist/types/extensions/prebuilts/deploy-published.d.ts +16 -0
- package/dist/types/extensions/prebuilts/deploy-published.d.ts.map +1 -1
- package/dist/types/react/core/hooks/others/useProfiles.d.ts +1 -1
- package/dist/types/react/core/utils/storage.d.ts +1 -1
- package/dist/types/react/core/utils/storage.d.ts.map +1 -1
- package/dist/types/react/core/utils/walletIcon.d.ts +3 -1
- package/dist/types/react/core/utils/walletIcon.d.ts.map +1 -1
- package/dist/types/react/native/ui/components/WalletImage.d.ts.map +1 -1
- package/dist/types/react/native/ui/connect/InAppWalletUI.d.ts.map +1 -1
- package/dist/types/react/native/ui/icons/svgs.d.ts +1 -0
- package/dist/types/react/native/ui/icons/svgs.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/ConnectWalletSocialOptions.d.ts.map +1 -1
- package/dist/types/react/web/wallets/shared/oauthSignIn.d.ts.map +1 -1
- package/dist/types/utils/any-evm/compute-published-contract-address.d.ts +0 -4
- package/dist/types/utils/any-evm/compute-published-contract-address.d.ts.map +1 -1
- package/dist/types/utils/any-evm/compute-published-contract-deploy-info.d.ts.map +1 -1
- package/dist/types/utils/any-evm/deploy-metadata.d.ts +3 -6
- package/dist/types/utils/any-evm/deploy-metadata.d.ts.map +1 -1
- package/dist/types/utils/ipfs.d.ts +1 -1
- package/dist/types/utils/ipfs.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/authentication/types.d.ts +1 -0
- package/dist/types/wallets/in-app/core/authentication/types.d.ts.map +1 -1
- package/dist/types/wallets/in-app/native/native-connector.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/in-app.d.ts +2 -0
- package/dist/types/wallets/in-app/web/in-app.d.ts.map +1 -1
- package/dist/types/wallets/in-app/web/lib/web-connector.d.ts.map +1 -1
- package/dist/types/wallets/types.d.ts +2 -2
- package/dist/types/wallets/types.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/contract/actions/compiler-metadata.ts +2 -2
- package/src/contract/deployment/publisher.test.ts +2 -2
- package/src/contract/deployment/utils/bootstrap.ts +1 -1
- package/src/contract/verification/source-files.ts +2 -2
- package/src/exports/contract.ts +6 -0
- package/src/exports/deploys.ts +2 -0
- package/src/exports/extensions/erc721.ts +3 -1
- package/src/extensions/erc721/lazyMinting/read/getBatchesToReveal.ts +15 -15
- package/src/extensions/erc721/lazyMinting/write/createAndReveal.test.ts +84 -0
- package/src/extensions/erc721/lazyMinting/write/createDelayedRevealBatch.ts +33 -3
- package/src/extensions/erc721/lazyMinting/write/reveal.test.ts +1 -45
- package/src/extensions/erc721/lazyMinting/write/reveal.ts +2 -23
- package/src/extensions/prebuilts/deploy-published.ts +61 -22
- package/src/react/core/hooks/others/useProfiles.ts +1 -1
- package/src/react/core/utils/walletIcon.ts +5 -0
- package/src/react/native/ui/components/WalletImage.tsx +3 -0
- package/src/react/native/ui/connect/InAppWalletUI.tsx +2 -0
- package/src/react/native/ui/icons/svgs.ts +2 -0
- package/src/react/web/wallets/shared/ConnectWalletSocialOptions.tsx +1 -0
- package/src/react/web/wallets/shared/oauthSignIn.ts +1 -0
- package/src/utils/any-evm/compute-published-contract-address.ts +0 -4
- package/src/utils/any-evm/compute-published-contract-deploy-info.ts +2 -3
- package/src/utils/any-evm/deploy-metadata.ts +9 -34
- package/src/utils/domains.ts +1 -1
- package/src/utils/ipfs.ts +3 -1
- package/src/version.ts +1 -1
- package/src/wallets/in-app/core/authentication/types.ts +1 -0
- package/src/wallets/in-app/native/native-connector.ts +2 -0
- package/src/wallets/in-app/web/in-app.ts +2 -0
- package/src/wallets/in-app/web/lib/web-connector.ts +2 -0
- package/src/wallets/types.ts +1 -0
@@ -1,8 +1,9 @@
|
|
1
|
-
import { simulateTransaction } from "../../../../transaction/actions/simulate.js";
|
2
1
|
import type { BaseTransactionOptions } from "../../../../transaction/types.js";
|
3
2
|
import { reveal as generatedReveal } from "../../__generated__/IDelayedReveal/write/reveal.js";
|
4
3
|
import { hashDelayedRevealPassword } from "../helpers/hashDelayedRevealBatch.js";
|
5
4
|
|
5
|
+
export { isRevealSupported } from "../../__generated__/IDelayedReveal/write/reveal.js";
|
6
|
+
|
6
7
|
/**
|
7
8
|
* @extension ERC721
|
8
9
|
*/
|
@@ -44,28 +45,6 @@ export function reveal(options: BaseTransactionOptions<RevealParams>) {
|
|
44
45
|
options.password,
|
45
46
|
options.contract,
|
46
47
|
);
|
47
|
-
|
48
|
-
const transaction = generatedReveal({
|
49
|
-
contract: options.contract,
|
50
|
-
asyncParams: async () => ({
|
51
|
-
identifier: options.batchId,
|
52
|
-
key,
|
53
|
-
}),
|
54
|
-
});
|
55
|
-
|
56
|
-
let decryptedUri: string;
|
57
|
-
try {
|
58
|
-
decryptedUri = await simulateTransaction({
|
59
|
-
transaction,
|
60
|
-
});
|
61
|
-
} catch (error) {
|
62
|
-
throw new Error("Reveal failed", { cause: error });
|
63
|
-
}
|
64
|
-
|
65
|
-
if (!decryptedUri.includes("://") || decryptedUri.slice(-1) !== "/") {
|
66
|
-
throw new Error("Invalid reveal password");
|
67
|
-
}
|
68
|
-
|
69
48
|
return {
|
70
49
|
identifier: options.batchId,
|
71
50
|
key,
|
@@ -9,6 +9,7 @@ import { simulateTransaction } from "../../transaction/actions/simulate.js";
|
|
9
9
|
import { prepareContractCall } from "../../transaction/prepare-contract-call.js";
|
10
10
|
import { resolveMethod } from "../../transaction/resolve-method.js";
|
11
11
|
import type { CompilerMetadata } from "../../utils/any-evm/deploy-metadata.js";
|
12
|
+
import type { FetchDeployMetadataResult } from "../../utils/any-evm/deploy-metadata.js";
|
12
13
|
import { isZkSyncChain } from "../../utils/any-evm/zksync/isZkSyncChain.js";
|
13
14
|
import type { Account } from "../../wallets/interfaces/wallet.js";
|
14
15
|
|
@@ -58,21 +59,56 @@ export async function deployPublishedContract(
|
|
58
59
|
version,
|
59
60
|
implementationConstructorParams,
|
60
61
|
} = options;
|
61
|
-
const
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
62
|
+
const deployMetadata = await fetchPublishedContractMetadata({
|
63
|
+
client,
|
64
|
+
contractId: isZkSyncChain(chain) ? `${contractId}_ZkSync` : contractId,
|
65
|
+
publisher,
|
66
|
+
version,
|
67
|
+
});
|
68
|
+
|
69
|
+
return deployContractfromDeployMetadata({
|
70
|
+
account,
|
71
|
+
chain,
|
72
|
+
deployMetadata,
|
73
|
+
client,
|
74
|
+
contractParams,
|
75
|
+
implementationConstructorParams,
|
76
|
+
});
|
77
|
+
}
|
78
|
+
|
79
|
+
/**
|
80
|
+
* @internal
|
81
|
+
*/
|
82
|
+
export type DeployContractfromDeployMetadataOptions = {
|
83
|
+
client: ThirdwebClient;
|
84
|
+
chain: Chain;
|
85
|
+
account: Account;
|
86
|
+
deployMetadata: FetchDeployMetadataResult;
|
87
|
+
contractParams: unknown[];
|
88
|
+
implementationConstructorParams?: unknown[];
|
89
|
+
};
|
68
90
|
|
69
|
-
|
91
|
+
/**
|
92
|
+
* @internal
|
93
|
+
*/
|
94
|
+
export async function deployContractfromDeployMetadata(
|
95
|
+
options: DeployContractfromDeployMetadataOptions,
|
96
|
+
) {
|
97
|
+
const {
|
98
|
+
client,
|
99
|
+
account,
|
100
|
+
chain,
|
101
|
+
contractParams,
|
102
|
+
deployMetadata,
|
103
|
+
implementationConstructorParams,
|
104
|
+
} = options;
|
105
|
+
switch (deployMetadata?.deployType) {
|
70
106
|
case "standard": {
|
71
107
|
return directDeploy({
|
72
108
|
account,
|
73
109
|
client,
|
74
110
|
chain,
|
75
|
-
compilerMetadata,
|
111
|
+
compilerMetadata: deployMetadata,
|
76
112
|
contractParams,
|
77
113
|
});
|
78
114
|
}
|
@@ -89,19 +125,21 @@ export async function deployPublishedContract(
|
|
89
125
|
chain,
|
90
126
|
client,
|
91
127
|
account,
|
92
|
-
contractId,
|
128
|
+
contractId: deployMetadata.name,
|
93
129
|
constructorParams: implementationConstructorParams || [],
|
94
|
-
publisher,
|
130
|
+
publisher: deployMetadata.publisher,
|
95
131
|
});
|
96
|
-
const initializeFunction =
|
132
|
+
const initializeFunction = deployMetadata.abi.find(
|
97
133
|
(i) =>
|
98
134
|
i.type === "function" &&
|
99
135
|
i.name ===
|
100
|
-
(
|
136
|
+
(deployMetadata.factoryDeploymentData
|
101
137
|
?.implementationInitializerFunction || "initialize"),
|
102
138
|
) as AbiFunction;
|
103
139
|
if (!initializeFunction) {
|
104
|
-
throw new Error(
|
140
|
+
throw new Error(
|
141
|
+
`Could not find initialize function for ${deployMetadata.name}`,
|
142
|
+
);
|
105
143
|
}
|
106
144
|
const initializeTransaction = prepareContractCall({
|
107
145
|
contract: getContract({
|
@@ -109,7 +147,10 @@ export async function deployPublishedContract(
|
|
109
147
|
chain,
|
110
148
|
address: implementationContract.address,
|
111
149
|
}),
|
112
|
-
method:
|
150
|
+
method: resolveMethod(
|
151
|
+
deployMetadata.factoryDeploymentData
|
152
|
+
?.implementationInitializerFunction || "initialize",
|
153
|
+
),
|
113
154
|
params: contractParams,
|
114
155
|
});
|
115
156
|
|
@@ -122,14 +163,14 @@ export async function deployPublishedContract(
|
|
122
163
|
});
|
123
164
|
}
|
124
165
|
case "customFactory": {
|
125
|
-
if (!
|
166
|
+
if (!deployMetadata?.factoryDeploymentData?.customFactoryInput) {
|
126
167
|
throw new Error("No custom factory info found");
|
127
168
|
}
|
128
169
|
const factoryAddress =
|
129
|
-
|
170
|
+
deployMetadata?.factoryDeploymentData?.customFactoryInput
|
130
171
|
?.customFactoryAddresses?.[chain.id];
|
131
172
|
const factoryFunction =
|
132
|
-
|
173
|
+
deployMetadata.factoryDeploymentData?.customFactoryInput
|
133
174
|
?.factoryFunction;
|
134
175
|
if (!factoryAddress || !factoryFunction) {
|
135
176
|
throw new Error(`No factory address found on chain ${chain.id}`);
|
@@ -161,15 +202,13 @@ export async function deployPublishedContract(
|
|
161
202
|
account,
|
162
203
|
client,
|
163
204
|
chain,
|
164
|
-
compilerMetadata,
|
205
|
+
compilerMetadata: deployMetadata,
|
165
206
|
contractParams,
|
166
207
|
});
|
167
208
|
}
|
168
209
|
default:
|
169
210
|
// If a deployType was specified but we don't support it, throw an error
|
170
|
-
throw new Error(
|
171
|
-
`Unsupported deploy type: ${extendedMetadata?.deployType}`,
|
172
|
-
);
|
211
|
+
throw new Error(`Unsupported deploy type: ${deployMetadata?.deployType}`);
|
173
212
|
}
|
174
213
|
}
|
175
214
|
|
@@ -19,6 +19,8 @@ export const twitchIconUri =
|
|
19
19
|
"";
|
20
20
|
export const discordIconUri =
|
21
21
|
"";
|
22
|
+
export const lineIconUri =
|
23
|
+
"";
|
22
24
|
export const farcasterIconUri =
|
23
25
|
"";
|
24
26
|
export const telegramIconUri =
|
@@ -46,6 +48,7 @@ export const socialIcons = {
|
|
46
48
|
apple: appleIconUri,
|
47
49
|
facebook: facebookIconUri,
|
48
50
|
discord: discordIconUri,
|
51
|
+
line: lineIconUri,
|
49
52
|
farcaster: farcasterIconUri,
|
50
53
|
telegram: telegramIconUri,
|
51
54
|
};
|
@@ -67,6 +70,8 @@ export function getWalletIcon(provider: string) {
|
|
67
70
|
return passkeyIcon;
|
68
71
|
case "discord":
|
69
72
|
return discordIconUri;
|
73
|
+
case "line":
|
74
|
+
return lineIconUri;
|
70
75
|
case "farcaster":
|
71
76
|
return farcasterIconUri;
|
72
77
|
case "telegram":
|
@@ -12,6 +12,7 @@ import {
|
|
12
12
|
FACEBOOK_ICON,
|
13
13
|
FARCASTER_ICON,
|
14
14
|
GOOGLE_ICON,
|
15
|
+
LINE_ICON,
|
15
16
|
PASSKEY_ICON,
|
16
17
|
PHONE_ICON,
|
17
18
|
TELEGRAM_ICON,
|
@@ -81,6 +82,8 @@ export function getAuthProviderImage(authProvider: string | null): string {
|
|
81
82
|
return FACEBOOK_ICON;
|
82
83
|
case "discord":
|
83
84
|
return DISCORD_ICON;
|
85
|
+
case "line":
|
86
|
+
return LINE_ICON;
|
84
87
|
case "farcaster":
|
85
88
|
return FARCASTER_ICON;
|
86
89
|
case "telegram":
|
@@ -34,6 +34,7 @@ import {
|
|
34
34
|
FACEBOOK_ICON,
|
35
35
|
FARCASTER_ICON,
|
36
36
|
GOOGLE_ICON,
|
37
|
+
LINE_ICON,
|
37
38
|
TELEGRAM_ICON,
|
38
39
|
} from "../icons/svgs.js";
|
39
40
|
import type { ModalState } from "./ConnectModal.js";
|
@@ -53,6 +54,7 @@ const socialIcons = {
|
|
53
54
|
facebook: FACEBOOK_ICON,
|
54
55
|
apple: APPLE_ICON,
|
55
56
|
discord: DISCORD_ICON,
|
57
|
+
line: LINE_ICON,
|
56
58
|
farcaster: FARCASTER_ICON,
|
57
59
|
telegram: TELEGRAM_ICON,
|
58
60
|
};
|
@@ -37,6 +37,8 @@ export const DISCORD_ICON = `<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink
|
|
37
37
|
</g>
|
38
38
|
</svg>`;
|
39
39
|
|
40
|
+
export const LINE_ICON = `<svg xmlns="http://www.w3.org/2000/svg" width="320" height="320" viewBox="0 0 320 320"><defs><style>.cls-1{fill:#06c755;}.cls-2{fill:#fff;}</style></defs><g id="Layer_2" data-name="Layer 2"><g id="LINE_LOGO" data-name="LINE LOGO"><rect class="cls-1" width="320" height="320" rx="72.14"/><path class="cls-2" d="M266.66,144.92c0-47.74-47.86-86.58-106.69-86.58S53.28,97.18,53.28,144.92c0,42.8,38,78.65,89.22,85.42,3.48.75,8.21,2.29,9.4,5.26,1.08,2.7.71,6.93.35,9.65,0,0-1.25,7.53-1.52,9.13-.47,2.7-2.15,10.55,9.24,5.76s61.44-36.18,83.82-61.95h0C259.25,181.24,266.66,164,266.66,144.92Z"/><path class="cls-1" d="M231.16,172.49h-30a2,2,0,0,1-2-2v0h0V123.94h0v0a2,2,0,0,1,2-2h30a2,2,0,0,1,2,2v7.57a2,2,0,0,1-2,2H210.79v7.85h20.37a2,2,0,0,1,2,2V151a2,2,0,0,1-2,2H210.79v7.86h20.37a2,2,0,0,1,2,2v7.56A2,2,0,0,1,231.16,172.49Z"/><path class="cls-1" d="M120.29,172.49a2,2,0,0,0,2-2v-7.56a2,2,0,0,0-2-2H99.92v-37a2,2,0,0,0-2-2H90.32a2,2,0,0,0-2,2v46.53h0v0a2,2,0,0,0,2,2h30Z"/><rect class="cls-1" x="128.73" y="121.85" width="11.64" height="50.64" rx="2.04"/><path class="cls-1" d="M189.84,121.85h-7.56a2,2,0,0,0-2,2v27.66l-21.3-28.77a1.2,1.2,0,0,0-.17-.21v0l-.12-.12,0,0-.11-.09-.06,0-.11-.08-.06,0-.11-.06-.07,0-.11,0-.07,0-.12,0-.08,0-.12,0h-.08l-.11,0h-7.71a2,2,0,0,0-2,2v46.56a2,2,0,0,0,2,2h7.57a2,2,0,0,0,2-2V142.81l21.33,28.8a2,2,0,0,0,.52.52h0l.12.08.06,0,.1.05.1,0,.07,0,.14,0h0a2.42,2.42,0,0,0,.54.07h7.52a2,2,0,0,0,2-2V123.89A2,2,0,0,0,189.84,121.85Z"/></g></g></svg>`;
|
41
|
+
|
40
42
|
export const FARCASTER_ICON = `<svg width={width} height={height} viewBox="0 0 1000 1000" fill="none" xmlns="http://www.w3.org/2000/svg">
|
41
43
|
<rect width="1000" height="1000" rx="200" fill="#855DCD"/>
|
42
44
|
<path d="M257.778 155.556H742.222V844.444H671.111V528.889H670.414C662.554 441.677 589.258 373.333 500 373.333C410.742 373.333 337.446 441.677 329.586 528.889H328.889V844.444H257.778V155.556Z" fill="white"/>
|
@@ -20,10 +20,6 @@ import type { FetchDeployMetadataResult } from "./deploy-metadata.js";
|
|
20
20
|
* ```ts
|
21
21
|
* import { computePublishedContractAddress } from "thirdweb/deploys";
|
22
22
|
*
|
23
|
-
* const contractMetadata = await fetchPublishedContractMetadata({
|
24
|
-
* client,
|
25
|
-
* chain,
|
26
|
-
* });
|
27
23
|
* const address = await computePublishedContractAddress({
|
28
24
|
* client,
|
29
25
|
* chain,
|
@@ -46,14 +46,13 @@ export async function computeDeploymentInfoFromMetadata(args: {
|
|
46
46
|
salt?: string;
|
47
47
|
}) {
|
48
48
|
const { client, chain, contractMetadata, constructorParams, salt } = args;
|
49
|
-
const { compilerMetadata } = contractMetadata;
|
50
49
|
const create2FactoryAddress = await computeCreate2FactoryAddress({
|
51
50
|
client,
|
52
51
|
chain,
|
53
52
|
});
|
54
|
-
const bytecode =
|
53
|
+
const bytecode = contractMetadata.bytecode;
|
55
54
|
const constructorAbi =
|
56
|
-
(
|
55
|
+
(contractMetadata.abi.find(
|
57
56
|
(abi) => abi.type === "constructor",
|
58
57
|
) as AbiConstructor) || [];
|
59
58
|
const encodedArgs = encodeAbiParameters(
|
@@ -10,10 +10,8 @@ export type FetchDeployMetadataOptions = {
|
|
10
10
|
client: ThirdwebClient;
|
11
11
|
};
|
12
12
|
|
13
|
-
export type FetchDeployMetadataResult =
|
14
|
-
|
15
|
-
extendedMetadata: ExtendedMetadata | undefined;
|
16
|
-
};
|
13
|
+
export type FetchDeployMetadataResult = Partial<ExtendedMetadata> &
|
14
|
+
CompilerMetadata;
|
17
15
|
|
18
16
|
/**
|
19
17
|
* Fetches the deployment metadata.
|
@@ -24,31 +22,6 @@ export type FetchDeployMetadataResult = {
|
|
24
22
|
export async function fetchDeployMetadata(
|
25
23
|
options: FetchDeployMetadataOptions,
|
26
24
|
): Promise<FetchDeployMetadataResult> {
|
27
|
-
const [compilerMetadata, extendedMetadata] = await Promise.all([
|
28
|
-
fetchCompilerMetadata(options),
|
29
|
-
fetchExtendedMetadata(options).catch(() => undefined),
|
30
|
-
]);
|
31
|
-
return { compilerMetadata, extendedMetadata };
|
32
|
-
}
|
33
|
-
|
34
|
-
// helpers
|
35
|
-
/**
|
36
|
-
* Fetches the published metadata.
|
37
|
-
* @param options - The options for fetching the published metadata.
|
38
|
-
* @internal
|
39
|
-
*/
|
40
|
-
async function fetchExtendedMetadata(
|
41
|
-
options: FetchDeployMetadataOptions,
|
42
|
-
): Promise<ExtendedMetadata> {
|
43
|
-
return download({
|
44
|
-
uri: options.uri,
|
45
|
-
client: options.client,
|
46
|
-
}).then((r) => r.json());
|
47
|
-
}
|
48
|
-
|
49
|
-
async function fetchCompilerMetadata(
|
50
|
-
options: FetchDeployMetadataOptions,
|
51
|
-
): Promise<CompilerMetadata> {
|
52
25
|
const rawMeta: RawCompilerMetadata = await download({
|
53
26
|
uri: options.uri,
|
54
27
|
client: options.client,
|
@@ -144,11 +117,13 @@ export type ExtendedMetadata = {
|
|
144
117
|
publisherAddress: string;
|
145
118
|
}[]
|
146
119
|
| undefined;
|
147
|
-
defaultModules?:
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
120
|
+
defaultModules?:
|
121
|
+
| Array<{
|
122
|
+
moduleName: string;
|
123
|
+
moduleVersion: string;
|
124
|
+
publisherAddress: string;
|
125
|
+
}>
|
126
|
+
| undefined;
|
152
127
|
publisher?: string | undefined;
|
153
128
|
audit?: string | undefined;
|
154
129
|
logo?: string | undefined;
|
package/src/utils/domains.ts
CHANGED
@@ -32,8 +32,8 @@ type DomainOverrides = {
|
|
32
32
|
};
|
33
33
|
|
34
34
|
export const DEFAULT_RPC_URL = "rpc.thirdweb.com";
|
35
|
-
const DEFAULT_IN_APP_WALLET_URL = "embedded-wallet.thirdweb.com";
|
36
35
|
const DEFAULT_SOCIAL_URL = "social.thirdweb.com";
|
36
|
+
const DEFAULT_IN_APP_WALLET_URL = "embedded-wallet.thirdweb.com";
|
37
37
|
const DEFAULT_PAY_URL = "pay.thirdweb.com";
|
38
38
|
const DEFAULT_STORAGE_URL = "storage.thirdweb.com";
|
39
39
|
const DEFAULT_BUNDLER_URL = "bundler.thirdweb.com";
|
package/src/utils/ipfs.ts
CHANGED
@@ -107,7 +107,9 @@ export async function uploadOrExtractURIs<
|
|
107
107
|
* @throws If the batch contains URIs with different base URIs or if no base URI is found.
|
108
108
|
* @internal
|
109
109
|
*/
|
110
|
-
export function getBaseUriFromBatch(uris: string[]): string {
|
110
|
+
export function getBaseUriFromBatch(uris: string | string[]): string {
|
111
|
+
// biome-ignore lint/style/noParameterAssign: lemme do my stuff
|
112
|
+
uris = Array.isArray(uris) ? uris : [uris];
|
111
113
|
const [base, ...rest] = uris.map((uri) => {
|
112
114
|
// remove query parameters
|
113
115
|
// biome-ignore lint/style/noParameterAssign: lemme do my stuff
|
package/src/version.ts
CHANGED
@@ -1 +1 @@
|
|
1
|
-
export const version = "5.53.
|
1
|
+
export const version = "5.53.1-nightly-865c5e3b16af70c3660f30ba8cffc5d6e360a389-20240911000352";
|
@@ -109,6 +109,7 @@ export class InAppNativeConnector implements InAppConnector {
|
|
109
109
|
case "google":
|
110
110
|
case "facebook":
|
111
111
|
case "discord":
|
112
|
+
case "line":
|
112
113
|
case "apple": {
|
113
114
|
const ExpoLinking = require("expo-linking");
|
114
115
|
const redirectUrl =
|
@@ -144,6 +145,7 @@ export class InAppNativeConnector implements InAppConnector {
|
|
144
145
|
case "google":
|
145
146
|
case "facebook":
|
146
147
|
case "discord":
|
148
|
+
case "line":
|
147
149
|
case "farcaster":
|
148
150
|
case "telegram":
|
149
151
|
case "apple": {
|
@@ -14,6 +14,8 @@ import { createInAppWallet } from "../core/wallet/in-app-core.js";
|
|
14
14
|
* - Apple
|
15
15
|
* - Facebook
|
16
16
|
* - Discord
|
17
|
+
* - Telegram
|
18
|
+
* - LINE
|
17
19
|
* - Farcaster
|
18
20
|
*
|
19
21
|
* Can also be configured to use Account Abstraction to directly connect to a ERC4337 smart account based on those authentication methods.
|
@@ -215,6 +215,7 @@ export class InAppWebConnector implements InAppConnector {
|
|
215
215
|
case "google":
|
216
216
|
case "telegram":
|
217
217
|
case "farcaster":
|
218
|
+
case "line":
|
218
219
|
case "discord": {
|
219
220
|
return loginWithOauth({
|
220
221
|
authOption: strategy,
|
@@ -275,6 +276,7 @@ export class InAppWebConnector implements InAppConnector {
|
|
275
276
|
case "google":
|
276
277
|
case "farcaster":
|
277
278
|
case "telegram":
|
279
|
+
case "line":
|
278
280
|
case "discord": {
|
279
281
|
const authToken = await this.authenticate(args);
|
280
282
|
return this.auth.loginWithAuthToken(authToken);
|