@tatumio/tatum-v1
Version:
Tatum API client allows browsers and Node.js clients to interact with Tatum API.
340 lines • 31.9 kB
JavaScript
;
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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"}