UNPKG

hadeswap-sdk

Version:

HadeSwap SDK for interacting with protocol

66 lines (65 loc) 3.81 kB
"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.findRuleSetPDA = exports.getMetaplexMetadata = exports.findTokenRecordPda = exports.enumToAnchorEnum = exports.anchorRawBNsAndPubkeysToNumsAndStrings = exports.returnAnchorProgram = void 0; const anchor_1 = require("@project-serum/anchor"); const auction_1 = require("./idl/auction"); const common_1 = require("../common"); const constants_1 = require("./constants"); const returnAnchorProgram = (programId, connection) => new anchor_1.Program(auction_1.IDL, programId, new anchor_1.AnchorProvider(connection, (0, common_1.createFakeWallet)(), anchor_1.AnchorProvider.defaultOptions())); exports.returnAnchorProgram = returnAnchorProgram; const anchorRawBNsAndPubkeysToNumsAndStrings = (rawAccount) => { const copyRawAccount = Object.assign({}, rawAccount); const newAccount = parseRawAccount(rawAccount.account); return Object.assign(Object.assign({}, newAccount), { publicKey: copyRawAccount.publicKey.toBase58() }); }; exports.anchorRawBNsAndPubkeysToNumsAndStrings = anchorRawBNsAndPubkeysToNumsAndStrings; const parseRawAccount = (rawAccount) => { const copyRawAccount = Object.assign({}, rawAccount); for (let key in copyRawAccount) { if (copyRawAccount[key] === null || copyRawAccount[key] === undefined) continue; if (copyRawAccount[key].toNumber) { copyRawAccount[key] = copyRawAccount[key].toNumber(); } if (copyRawAccount[key].toBase58) { copyRawAccount[key] = copyRawAccount[key].toBase58(); } if (typeof copyRawAccount[key] === 'object' && Object.keys(copyRawAccount[key]).length === 1) { copyRawAccount[key] = Object.keys(copyRawAccount[key])[0]; } else if (typeof copyRawAccount[key] === 'object') { copyRawAccount[key] = parseRawAccount(copyRawAccount[key]); } } return copyRawAccount; }; const enumToAnchorEnum = (anyEnum) => ({ [anyEnum]: {} }); exports.enumToAnchorEnum = enumToAnchorEnum; const findTokenRecordPda = (mintPubkey, token) => { return anchor_1.web3.PublicKey.findProgramAddressSync([ Buffer.from(constants_1.METADATA_PREFIX), constants_1.METADATA_PROGRAM_PUBKEY.toBuffer(), mintPubkey.toBuffer(), Buffer.from(constants_1.TOKEN_RECORD), token.toBuffer(), ], constants_1.METADATA_PROGRAM_PUBKEY)[0]; }; exports.findTokenRecordPda = findTokenRecordPda; const getMetaplexMetadata = (mintPubkey) => { const [metadata] = anchor_1.web3.PublicKey.findProgramAddressSync([Buffer.from(constants_1.METADATA_PREFIX), constants_1.METADATA_PROGRAM_PUBKEY.toBuffer(), mintPubkey.toBuffer()], constants_1.METADATA_PROGRAM_PUBKEY); return metadata; }; exports.getMetaplexMetadata = getMetaplexMetadata; const findRuleSetPDA = (payer, name) => __awaiter(void 0, void 0, void 0, function* () { return (yield anchor_1.web3.PublicKey.findProgramAddress([Buffer.from("rule_set"), payer.toBuffer(), Buffer.from(name)], constants_1.AUTHORIZATION_RULES_PROGRAM))[0]; }); exports.findRuleSetPDA = findRuleSetPDA;