hadeswap-sdk
Version:
HadeSwap SDK for interacting with protocol
55 lines (54 loc) • 3.35 kB
JavaScript
"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.validateNft = void 0;
const anchor_1 = require("@project-serum/anchor");
const constants_1 = require("../../../hadeswap-core/constants");
const helpers_1 = require("../../../hadeswap-core/helpers");
const constants_2 = require("../../constants");
const helpers_2 = require("../../helpers");
const validateNft = ({ programId, connection, args, accounts, sendTxn }) => __awaiter(void 0, void 0, void 0, function* () {
const program = (0, helpers_2.returnAnchorProgram)(programId, connection);
const instructions = [];
const nftValidationAdapter = anchor_1.web3.Keypair.generate();
const metadataInfo = (0, helpers_1.getMetaplexMetadataPda)(accounts.nftMint);
const editionInfo = (0, helpers_1.getMetaplexEditionPda)(accounts.nftMint);
const [adapterProgramAuthority, adapterProgramAuthoritySeed] = yield anchor_1.web3.PublicKey.findProgramAddress([constants_1.ENCODER.encode(constants_2.ADAPTER_PREFIX)], program.programId);
const [hadoRegistry, registrySeed] = yield anchor_1.web3.PublicKey.findProgramAddress([constants_1.ENCODER.encode(constants_2.HADOMARKET_REGISTRY_PREFIX), accounts.hadoMarket.toBuffer()], program.programId);
const [whitelistEntry, whitelistEntrySeed] = yield anchor_1.web3.PublicKey.findProgramAddress([constants_1.ENCODER.encode(constants_2.WHITELIST_ENTRY_PREFIX), accounts.whitelistedAddress.toBuffer()], accounts.fraktMarketRegistryProgramId);
instructions.push(yield program.methods
.validateNft(adapterProgramAuthoritySeed, args.proof)
.accountsStrict({
nftMint: accounts.nftMint,
pair: accounts.pair,
hadoMarket: accounts.hadoMarket,
hadoRegistry: hadoRegistry,
nftValidationAdapter: nftValidationAdapter.publicKey,
fraktMarket: accounts.fraktMarket,
whitelistEntry: whitelistEntry,
adapterProgramAuthority: adapterProgramAuthority,
user: accounts.userPubkey,
systemProgram: anchor_1.web3.SystemProgram.programId,
rent: anchor_1.web3.SYSVAR_RENT_PUBKEY,
metadataProgram: constants_1.METADATA_PROGRAM_PUBKEY,
metadataInfo: metadataInfo,
editionInfo: editionInfo,
hadeSwapProgram: accounts.hadeSwapProgramId,
})
.instruction());
const transaction = new anchor_1.web3.Transaction();
for (let instruction of instructions)
transaction.add(instruction);
const signers = [nftValidationAdapter];
yield sendTxn(transaction, signers);
return { account: nftValidationAdapter.publicKey, instructions, signers };
});
exports.validateNft = validateNft;