diff --git a/src/adapters/fetcher/utils.ts b/src/adapters/fetcher/utils.ts index d32b6eb38..57e547677 100644 --- a/src/adapters/fetcher/utils.ts +++ b/src/adapters/fetcher/utils.ts @@ -32,7 +32,10 @@ export function makeLog({ export function attachAuthorization(url: string, options: any) { // only attach token for mochi-pay's request atm - if (url.startsWith(MOCHI_PAY_API_BASE_URL)) { + if ( + url.startsWith(MOCHI_PAY_API_BASE_URL) && + !options.headers["Authorization"] + ) { options.headers = { ...options.headers, Authorization: `Basic ${MOCHI_API_KEY}`, diff --git a/src/adapters/mochi-pay.ts b/src/adapters/mochi-pay.ts index cd88d1e1d..db062e5da 100644 --- a/src/adapters/mochi-pay.ts +++ b/src/adapters/mochi-pay.ts @@ -5,6 +5,7 @@ import { import { Fetcher } from "./fetcher" import fetch from "node-fetch" import { getKrystalEarnPortfolioResponse } from "types/mochipay" +import { MOCHI_BOT_SECRET } from "env" type KrystalStakeRequest = { chain_id: number @@ -403,6 +404,22 @@ class MochiPay extends Fetcher { } return data } + + async claimTradingVault({ + profileId, + vaultId, + }: { + profileId: string + vaultId: string + }): Promise { + return await this.jsonFetch( + `${MOCHI_PAY_API_BASE_URL}/profiles/${profileId}/syndicates/earning-vaults/${vaultId}/claim`, + { + method: "POST", + headers: { Authorization: `Bearer ${MOCHI_BOT_SECRET}` }, + }, + ) + } } export default new MochiPay() diff --git a/src/commands/vault/info/processor.ts b/src/commands/vault/info/processor.ts index ef16928e7..37df7e6be 100644 --- a/src/commands/vault/info/processor.ts +++ b/src/commands/vault/info/processor.ts @@ -338,10 +338,10 @@ export async function runGetVaultDetail({ value: Number(share), fractionDigits: 4, })}`, - `${getEmoji("GIFT")} \`Floating profit. \` ${utils.formatUsdPriceDigit({ - value: Number(report.vault_equity.floating_profit ?? 0), - shorten: false, - })}`, + // `${getEmoji("GIFT")} \`Floating profit. \` ${utils.formatUsdPriceDigit({ + // value: Number(report.vault_equity.floating_profit ?? 0), + // shorten: false, + // })}`, `:tada: \`Claimable amount. \` ${claiambleInfo}`, ].join("\n") @@ -437,6 +437,8 @@ export async function runGetVaultDetail({ }, vaultId: selectedVault, report, + profileId, + vaultName: data.name, }, msgOpts: { embeds: [embed], @@ -448,7 +450,7 @@ export async function runGetVaultDetail({ .setStyle("SECONDARY") .setCustomId("claim") .setEmoji("<:FeelsGood:1177549805048836126>") - .setDisabled(Number(report.vault_equity.claimable ?? 0) > 0), + .setDisabled(Number(report.member_equity?.claimable ?? 0) <= 0), new MessageButton() .setLabel("Report") .setEmoji(getEmoji("CHART")) @@ -803,3 +805,36 @@ function formatDateTime(s: string | undefined, timeOnly?: boolean) { .toLocaleTimeString("en-US", { hour12: true, hour: "numeric" }) .replace(" ", "")}` } + +export async function vaultClaim({ + interaction, + vaultId, + profileId, + vaultName, +}: { + interaction: ButtonInteraction + vaultId: string + profileId: string + vaultName: string +}) { + const { ok } = await mochiPay.claimTradingVault({ profileId, vaultId }) + if (!ok) { + throw new InternalError({ + msgOrInteraction: interaction, + title: "Failed to claim", + }) + } + + const embed = composeEmbedMessage2(interaction as any, { + title: vaultName, + description: "You have claimed successfully", + }) + + return { + msgOpts: { + embeds: [embed], + components: [], + attachments: [], + }, + } +} diff --git a/src/commands/vault/info/slash.ts b/src/commands/vault/info/slash.ts index ce650a203..4984fbc8d 100644 --- a/src/commands/vault/info/slash.ts +++ b/src/commands/vault/info/slash.ts @@ -13,7 +13,12 @@ import { MachineConfig, route, RouterSpecialAction } from "utils/router" import { SlashCommandSubcommandBuilder } from "@discordjs/builders" -import { handleVaultRounds, runGetVaultDetail, vaultReport } from "./processor" +import { + handleVaultRounds, + runGetVaultDetail, + vaultClaim, + vaultReport, +} from "./processor" import profile from "adapters/profile" import mochiPay from "adapters/mochi-pay" import { runVaultList } from "commands/vault/list/processor" @@ -44,6 +49,15 @@ export const machineConfig: ( return handleVaultRounds(vaultId, i) }, vaultList: (i) => runVaultList(i), + vaultClaim: (i, _ev, ctx) => { + const { vaultId, profileId, vaultName } = ctx + return vaultClaim({ + vaultName, + interaction: i, + vaultId, + profileId, + }) + }, }, select: { vaultInfo: async (i, _ev, ctx) => { @@ -86,6 +100,7 @@ export const machineConfig: ( [RouterSpecialAction.BACK]: "vaultInfo", }, }, + vaultClaim: {}, vaultInfo: { on: { BACK: [ @@ -93,6 +108,7 @@ export const machineConfig: ( ], ROUNDS: "vaultRounds", REPORT: "vaultReport", + CLAIM: "vaultClaim", DEPOSIT: { target: "vaultInfo", actions: {