@frakt-protocol/frakt-sdk
Version:
Frakt SDK for interacting with frakt.xyz protocols
79 lines (78 loc) • 3.86 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.claimCardinalIx = void 0;
const anchor_1 = require("@project-serum/anchor");
const helpers_1 = require("../../helpers");
const common_1 = require("../../../common");
const claimCardinalIx = ({ programId, connection, user, payer, cardinalRewardsCenter, nftMint, stakePool, rewardDistributor, loan, rewardMint, claimRewardsPaymentInfo, paymentPubkey1, paymentPubkey2, }) => __awaiter(void 0, void 0, void 0, function* () {
const encoder = new TextEncoder();
const program = (0, helpers_1.returnAnchorProgram)(programId, connection);
const [identity, bumpAuth] = yield anchor_1.web3.PublicKey.findProgramAddress([encoder.encode('degod_cardinal'), user.toBuffer()], programId);
const [lendingStake] = yield anchor_1.web3.PublicKey.findProgramAddress([encoder.encode('stake_acc'), loan.toBuffer()], programId);
const [stakeEntry] = yield anchor_1.web3.PublicKey.findProgramAddress([encoder.encode('stake-entry'), stakePool.toBuffer(), nftMint.toBuffer(), anchor_1.web3.PublicKey.default.toBuffer()], cardinalRewardsCenter);
const [rewardEntry] = yield anchor_1.web3.PublicKey.findProgramAddress([encoder.encode('reward-entry'), rewardDistributor.toBuffer(), stakeEntry.toBuffer(),], cardinalRewardsCenter);
const tokenDestinationIdentity = yield (0, common_1.findAssociatedTokenAddress)(identity, rewardMint);
const rewardDestination = yield (0, common_1.findAssociatedTokenAddress)(user, rewardMint);
const rewardDistributorTokenAccount = yield (0, common_1.findAssociatedTokenAddress)(rewardDistributor, rewardMint);
// const additionalComputeBudgetInstruction = ComputeBudgetProgram.requestUnits({
// units: 400000,
// additionalFee: 0,
// });
const claimIx = yield program.methods.claimCardinal().accountsStrict({
user,
identity,
rewardMint,
payer: payer,
cardinalStakeCenter: cardinalRewardsCenter,
rewardDistributor,
rewardDistributorTokenAccount,
rewardEntry,
stakeEntry,
stakePool,
rewardDestination,
loan,
lendingStake,
tokenDestinationIdentity,
rent: anchor_1.web3.SYSVAR_RENT_PUBKEY,
systemProgram: anchor_1.web3.SystemProgram.programId,
tokenProgram: anchor_1.utils.token.TOKEN_PROGRAM_ID,
associatedTokenProgram: anchor_1.utils.token.ASSOCIATED_PROGRAM_ID,
}).remainingAccounts([
{
pubkey: claimRewardsPaymentInfo,
isSigner: false,
isWritable: true,
},
{
pubkey: payer,
isSigner: true,
isWritable: true,
},
{
pubkey: anchor_1.web3.SystemProgram.programId,
isSigner: false,
isWritable: false,
},
{
pubkey: paymentPubkey1,
isSigner: false,
isWritable: true,
},
{
pubkey: paymentPubkey2,
isSigner: false,
isWritable: true,
},
]).instruction();
return { claimIx };
});
exports.claimCardinalIx = claimCardinalIx;