UNPKG

@tatumio/tatum-v1

Version:

Tatum API client allows browsers and Node.js clients to interact with Tatum API.

340 lines 31.9 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.sendMarketplaceCancelListing = exports.sendMarketplaceBuyListing = exports.sendMarketplaceCreateListing = exports.sendMarketplaceApproveErc20Spending = exports.sendMarketplaceUpdateFeeRecipient = exports.sendMarketplaceUpdateFee = exports.prepareMarketplaceCancelListing = exports.prepareMarketplaceBuyListing = exports.prepareMarketplaceCreateListing = exports.prepareMarketplaceApproveErc20Spending = exports.prepareMarketplaceUpdateFeeRecipient = exports.prepareMarketplaceUpdateFee = exports.prepareDeployMarketplaceListing = exports.deployMarketplaceListing = exports.getMarketplaceFeeRecipient = exports.getMarketplaceListing = exports.getMarketplaceFee = void 0; const bignumber_js_1 = __importDefault(require("bignumber.js")); const tatum_1 = require("../../connector/tatum"); const fungible_1 = require("../../fungible"); const helpers_1 = require("../../helpers"); const model_1 = require("../../model"); const transaction_1 = require("../../transaction"); var ListingState; (function (ListingState) { ListingState["INITIATED"] = "0"; ListingState["SOLD"] = "1"; ListingState["CANCELLED"] = "2"; })(ListingState || (ListingState = {})); /** * For more details, see <a href="https://apidoc.tatum.io/#operation/GetMarketplaceFee" target="_blank">Tatum API documentation</a> */ const getMarketplaceFee = async (chain, contractAddress) => tatum_1.get(`/v3/blockchain/marketplace/listing/${chain}/${contractAddress}/fee`); exports.getMarketplaceFee = getMarketplaceFee; /** * For more details, see <a href="https://apidoc.tatum.io/#operation/GetMarketplaceListing" target="_blank">Tatum API documentation</a> */ const getMarketplaceListing = async (chain, contractAddress, listingId) => tatum_1.get(`/v3/blockchain/marketplace/listing/${chain}/${contractAddress}/listing/${listingId}`); exports.getMarketplaceListing = getMarketplaceListing; /** * For more details, see <a href="https://apidoc.tatum.io/#operation/GetMarketplaceFeeRecipient" target="_blank">Tatum API documentation</a> */ const getMarketplaceFeeRecipient = async (chain, contractAddress) => tatum_1.get(`/v3/blockchain/marketplace/listing/${chain}/${contractAddress}/recipient`); exports.getMarketplaceFeeRecipient = getMarketplaceFeeRecipient; /** * Deploy new smart contract for NFT marketplace logic. Smart contract enables marketplace operator to create new listing for NFT (ERC-721/1155). * Operator can set a fee in percentage, which will be paid on top of the price of the asset. * Listing can be offered for native asset - ETH, BSC, etc. - or any ERC20 token - this is configurable during listing creation. * Once the listing is created, seller must send the NFT asset to the smart contract. * Buyer will buy the asset from the listing using native asset - send assets along the buyAssetFromListing() smart contract call, or via ERC20 token. * Buyer of the listing must perform approval for the smart contract to access ERC20 token, before the actual buyAssetFromListing() method is called. * Once both assets - from buyer and seller - are in the smart contract, NFT is sent to the buyer, price is sent to the seller * and marketplace fee is set to the operator. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const deployMarketplaceListing = async (testnet, body, provider) => { switch (body.chain) { case model_1.Currency.CELO: return await transaction_1.sendCeloDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.ONE: return await transaction_1.sendOneDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.ETH: return await transaction_1.sendEthDeployMarketplaceListingSignedTransaction(body, provider); case model_1.Currency.BSC: return await transaction_1.sendBscDeployMarketplaceListingSignedTransaction(body, provider); case model_1.Currency.MATIC: return await transaction_1.sendPolygonDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.KLAY: return await transaction_1.sendKlaytnDeployMarketplaceListingSignedTransaction(testnet, body, provider); // case Currency.TRON: // return await sendTronDeployMarketplaceListingSignedTransaction(testnet, body as DeployTronMarketplaceListing, provider) default: throw new Error('Unsupported chain'); } }; exports.deployMarketplaceListing = deployMarketplaceListing; /** * Prepare signed transaction for deploy new smart contract for NFT marketplace logic. Smart contract enables marketplace operator to create new listing for NFT (ERC-721/1155). * Operator can set a fee in percentage, which will be paid on top of the price of the asset. * Listing can be offered for native asset - ETH, BSC, etc. - or any ERC20 token - this is configurable during listing creation. * Once the listing is created, seller must send the NFT asset to the smart contract. * Buyer will buy the asset from the listing using native asset - send assets along the buyAssetFromListing() smart contract call, or via ERC20 token. * Buyer of the listing must perform approval for the smart contract to access ERC20 token, before the actual buyAssetFromListing() method is called. * Once both assets - from buyer and seller - are in the smart contract, NFT is sent to the buyer, price is sent to the seller * and marketplace fee is set to the operator. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareDeployMarketplaceListing = async (testnet, body, provider) => { switch (body.chain) { case model_1.Currency.CELO: return await transaction_1.prepareCeloDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.ONE: return await transaction_1.prepareOneDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.ETH: return await transaction_1.prepareEthDeployMarketplaceListingSignedTransaction(body, provider); case model_1.Currency.BSC: return await transaction_1.prepareBscDeployMarketplaceListingSignedTransaction(body, provider); case model_1.Currency.MATIC: return await transaction_1.preparePolygonDeployMarketplaceListingSignedTransaction(testnet, body, provider); case model_1.Currency.KLAY: return await transaction_1.prepareKlaytnDeployMarketplaceListingSignedTransaction(testnet, body, provider); // case Currency.TRON: // return await prepareTronDeployMarketplaceListingSignedTransaction(testnet, body as DeployTronMarketplaceListing, provider) default: throw new Error('Unsupported chain'); } }; exports.prepareDeployMarketplaceListing = prepareDeployMarketplaceListing; /** * Update marketplace fee. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceUpdateFee = async (testnet, body, provider) => { await tatum_1.validateBody(body, body.chain === model_1.Currency.TRON ? model_1.UpdateTronMarketplaceFee : model_1.UpdateMarketplaceFee); const params = [`0x${new bignumber_js_1.default(body.marketplaceFee).toString(16)}`]; if (body.chain === model_1.Currency.TRON) { throw new Error('Unsupported chain'); // return await helperPrepareSCCall(testnet, body, UpdateTronMarketplaceFee, 'setMarketplaceFee', // [ // {type: 'uint256', value: params[0]}, // ], 'setMarketplaceFee(uint256)', provider) } else { return await helpers_1.helperPrepareSCCall(testnet, body, model_1.UpdateMarketplaceFee, 'setMarketplaceFee', params, undefined, provider); } }; exports.prepareMarketplaceUpdateFee = prepareMarketplaceUpdateFee; /** * Update marketplace fee recipient. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceUpdateFeeRecipient = async (testnet, body, provider) => { await tatum_1.validateBody(body, body.chain === model_1.Currency.TRON ? model_1.UpdateTronMarketplaceFeeRecipient : model_1.UpdateMarketplaceFeeRecipient); const params = [body.feeRecipient]; if (body.chain === model_1.Currency.TRON) { throw new Error('Unsupported chain'); // return await helperPrepareSCCall(testnet, body, UpdateTronMarketplaceFeeRecipient, 'setMarketplaceFeeRecipient', // [ // {type: 'address', value: convertAddressToHex(params[0])}, // ], 'setMarketplaceFeeRecipient(address)', provider) } else { return await helpers_1.helperPrepareSCCall(testnet, body, model_1.UpdateMarketplaceFeeRecipient, 'setMarketplaceFeeRecipient', params, undefined, provider); } }; exports.prepareMarketplaceUpdateFeeRecipient = prepareMarketplaceUpdateFeeRecipient; /** * Approve ERC20 spending for marketplace to perform buy with ERC20 token. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceApproveErc20Spending = async (testnet, body, provider) => { return fungible_1.prepareApproveErc20(testnet, body, provider); }; exports.prepareMarketplaceApproveErc20Spending = prepareMarketplaceApproveErc20Spending; /** * Create new listing on the marketplace. * After listing is created, seller must send the asset to the marketplace smart contract. * Only listing for existing NFTs can be created - seller must be owner of the NFT asset. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceCreateListing = async (testnet, body, provider) => { await tatum_1.validateBody(body, body.chain === model_1.Currency.TRON ? model_1.CreateTronMarketplaceListing : model_1.CreateMarketplaceListing); const decimals = body.erc20Address ? await fungible_1.getErc20Decimals(testnet, body.chain, body.erc20Address, provider) : 18; const params = [body.listingId, body.isErc721, body.nftAddress.trim(), `0x${new bignumber_js_1.default(body.tokenId).toString(16)}`, `0x${new bignumber_js_1.default(body.price).multipliedBy(10 ** decimals).toString(16)}`, body.seller.trim(), `0x${new bignumber_js_1.default(body.amount || 0).toString(16)}`, body.erc20Address || '0x0000000000000000000000000000000000000000']; if (body.chain === model_1.Currency.TRON) { throw new Error('Unsupported chain'); // if (!body.erc20Address) { // params[7] = 'T9yD14Nj9j7xAB4dbGeiX9h8unkKHxuWwb'; // } // return await helperPrepareSCCall(testnet, body, CreateTronMarketplaceListing, 'createListing', // [ // {type: 'string', value: params[0]}, // {type: 'bool', value: params[1]}, // {type: 'address', value: convertAddressToHex(params[2] as string)}, // {type: 'uint256', value: params[3]}, // {type: 'uint256', value: params[4]}, // {type: 'address', value: convertAddressToHex(params[5] as string)}, // {type: 'uint256', value: params[6]}, // {type: 'address', value: convertAddressToHex(params[7] as string)}, // ], 'createListing(string,bool,address,uint256,uint256,address,uint256,address)', provider) } else { if (!body.isErc721) { body.amount = undefined; } return await helpers_1.helperPrepareSCCall(testnet, body, model_1.CreateMarketplaceListing, 'createListing', params, undefined, provider); } }; exports.prepareMarketplaceCreateListing = prepareMarketplaceCreateListing; /** * Buy listing on the marketplace. Buyer must either send native assets with this operation, or approve ERC20 token spending before. * After listing is sold, it's in a pending state to be processed by the marketplace. Noone receives the assets unless the marketplace operator processes that. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceBuyListing = async (testnet, body, provider) => { await tatum_1.validateBody(body, body.chain === model_1.Currency.TRON ? model_1.InvokeTronMarketplaceListingOperation : model_1.InvokeMarketplaceListingOperation); const params = [body.listingId, body.erc20Address || '0x0000000000000000000000000000000000000000']; let methodName = 'buyAssetFromListing'; if (body.erc20Address) { body.amount = undefined; if (body.buyer) { params.push(body.buyer.trim()); methodName = 'buyAssetFromListingForExternalBuyer'; } } if (body.chain === model_1.Currency.TRON) { throw new Error('Unsupported chain'); // return await helperPrepareSCCall(testnet, body, InvokeTronMarketplaceListingOperation, 'buyAssetFromListing', // [ // {type: 'string', value: params[0]}, // {type: 'address', value: convertAddressToHex(params[1])}, // ], 'buyAssetFromListing(string,address)', provider); } else { return await helpers_1.helperPrepareSCCall(testnet, body, model_1.InvokeMarketplaceListingOperation, methodName, params, undefined, provider); } }; exports.prepareMarketplaceBuyListing = prepareMarketplaceBuyListing; /** * Cancel listing on the marketplace. Only possible for the seller or the operator. There must be no buyer present for that listing. NFT asset is sent back to the seller. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const prepareMarketplaceCancelListing = async (testnet, body, provider) => { await tatum_1.validateBody(body, body.chain === model_1.Currency.TRON ? model_1.InvokeTronMarketplaceListingOperation : model_1.InvokeMarketplaceListingOperation); const params = [body.listingId]; if (body.chain === model_1.Currency.TRON) { throw new Error('Unsupported chain'); // return await helperPrepareSCCall(testnet, body, InvokeTronMarketplaceListingOperation, 'cancelListing', // [ // {type: 'string', value: params[0]}, // ], 'cancelListing(string)', provider) } else { return await helpers_1.helperPrepareSCCall(testnet, body, model_1.InvokeMarketplaceListingOperation, 'cancelListing', params, undefined, provider); } }; exports.prepareMarketplaceCancelListing = prepareMarketplaceCancelListing; /** * Update marketplace fee. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceUpdateFee = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.put(`v3/blockchain/marketplace/listing/recipient`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceUpdateFee(testnet, body, provider)); }; exports.sendMarketplaceUpdateFee = sendMarketplaceUpdateFee; /** * Update marketplace fee recipient. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceUpdateFeeRecipient = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.put(`v3/blockchain/marketplace/listing/fee`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceUpdateFeeRecipient(testnet, body, provider)); }; exports.sendMarketplaceUpdateFeeRecipient = sendMarketplaceUpdateFeeRecipient; /** * Approve ERC20 spending for marketplace to perform buy with ERC20 token. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceApproveErc20Spending = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.post(`v3/blockchain/token/approve`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceApproveErc20Spending(testnet, body, provider)); }; exports.sendMarketplaceApproveErc20Spending = sendMarketplaceApproveErc20Spending; /** * Create new listing on the marketplace. * After listing is created, seller must send the asset to the marketplace smart contract. * Only listing for existing NFTs can be created - seller must be owner of the NFT asset. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceCreateListing = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.post(`v3/blockchain/marketplace/listing/sell`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceCreateListing(testnet, body, provider)); }; exports.sendMarketplaceCreateListing = sendMarketplaceCreateListing; /** * Buy listing on the marketplace. Buyer must either send native assets with this operation, or approve ERC20 token spending before. * After listing is sold, it's in a pending state to be processed by the marketplace. Noone receives the assets unless the marketplace operator processes that. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceBuyListing = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.post(`v3/blockchain/marketplace/listing/buy`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceBuyListing(testnet, body, provider)); }; exports.sendMarketplaceBuyListing = sendMarketplaceBuyListing; /** * Cancel listing on the marketplace. Only possible for the seller or the operator. There must be no buyer present for that listing. NFT asset is sent back to the seller. * @param testnet chain to work with * @param body request data * @param provider optional provider to enter. if not present, Tatum Web3 will be used. * @returns {txId: string} Transaction ID of the operation, or signatureID in case of Tatum KMS */ const sendMarketplaceCancelListing = async (testnet, body, provider) => { if (body.signatureId) { return await tatum_1.post(`v3/blockchain/marketplace/listing/cancel`, body); } return helpers_1.helperBroadcastTx(body.chain, await exports.prepareMarketplaceCancelListing(testnet, body, provider)); }; exports.sendMarketplaceCancelListing = sendMarketplaceCancelListing; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listing.js","sourceRoot":"","sources":["../../../../src/nft/marketplace/listing.ts"],"names":[],"mappings":"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"}