UNPKG

fbonds-core

Version:

Banx protocol sdk

85 lines (84 loc) 5.21 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.getLastTransactedAtFromPerpetualBondTradeTransaction = exports.getFilteredAccountsByNumber = exports.getFilteredAccounts = exports.getAllPerpetualProgramAccounts = void 0; const constants_1 = require("../../constants"); const helpers_1 = require("../../helpers"); const types_1 = require("../../types"); const perpetual_1 = require("../perpetual"); const anchor_1 = require("@coral-xyz/anchor"); const bytes_1 = require("@coral-xyz/anchor/dist/cjs/utils/bytes"); const getAllPerpetualProgramAccounts = (connection) => __awaiter(void 0, void 0, void 0, function* () { const program = (0, helpers_1.returnAnchorProgram)(connection); const fraktBondsOffset = 8; const fraktBondsRaw = yield (0, exports.getFilteredAccounts)(program, 'fraktBond', fraktBondsOffset, [5, 6, 7, 8]); const fraktBonds = fraktBondsRaw.map((fraktBondRaw) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(fraktBondRaw)); const hadoMarketRegistry = (yield program.account.hadoMarketRegistry.all()).map((raw) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(raw)); const hadoMarketValidation = (yield program.account.hadoMarketValidation.all()).map((raw) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(raw)); const hadoMarketOffset = 32 + 8; const hadoMarketsRaw = yield (0, exports.getFilteredAccounts)(program, 'hadoMarket', hadoMarketOffset, [3, 4]); const hadoMarkets = hadoMarketsRaw.map((hadoMarketRaw) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(hadoMarketRaw)); const bondOfferOffset = 32 + 8; const bondOffersV3Raw = yield (0, exports.getFilteredAccounts)(program, 'bondOfferV3', bondOfferOffset, [5, 6, 7, 8, 9]); const bondOffersV3 = bondOffersV3Raw.map((acc) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(acc)); const bondTradeTxnOffset = 8; const bondTradeTxnRawV3 = yield (0, exports.getFilteredAccounts)(program, 'bondTradeTransactionV3', bondTradeTxnOffset, [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17]); // const bondTradeTxnRawV2 = await getFilteredAccounts( // program, // 'bondTradeTransactionV2', // bondTradeTxnOffset, // [2, 3, 4, 5, 6, 7, 8, 9], // ); const bondTradeTransactionsV3 = bondTradeTxnRawV3.map((acc) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(acc)); const userVault = (yield program.account.userVault.all()).map((raw) => (0, helpers_1.anchorRawBNsAndPubkeysToNumsAndStrings)(raw)); return { userVault, bondTradeTransactionsV3, fraktBonds, hadoMarketRegistry, hadoMarkets, hadoMarketValidation, bondOffersV3, }; }); exports.getAllPerpetualProgramAccounts = getAllPerpetualProgramAccounts; const getFilteredAccounts = (program, accountName, offset, indexes) => __awaiter(void 0, void 0, void 0, function* () { return (yield Promise.all(indexes.map((i) => program.account[accountName].all([ { memcmp: { offset: offset, // number of bytes bytes: bytes_1.bs58.encode(Buffer.from([i])), //PerpetualActive }, }, ])))).flat(); }); exports.getFilteredAccounts = getFilteredAccounts; const getFilteredAccountsByNumber = (program, accountName, offset, indexes) => __awaiter(void 0, void 0, void 0, function* () { return (yield Promise.all(indexes.map((i) => program.account[accountName].all([ { memcmp: { offset: offset, // number of bytes bytes: bytes_1.bs58.encode(new anchor_1.BN(i).toBuffer()), //PerpetualActive }, }, ])))).flat(); }); exports.getFilteredAccountsByNumber = getFilteredAccountsByNumber; const getLastTransactedAtFromPerpetualBondTradeTransaction = (bond_trade_txn) => { if (bond_trade_txn.bondTradeTransactionState === types_1.BondTradeTransactionV2State.PerpetualActive) return bond_trade_txn.soldAt; if (bond_trade_txn.bondTradeTransactionState === types_1.BondTradeTransactionV2State.PerpetualManualTerminating || new anchor_1.BN((0, perpetual_1.nowInSeconds)()) < bond_trade_txn.redeemedAt.add(new anchor_1.BN(constants_1.TERMINATION_PERIOD))) return bond_trade_txn.redeemedAt; else return bond_trade_txn.redeemedAt.add(new anchor_1.BN(constants_1.TERMINATION_PERIOD)); }; exports.getLastTransactedAtFromPerpetualBondTradeTransaction = getLastTransactedAtFromPerpetualBondTradeTransaction;