hadeswap-sdk
Version:
HadeSwap SDK for interacting with protocol
66 lines (65 loc) • 3.81 kB
JavaScript
;
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;