UNPKG

@pump-fun/pump-swap-sdk

Version:

Official SDK for interacting with Pump Swap AMM protocol on Solana

127 lines (121 loc) 5.42 kB
"use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/sdk/buy.ts var buy_exports = {}; __export(buy_exports, { buyBaseInputInternal: () => buyBaseInputInternal, buyQuoteInputInternal: () => buyQuoteInputInternal }); module.exports = __toCommonJS(buy_exports); var import_bn3 = __toESM(require("bn.js")); // src/sdk/util.ts var import_bn2 = __toESM(require("bn.js")); var import_anchor = require("@coral-xyz/anchor"); // src/sdk/pda.ts var import_web3 = require("@solana/web3.js"); var import_bn = __toESM(require("bn.js")); var import_spl_token = require("@solana/spl-token"); var PUMP_AMM_PROGRAM_ID = "pAMMBay6oceH9fJKBRHGP5D4bD4sWpmSwMn52FMfXEA"; var PUMP_AMM_PROGRAM_ID_PUBKEY = new import_web3.PublicKey(PUMP_AMM_PROGRAM_ID); var PUMP_PROGRAM_ID = "6EF8rrecthR5Dkzon8Nwu78hRvfCKubJ14M5uBEwF6P"; var PUMP_PROGRAM_ID_PUBKEY = new import_web3.PublicKey(PUMP_PROGRAM_ID); var PUMP_MINT = new import_web3.PublicKey( "pumpCmXqMfrsAkQ5r49WcJnRayYRqmXz6ae8H7H9Dfn" ); // src/sdk/util.ts function ceilDiv(a, b) { if (b.isZero()) { throw new Error("Cannot divide by zero."); } return a.add(b.subn(1)).div(b); } function fee(amount, basisPoints) { return ceilDiv(amount.mul(basisPoints), new import_bn2.default(1e4)); } // src/sdk/buy.ts var import_web32 = require("@solana/web3.js"); function buyBaseInputInternal(base, slippage, baseReserve, quoteReserve, globalConfig, coinCreator) { if (baseReserve.isZero() || quoteReserve.isZero()) { throw new Error( "Invalid input: 'baseReserve' or 'quoteReserve' cannot be zero." ); } if (base.gt(baseReserve)) { throw new Error("Cannot buy more base tokens than the pool reserves."); } const numerator = quoteReserve.mul(base); const denominator = baseReserve.sub(base); if (denominator.isZero()) { throw new Error("Pool would be depleted; denominator is zero."); } const quoteAmountIn = ceilDiv(numerator, denominator); const lpFee = fee(quoteAmountIn, globalConfig.lpFeeBasisPoints); const protocolFee = fee(quoteAmountIn, globalConfig.protocolFeeBasisPoints); const coinCreatorFee = import_web32.PublicKey.default.equals(coinCreator) ? new import_bn3.default(0) : fee(quoteAmountIn, globalConfig.coinCreatorFeeBasisPoints); const totalQuote = quoteAmountIn.add(lpFee).add(protocolFee).add(coinCreatorFee); const precision = new import_bn3.default(1e9); const slippageFactorFloat = (1 + slippage / 100) * 1e9; const slippageFactor = new import_bn3.default(Math.floor(slippageFactorFloat)); const maxQuote = totalQuote.mul(slippageFactor).div(precision); return { internalQuoteAmount: quoteAmountIn, uiQuote: totalQuote, // Final total quote after fees maxQuote }; } function buyQuoteInputInternal(quote, slippage, baseReserve, quoteReserve, globalConfig, coinCreator) { if (baseReserve.isZero() || quoteReserve.isZero()) { throw new Error( "Invalid input: 'baseReserve' or 'quoteReserve' cannot be zero." ); } const totalFeeBps = globalConfig.lpFeeBasisPoints.add(globalConfig.protocolFeeBasisPoints).add( import_web32.PublicKey.default.equals(coinCreator) ? new import_bn3.default(0) : globalConfig.coinCreatorFeeBasisPoints ); const denominator = new import_bn3.default(1e4).add(totalFeeBps); const effectiveQuote = quote.mul(new import_bn3.default(1e4)).div(denominator); const numerator = baseReserve.mul(effectiveQuote); const denominatorEffective = quoteReserve.add(effectiveQuote); if (denominatorEffective.isZero()) { throw new Error("Pool would be depleted; denominator is zero."); } const baseAmountOut = numerator.div(denominatorEffective); const precision = new import_bn3.default(1e9); const slippageFactorFloat = (1 + slippage / 100) * 1e9; const slippageFactor = new import_bn3.default(Math.floor(slippageFactorFloat)); const maxQuote = quote.mul(slippageFactor).div(precision); return { base: baseAmountOut, // Base tokens received after fees internalQuoteWithoutFees: effectiveQuote, maxQuote // Maximum quote tokens to pay (with slippage) }; }