From 52abd1a0d4f4ac0a5341451577a545e6374c3bf5 Mon Sep 17 00:00:00 2001 From: Phillip Ho Date: Sun, 8 Dec 2024 17:44:50 +0800 Subject: [PATCH] chore: Update ERC20 and ERC1155 mintTo to thirdweb v5 --- .../extensions/erc1155/write/mintTo.ts | 79 +++++++++++++------ .../contract/extensions/erc20/write/mintTo.ts | 58 +++++++++----- .../extensions/erc721/write/mintTo.ts | 2 + 3 files changed, 99 insertions(+), 40 deletions(-) diff --git a/src/server/routes/contract/extensions/erc1155/write/mintTo.ts b/src/server/routes/contract/extensions/erc1155/write/mintTo.ts index 0f72457f8..4fe92d9be 100644 --- a/src/server/routes/contract/extensions/erc1155/write/mintTo.ts +++ b/src/server/routes/contract/extensions/erc1155/write/mintTo.ts @@ -1,8 +1,12 @@ import { Type, type Static } from "@sinclair/typebox"; import type { FastifyInstance } from "fastify"; import { StatusCodes } from "http-status-codes"; -import { queueTx } from "../../../../../../db/transactions/queueTx"; -import { getContract } from "../../../../../../utils/cache/getContract"; +import { getContract } from "thirdweb"; +import { mintTo } from "thirdweb/extensions/erc1155"; +import type { NFTInput } from "thirdweb/utils"; +import { getChain } from "../../../../../../utils/chain"; +import { thirdwebClient } from "../../../../../../utils/sdk"; +import { queueTransaction } from "../../../../../../utils/transaction/queueTransation"; import { AddressSchema } from "../../../../../schemas/address"; import { nftAndSupplySchema } from "../../../../../schemas/nft"; import { @@ -12,10 +16,13 @@ import { transactionWritesResponseSchema, } from "../../../../../schemas/sharedApiSchemas"; import { txOverridesWithValueSchema } from "../../../../../schemas/txOverrides"; -import { walletWithAAHeaderSchema } from "../../../../../schemas/wallet"; +import { + maybeAddress, + requiredAddress, + walletWithAAHeaderSchema, +} from "../../../../../schemas/wallet"; import { getChainIdFromChain } from "../../../../../utils/chain"; -// INPUTS const requestSchema = erc1155ContractParamSchema; const requestBodySchema = Type.Object({ receiver: { @@ -66,34 +73,62 @@ export async function erc1155mintTo(fastify: FastifyInstance) { }, }, handler: async (request, reply) => { - const { chain, contractAddress } = request.params; + const { chain: _chain, contractAddress } = request.params; const { simulateTx } = request.query; const { receiver, metadataWithSupply, txOverrides } = request.body; const { - "x-backend-wallet-address": walletAddress, + "x-backend-wallet-address": fromAddress, "x-account-address": accountAddress, "x-idempotency-key": idempotencyKey, + "x-account-factory-address": accountFactoryAddress, + "x-account-salt": accountSalt, } = request.headers as Static; - const chainId = await getChainIdFromChain(chain); - const contract = await getContract({ - chainId, - contractAddress, - walletAddress, - accountAddress, + const chainId = await getChainIdFromChain(_chain); + const chain = await getChain(chainId); + + const contract = getContract({ + chain, + client: thirdwebClient, + address: contractAddress, }); - const tx = await contract.erc1155.mintTo.prepare( - receiver, - metadataWithSupply, - ); - const queueId = await queueTx({ - tx, - chainId, - simulateTx, - extension: "erc1155", - idempotencyKey, + // Backward compatibility: Transform the request body's v4 shape to v5. + const { metadata, supply } = metadataWithSupply; + const nft: NFTInput | string = + typeof metadata === "string" + ? metadata + : { + name: metadata.name?.toString() ?? undefined, + description: metadata.description ?? undefined, + image: metadata.image ?? undefined, + animation_url: metadata.animation_url ?? undefined, + external_url: metadata.external_url ?? undefined, + background_color: metadata.background_color ?? undefined, + properties: metadata.properties, + }; + const transaction = mintTo({ + contract, + to: receiver, + nft, + supply: BigInt(supply), + }); + + const queueId = await queueTransaction({ + transaction, + fromAddress: requiredAddress(fromAddress, "x-backend-wallet-address"), + toAddress: maybeAddress(contractAddress, "to"), + accountAddress: maybeAddress(accountAddress, "x-account-address"), + accountFactoryAddress: maybeAddress( + accountFactoryAddress, + "x-account-factory-address", + ), + accountSalt, txOverrides, + idempotencyKey, + extension: "erc1155", + functionName: "mintTo", + shouldSimulate: simulateTx, }); reply.status(StatusCodes.OK).send({ diff --git a/src/server/routes/contract/extensions/erc20/write/mintTo.ts b/src/server/routes/contract/extensions/erc20/write/mintTo.ts index db3a9968e..32d54e502 100644 --- a/src/server/routes/contract/extensions/erc20/write/mintTo.ts +++ b/src/server/routes/contract/extensions/erc20/write/mintTo.ts @@ -1,8 +1,11 @@ import { Type, type Static } from "@sinclair/typebox"; import type { FastifyInstance } from "fastify"; import { StatusCodes } from "http-status-codes"; -import { queueTx } from "../../../../../../db/transactions/queueTx"; -import { getContract } from "../../../../../../utils/cache/getContract"; +import { getContract } from "thirdweb"; +import { mintTo } from "thirdweb/extensions/erc20"; +import { getChain } from "../../../../../../utils/chain"; +import { thirdwebClient } from "../../../../../../utils/sdk"; +import { queueTransaction } from "../../../../../../utils/transaction/queueTransation"; import { AddressSchema } from "../../../../../schemas/address"; import { erc20ContractParamSchema, @@ -11,7 +14,11 @@ import { transactionWritesResponseSchema, } from "../../../../../schemas/sharedApiSchemas"; import { txOverridesWithValueSchema } from "../../../../../schemas/txOverrides"; -import { walletWithAAHeaderSchema } from "../../../../../schemas/wallet"; +import { + maybeAddress, + requiredAddress, + walletWithAAHeaderSchema, +} from "../../../../../schemas/wallet"; import { getChainIdFromChain } from "../../../../../utils/chain"; // INPUTS @@ -59,31 +66,46 @@ export async function erc20mintTo(fastify: FastifyInstance) { }, }, handler: async (request, reply) => { - const { chain, contractAddress } = request.params; + const { chain: _chain, contractAddress } = request.params; const { simulateTx } = request.query; const { toAddress, amount, txOverrides } = request.body; const { - "x-backend-wallet-address": walletAddress, + "x-backend-wallet-address": fromAddress, "x-account-address": accountAddress, "x-idempotency-key": idempotencyKey, + "x-account-factory-address": accountFactoryAddress, + "x-account-salt": accountSalt, } = request.headers as Static; - const chainId = await getChainIdFromChain(chain); - const contract = await getContract({ - chainId, - contractAddress, - walletAddress, - accountAddress, + const chainId = await getChainIdFromChain(_chain); + const chain = await getChain(chainId); + + const contract = getContract({ + chain, + client: thirdwebClient, + address: contractAddress, + }); + const transaction = mintTo({ + contract, + to: toAddress, + amount, }); - const tx = await contract.erc20.mintTo.prepare(toAddress, amount); - const queueId = await queueTx({ - tx, - chainId, - simulateTx, - extension: "erc20", - idempotencyKey, + const queueId = await queueTransaction({ + transaction, + fromAddress: requiredAddress(fromAddress, "x-backend-wallet-address"), + toAddress: maybeAddress(contractAddress, "to"), + accountAddress: maybeAddress(accountAddress, "x-account-address"), + accountFactoryAddress: maybeAddress( + accountFactoryAddress, + "x-account-factory-address", + ), + accountSalt, txOverrides, + idempotencyKey, + extension: "erc20", + functionName: "mintTo", + shouldSimulate: simulateTx, }); reply.status(StatusCodes.OK).send({ diff --git a/src/server/routes/contract/extensions/erc721/write/mintTo.ts b/src/server/routes/contract/extensions/erc721/write/mintTo.ts index 22e6345ca..0a8f108da 100644 --- a/src/server/routes/contract/extensions/erc721/write/mintTo.ts +++ b/src/server/routes/contract/extensions/erc721/write/mintTo.ts @@ -120,6 +120,8 @@ export async function erc721mintTo(fastify: FastifyInstance) { accountSalt, txOverrides, idempotencyKey, + extension: "erc721", + functionName: "mintTo", shouldSimulate: simulateTx, });