perena-vault-sdk 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +396 -0
- package/dist/client/account.d.ts +59 -0
- package/dist/client/account.d.ts.map +1 -0
- package/dist/client/account.js +94 -0
- package/dist/client/account.js.map +1 -0
- package/dist/client/builders/activateCircuitBreaker.d.ts +12 -0
- package/dist/client/builders/activateCircuitBreaker.d.ts.map +1 -0
- package/dist/client/builders/activateCircuitBreaker.js +27 -0
- package/dist/client/builders/activateCircuitBreaker.js.map +1 -0
- package/dist/client/builders/anchorArgs.d.ts +59 -0
- package/dist/client/builders/anchorArgs.d.ts.map +1 -0
- package/dist/client/builders/anchorArgs.js +43 -0
- package/dist/client/builders/anchorArgs.js.map +1 -0
- package/dist/client/builders/args.d.ts +754 -0
- package/dist/client/builders/args.d.ts.map +1 -0
- package/dist/client/builders/args.js +3 -0
- package/dist/client/builders/args.js.map +1 -0
- package/dist/client/builders/base.d.ts +10 -0
- package/dist/client/builders/base.d.ts.map +1 -0
- package/dist/client/builders/base.js +20 -0
- package/dist/client/builders/base.js.map +1 -0
- package/dist/client/builders/cancelJuniorTrancheWithdraw.d.ts +13 -0
- package/dist/client/builders/cancelJuniorTrancheWithdraw.d.ts.map +1 -0
- package/dist/client/builders/cancelJuniorTrancheWithdraw.js +57 -0
- package/dist/client/builders/cancelJuniorTrancheWithdraw.js.map +1 -0
- package/dist/client/builders/crankNav.d.ts +29 -0
- package/dist/client/builders/crankNav.d.ts.map +1 -0
- package/dist/client/builders/crankNav.js +88 -0
- package/dist/client/builders/crankNav.js.map +1 -0
- package/dist/client/builders/crankPerformanceFees.d.ts +19 -0
- package/dist/client/builders/crankPerformanceFees.d.ts.map +1 -0
- package/dist/client/builders/crankPerformanceFees.js +80 -0
- package/dist/client/builders/crankPerformanceFees.js.map +1 -0
- package/dist/client/builders/createAssetHolding.d.ts +13 -0
- package/dist/client/builders/createAssetHolding.d.ts.map +1 -0
- package/dist/client/builders/createAssetHolding.js +47 -0
- package/dist/client/builders/createAssetHolding.js.map +1 -0
- package/dist/client/builders/createTrancheState.d.ts +13 -0
- package/dist/client/builders/createTrancheState.d.ts.map +1 -0
- package/dist/client/builders/createTrancheState.js +57 -0
- package/dist/client/builders/createTrancheState.js.map +1 -0
- package/dist/client/builders/createVault.d.ts +9 -0
- package/dist/client/builders/createVault.d.ts.map +1 -0
- package/dist/client/builders/createVault.js +75 -0
- package/dist/client/builders/createVault.js.map +1 -0
- package/dist/client/builders/disableCircuitBreaker.d.ts +12 -0
- package/dist/client/builders/disableCircuitBreaker.d.ts.map +1 -0
- package/dist/client/builders/disableCircuitBreaker.js +27 -0
- package/dist/client/builders/disableCircuitBreaker.js.map +1 -0
- package/dist/client/builders/executeDeposit.d.ts +15 -0
- package/dist/client/builders/executeDeposit.d.ts.map +1 -0
- package/dist/client/builders/executeDeposit.js +86 -0
- package/dist/client/builders/executeDeposit.js.map +1 -0
- package/dist/client/builders/executeTrancheDeposit.d.ts +16 -0
- package/dist/client/builders/executeTrancheDeposit.d.ts.map +1 -0
- package/dist/client/builders/executeTrancheDeposit.js +84 -0
- package/dist/client/builders/executeTrancheDeposit.js.map +1 -0
- package/dist/client/builders/executeTrancheWithdraw.d.ts +16 -0
- package/dist/client/builders/executeTrancheWithdraw.d.ts.map +1 -0
- package/dist/client/builders/executeTrancheWithdraw.js +83 -0
- package/dist/client/builders/executeTrancheWithdraw.js.map +1 -0
- package/dist/client/builders/executeWithdraw.d.ts +14 -0
- package/dist/client/builders/executeWithdraw.d.ts.map +1 -0
- package/dist/client/builders/executeWithdraw.js +86 -0
- package/dist/client/builders/executeWithdraw.js.map +1 -0
- package/dist/client/builders/feeCollector.d.ts +17 -0
- package/dist/client/builders/feeCollector.d.ts.map +1 -0
- package/dist/client/builders/feeCollector.js +66 -0
- package/dist/client/builders/feeCollector.js.map +1 -0
- package/dist/client/builders/fulfillJuniorTrancheWithdraw.d.ts +14 -0
- package/dist/client/builders/fulfillJuniorTrancheWithdraw.d.ts.map +1 -0
- package/dist/client/builders/fulfillJuniorTrancheWithdraw.js +82 -0
- package/dist/client/builders/fulfillJuniorTrancheWithdraw.js.map +1 -0
- package/dist/client/builders/index.d.ts +31 -0
- package/dist/client/builders/index.d.ts.map +1 -0
- package/dist/client/builders/index.js +47 -0
- package/dist/client/builders/index.js.map +1 -0
- package/dist/client/builders/initializeVaultRoles.d.ts +12 -0
- package/dist/client/builders/initializeVaultRoles.d.ts.map +1 -0
- package/dist/client/builders/initializeVaultRoles.js +37 -0
- package/dist/client/builders/initializeVaultRoles.js.map +1 -0
- package/dist/client/builders/managerRedepositAsset.d.ts +12 -0
- package/dist/client/builders/managerRedepositAsset.d.ts.map +1 -0
- package/dist/client/builders/managerRedepositAsset.js +52 -0
- package/dist/client/builders/managerRedepositAsset.js.map +1 -0
- package/dist/client/builders/managerWithdrawAsset.d.ts +12 -0
- package/dist/client/builders/managerWithdrawAsset.d.ts.map +1 -0
- package/dist/client/builders/managerWithdrawAsset.js +47 -0
- package/dist/client/builders/managerWithdrawAsset.js.map +1 -0
- package/dist/client/builders/protocolInteraction.d.ts +22 -0
- package/dist/client/builders/protocolInteraction.d.ts.map +1 -0
- package/dist/client/builders/protocolInteraction.js +157 -0
- package/dist/client/builders/protocolInteraction.js.map +1 -0
- package/dist/client/builders/removeAssetHolding.d.ts +13 -0
- package/dist/client/builders/removeAssetHolding.d.ts.map +1 -0
- package/dist/client/builders/removeAssetHolding.js +37 -0
- package/dist/client/builders/removeAssetHolding.js.map +1 -0
- package/dist/client/builders/requestJuniorTrancheWithdraw.d.ts +14 -0
- package/dist/client/builders/requestJuniorTrancheWithdraw.d.ts.map +1 -0
- package/dist/client/builders/requestJuniorTrancheWithdraw.js +72 -0
- package/dist/client/builders/requestJuniorTrancheWithdraw.js.map +1 -0
- package/dist/client/builders/setAssetPriceOracle.d.ts +12 -0
- package/dist/client/builders/setAssetPriceOracle.d.ts.map +1 -0
- package/dist/client/builders/setAssetPriceOracle.js +40 -0
- package/dist/client/builders/setAssetPriceOracle.js.map +1 -0
- package/dist/client/builders/setExternalLiquidity.d.ts +12 -0
- package/dist/client/builders/setExternalLiquidity.d.ts.map +1 -0
- package/dist/client/builders/setExternalLiquidity.js +49 -0
- package/dist/client/builders/setExternalLiquidity.js.map +1 -0
- package/dist/client/builders/setProtocolFee.d.ts +12 -0
- package/dist/client/builders/setProtocolFee.d.ts.map +1 -0
- package/dist/client/builders/setProtocolFee.js +37 -0
- package/dist/client/builders/setProtocolFee.js.map +1 -0
- package/dist/client/builders/setVaultConfig.d.ts +12 -0
- package/dist/client/builders/setVaultConfig.d.ts.map +1 -0
- package/dist/client/builders/setVaultConfig.js +54 -0
- package/dist/client/builders/setVaultConfig.js.map +1 -0
- package/dist/client/builders/trancheState.d.ts +28 -0
- package/dist/client/builders/trancheState.d.ts.map +1 -0
- package/dist/client/builders/trancheState.js +75 -0
- package/dist/client/builders/trancheState.js.map +1 -0
- package/dist/client/builders/updateAssetPrice.d.ts +18 -0
- package/dist/client/builders/updateAssetPrice.d.ts.map +1 -0
- package/dist/client/builders/updateAssetPrice.js +50 -0
- package/dist/client/builders/updateAssetPrice.js.map +1 -0
- package/dist/client/builders/updateConsensusOracle.d.ts +20 -0
- package/dist/client/builders/updateConsensusOracle.d.ts.map +1 -0
- package/dist/client/builders/updateConsensusOracle.js +64 -0
- package/dist/client/builders/updateConsensusOracle.js.map +1 -0
- package/dist/client/builders/updateConsensusSigners.d.ts +13 -0
- package/dist/client/builders/updateConsensusSigners.d.ts.map +1 -0
- package/dist/client/builders/updateConsensusSigners.js +38 -0
- package/dist/client/builders/updateConsensusSigners.js.map +1 -0
- package/dist/client/builders/updateTrancheConfig.d.ts +13 -0
- package/dist/client/builders/updateTrancheConfig.d.ts.map +1 -0
- package/dist/client/builders/updateTrancheConfig.js +50 -0
- package/dist/client/builders/updateTrancheConfig.js.map +1 -0
- package/dist/client/builders/vaultReallocation.d.ts +15 -0
- package/dist/client/builders/vaultReallocation.d.ts.map +1 -0
- package/dist/client/builders/vaultReallocation.js +148 -0
- package/dist/client/builders/vaultReallocation.js.map +1 -0
- package/dist/client/client.d.ts +34 -0
- package/dist/client/client.d.ts.map +1 -0
- package/dist/client/client.js +75 -0
- package/dist/client/client.js.map +1 -0
- package/dist/client/index.d.ts +8 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +24 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/pda.d.ts +42 -0
- package/dist/client/pda.d.ts.map +1 -0
- package/dist/client/pda.js +88 -0
- package/dist/client/pda.js.map +1 -0
- package/dist/client/transaction.d.ts +36 -0
- package/dist/client/transaction.d.ts.map +1 -0
- package/dist/client/transaction.js +39 -0
- package/dist/client/transaction.js.map +1 -0
- package/dist/client/types/builders.d.ts +12 -0
- package/dist/client/types/builders.d.ts.map +1 -0
- package/dist/client/types/builders.js +3 -0
- package/dist/client/types/builders.js.map +1 -0
- package/dist/client/types/tx.d.ts +13 -0
- package/dist/client/types/tx.d.ts.map +1 -0
- package/dist/client/types/tx.js +3 -0
- package/dist/client/types/tx.js.map +1 -0
- package/dist/constants.d.ts +45 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +49 -0
- package/dist/constants.js.map +1 -0
- package/dist/env.d.ts +70 -0
- package/dist/env.d.ts.map +1 -0
- package/dist/env.js +117 -0
- package/dist/env.js.map +1 -0
- package/dist/idl/index.d.ts +3 -0
- package/dist/idl/index.d.ts.map +1 -0
- package/dist/idl/index.js +6 -0
- package/dist/idl/index.js.map +1 -0
- package/dist/idl/vault.d.ts +9617 -0
- package/dist/idl/vault.d.ts.map +1 -0
- package/dist/idl/vault.js +7917 -0
- package/dist/idl/vault.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +23 -0
- package/dist/index.js.map +1 -0
- package/dist/services/consensusOracle/consensusOracleService.d.ts +38 -0
- package/dist/services/consensusOracle/consensusOracleService.d.ts.map +1 -0
- package/dist/services/consensusOracle/consensusOracleService.js +270 -0
- package/dist/services/consensusOracle/consensusOracleService.js.map +1 -0
- package/dist/services/consensusOracle/externalPositions.d.ts +26 -0
- package/dist/services/consensusOracle/externalPositions.d.ts.map +1 -0
- package/dist/services/consensusOracle/externalPositions.js +37 -0
- package/dist/services/consensusOracle/externalPositions.js.map +1 -0
- package/dist/services/consensusOracle/index.d.ts +7 -0
- package/dist/services/consensusOracle/index.d.ts.map +1 -0
- package/dist/services/consensusOracle/index.js +23 -0
- package/dist/services/consensusOracle/index.js.map +1 -0
- package/dist/services/consensusOracle/jupiterBalanceSource.d.ts +34 -0
- package/dist/services/consensusOracle/jupiterBalanceSource.d.ts.map +1 -0
- package/dist/services/consensusOracle/jupiterBalanceSource.js +80 -0
- package/dist/services/consensusOracle/jupiterBalanceSource.js.map +1 -0
- package/dist/services/consensusOracle/jupiterPriceSource.d.ts +25 -0
- package/dist/services/consensusOracle/jupiterPriceSource.d.ts.map +1 -0
- package/dist/services/consensusOracle/jupiterPriceSource.js +63 -0
- package/dist/services/consensusOracle/jupiterPriceSource.js.map +1 -0
- package/dist/services/consensusOracle/mockYieldTracker.d.ts +44 -0
- package/dist/services/consensusOracle/mockYieldTracker.d.ts.map +1 -0
- package/dist/services/consensusOracle/mockYieldTracker.js +107 -0
- package/dist/services/consensusOracle/mockYieldTracker.js.map +1 -0
- package/dist/services/consensusOracle/types.d.ts +180 -0
- package/dist/services/consensusOracle/types.d.ts.map +1 -0
- package/dist/services/consensusOracle/types.js +5 -0
- package/dist/services/consensusOracle/types.js.map +1 -0
- package/dist/services/index.d.ts +4 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +20 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/oracleService.d.ts +72 -0
- package/dist/services/oracleService.d.ts.map +1 -0
- package/dist/services/oracleService.js +93 -0
- package/dist/services/oracleService.js.map +1 -0
- package/dist/services/withdrawalQueueService.d.ts +76 -0
- package/dist/services/withdrawalQueueService.d.ts.map +1 -0
- package/dist/services/withdrawalQueueService.js +138 -0
- package/dist/services/withdrawalQueueService.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +20 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/provider.d.ts +4 -0
- package/dist/utils/provider.d.ts.map +1 -0
- package/dist/utils/provider.js +10 -0
- package/dist/utils/provider.js.map +1 -0
- package/dist/utils/rpc.d.ts +4 -0
- package/dist/utils/rpc.d.ts.map +1 -0
- package/dist/utils/rpc.js +8 -0
- package/dist/utils/rpc.js.map +1 -0
- package/dist/utils/token.d.ts +6 -0
- package/dist/utils/token.d.ts.map +1 -0
- package/dist/utils/token.js +32 -0
- package/dist/utils/token.js.map +1 -0
- package/package.json +50 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withdrawalQueueService.d.ts","sourceRoot":"","sources":["../../src/services/withdrawalQueueService.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAEH,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG1C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEpD,qEAAqE;AACrE,MAAM,WAAW,uBAAuB;IACtC,GAAG,EAAE,OAAO,CAAC;IACb,KAAK,EAAE,OAAO,CAAC;IACf,KAAK,EAAE,OAAO,CAAC;IACf,oEAAoE;IACpE,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,mDAAmD;IACnD,SAAS,EAAE,OAAO,CAAC;IACnB,mDAAmD;IACnD,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,mEAAmE;IACnE,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB;AAED,KAAK,KAAK,GAAG,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;AAUnC,qBAAa,sBAAsB;IACrB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,WAAW;IAEhD,wDAAwD;IACxD,OAAO,CAAC,GAAG;IAMX,gEAAgE;IAC1D,cAAc,IAAI,OAAO,CAAC,uBAAuB,EAAE,CAAC;IAa1D,4CAA4C;IACtC,mBAAmB,CACvB,KAAK,EAAE,OAAO,GACb,OAAO,CAAC,uBAAuB,EAAE,CAAC;IAKrC,kEAAkE;IAC5D,UAAU,CACd,KAAK,EAAE,OAAO,EACd,KAAK,EAAE,OAAO,EACd,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,uBAAuB,CAAC;IAenC,wEAAwE;IACxE,KAAK,CAAC,KAAK,EAAE,uBAAuB,EAAE,GAAG,GAAE,MAAmB,GAAG,OAAO;IAIxE,sEAAsE;IACtE,eAAe,CACb,KAAK,EAAE,uBAAuB,EAC9B,GAAG,GAAE,MAAmB,GACvB,MAAM;IAIT,YAAY,CACV,MAAM,EAAE,uBAAuB,EAAE,EACjC,GAAG,GAAE,MAAmB,GACvB,uBAAuB,EAAE;IAM5B;;;OAGG;IACG,OAAO,CACX,MAAM,EAAE,OAAO,EACf,KAAK,EAAE,uBAAuB,GAC7B,OAAO,CAAC,MAAM,CAAC;IAclB;;;OAGG;IACG,aAAa,CACjB,MAAM,EAAE,OAAO,EACf,IAAI,GAAE;QAAE,KAAK,CAAC,EAAE,OAAO,CAAC;QAAC,GAAG,CAAC,EAAE,KAAK,CAAA;KAAO,GAC1C,OAAO,CAAC,cAAc,CAAC;IA2C1B,OAAO,CAAC,UAAU;CAwBnB"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Junior-tranche withdrawal-queue fulfillment.
|
|
4
|
+
*
|
|
5
|
+
* Backend/cron logic — kept out of scripts so the fulfiller daemon, a Lambda,
|
|
6
|
+
* and the `fulfill-junior-withdraw` CLI can all share one implementation.
|
|
7
|
+
*
|
|
8
|
+
* A request is recorded on-chain as a `VaultWithdrawalQueue` PDA that escrows
|
|
9
|
+
* junior shares (`input_mint`) and pays out the vault asset (`output_mint`)
|
|
10
|
+
* once its lockup elapses. The program permits fulfillment when
|
|
11
|
+
* `now >= request.expiry_ts` (where `expiry_ts = request_ts + lockup`), so this
|
|
12
|
+
* service discovers queues, filters the ones whose lockup has elapsed, and
|
|
13
|
+
* submits `fulfill_junior_tranche_withdraw` for each.
|
|
14
|
+
*
|
|
15
|
+
* The queue account itself carries both mints, so fulfillment needs no extra
|
|
16
|
+
* lookups — no dependency on the (separately-maintained) tranche-state IDL.
|
|
17
|
+
*/
|
|
18
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
+
exports.WithdrawalQueueService = void 0;
|
|
20
|
+
const common_1 = require("common");
|
|
21
|
+
function bnToBigInt(value) {
|
|
22
|
+
return BigInt(value.toString());
|
|
23
|
+
}
|
|
24
|
+
function bnToNumber(value) {
|
|
25
|
+
return Number(value.toString());
|
|
26
|
+
}
|
|
27
|
+
class WithdrawalQueueService {
|
|
28
|
+
constructor(client) {
|
|
29
|
+
this.client = client;
|
|
30
|
+
}
|
|
31
|
+
/** Current unix time in seconds (override in tests). */
|
|
32
|
+
now() {
|
|
33
|
+
return Math.floor(Date.now() / 1000);
|
|
34
|
+
}
|
|
35
|
+
// ── Discovery ───────────────────────────────────────────────────────────
|
|
36
|
+
/** All withdrawal-queue accounts owned by the vault program. */
|
|
37
|
+
async fetchAllQueues() {
|
|
38
|
+
// `vaultWithdrawalQueue` is decoded from the IDL; cast keeps this resilient
|
|
39
|
+
// while the generated IDL surface is still being regenerated.
|
|
40
|
+
const program = this.client.program.account;
|
|
41
|
+
const accounts = await program.vaultWithdrawalQueue.all();
|
|
42
|
+
return accounts.map((entry) => this.toSnapshot((0, common_1.fromWeb3Pk)(entry.publicKey), entry.account));
|
|
43
|
+
}
|
|
44
|
+
/** Withdrawal queues for a single vault. */
|
|
45
|
+
async fetchQueuesForVault(vault) {
|
|
46
|
+
const all = await this.fetchAllQueues();
|
|
47
|
+
return all.filter((q) => q.vault === vault);
|
|
48
|
+
}
|
|
49
|
+
/** Fetch a single queue snapshot by owner/queueId for a vault. */
|
|
50
|
+
async fetchQueue(vault, owner, queueId) {
|
|
51
|
+
const [pda] = await this.client.pda.deriveVaultTrancheWithdrawalQueuePda(vault, owner, queueId);
|
|
52
|
+
const data = await this.client.account.fetchVaultTrancheWithdrawalQueue(pda, { fresh: true });
|
|
53
|
+
return this.toSnapshot(pda, data);
|
|
54
|
+
}
|
|
55
|
+
// ── Readiness ───────────────────────────────────────────────────────────
|
|
56
|
+
/** True once the queue's lockup has elapsed and it can be fulfilled. */
|
|
57
|
+
isDue(queue, now = this.now()) {
|
|
58
|
+
return now >= queue.expiryTs;
|
|
59
|
+
}
|
|
60
|
+
/** Seconds until the queue becomes fulfillable (0 if already due). */
|
|
61
|
+
secondsUntilDue(queue, now = this.now()) {
|
|
62
|
+
return Math.max(0, queue.expiryTs - now);
|
|
63
|
+
}
|
|
64
|
+
getDueQueues(queues, now = this.now()) {
|
|
65
|
+
return queues.filter((q) => this.isDue(q, now));
|
|
66
|
+
}
|
|
67
|
+
// ── Fulfillment ─────────────────────────────────────────────────────────
|
|
68
|
+
/**
|
|
69
|
+
* Fulfill a single queued junior withdrawal. `signer` pays fees and, if
|
|
70
|
+
* needed, initializes the owner's output ATA.
|
|
71
|
+
*/
|
|
72
|
+
async fulfill(signer, queue) {
|
|
73
|
+
const plan = await this.client.tx.fulfillJuniorTrancheWithdraw.getTx({
|
|
74
|
+
owner: queue.owner,
|
|
75
|
+
signer: (0, common_1.fromWeb3Pk)(signer.publicKey),
|
|
76
|
+
queuePayer: queue.payer,
|
|
77
|
+
vault: queue.vault,
|
|
78
|
+
withdrawalQueue: queue.pda,
|
|
79
|
+
assetMint: queue.outputMint,
|
|
80
|
+
juniorShareMint: queue.inputMint,
|
|
81
|
+
queueId: queue.queueId,
|
|
82
|
+
});
|
|
83
|
+
return this.client.sendTransaction(signer, plan);
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Fulfill every due queue, optionally scoped to a single vault. Non-fatal:
|
|
87
|
+
* a failure on one queue is logged and the rest still run.
|
|
88
|
+
*/
|
|
89
|
+
async fulfillAllDue(signer, opts = {}) {
|
|
90
|
+
const { vault, log } = opts;
|
|
91
|
+
const queues = vault
|
|
92
|
+
? await this.fetchQueuesForVault(vault)
|
|
93
|
+
: await this.fetchAllQueues();
|
|
94
|
+
const summary = {
|
|
95
|
+
fulfilled: 0,
|
|
96
|
+
skippedNotDue: 0,
|
|
97
|
+
failed: 0,
|
|
98
|
+
signatures: [],
|
|
99
|
+
};
|
|
100
|
+
const now = this.now();
|
|
101
|
+
for (const queue of queues) {
|
|
102
|
+
if (!this.isDue(queue, now)) {
|
|
103
|
+
summary.skippedNotDue += 1;
|
|
104
|
+
log?.(`skip ${queue.pda} (owner ${queue.owner}) — due in ${this.secondsUntilDue(queue, now)}s`);
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
try {
|
|
108
|
+
const sig = await this.fulfill(signer, queue);
|
|
109
|
+
summary.fulfilled += 1;
|
|
110
|
+
summary.signatures.push(sig);
|
|
111
|
+
log?.(`fulfilled ${queue.pda} (owner ${queue.owner}): ${sig}`);
|
|
112
|
+
}
|
|
113
|
+
catch (err) {
|
|
114
|
+
summary.failed += 1;
|
|
115
|
+
log?.(`FAILED ${queue.pda} (owner ${queue.owner}): ${err instanceof Error ? err.message : String(err)}`);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return summary;
|
|
119
|
+
}
|
|
120
|
+
// ── Internals ─────────────────────────────────────────────────────────
|
|
121
|
+
toSnapshot(pda, account) {
|
|
122
|
+
const a = account;
|
|
123
|
+
return {
|
|
124
|
+
pda,
|
|
125
|
+
vault: (0, common_1.fromWeb3Pk)(a.parties.vault),
|
|
126
|
+
owner: (0, common_1.fromWeb3Pk)(a.parties.owner),
|
|
127
|
+
payer: (0, common_1.fromWeb3Pk)(a.parties.payer),
|
|
128
|
+
queueId: a.header.queueId,
|
|
129
|
+
inputMint: (0, common_1.fromWeb3Pk)(a.mints.inputMint),
|
|
130
|
+
outputMint: (0, common_1.fromWeb3Pk)(a.mints.outputMint),
|
|
131
|
+
inputAmount: bnToBigInt(a.request.inputAmount),
|
|
132
|
+
requestTs: bnToNumber(a.request.requestTs),
|
|
133
|
+
expiryTs: bnToNumber(a.request.expiryTs),
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
exports.WithdrawalQueueService = WithdrawalQueueService;
|
|
138
|
+
//# sourceMappingURL=withdrawalQueueService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"withdrawalQueueService.js","sourceRoot":"","sources":["../../src/services/withdrawalQueueService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./provider"), exports);
|
|
18
|
+
__exportStar(require("./rpc"), exports);
|
|
19
|
+
__exportStar(require("./token"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,wCAAsB;AACtB,0CAAwB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/utils/provider.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAU,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAEtD,wBAAgB,YAAY,CAC1B,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,OAAO,GACb,cAAc,CAIhB"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeProvider = makeProvider;
|
|
4
|
+
const core_1 = require("@anchor-lang/core");
|
|
5
|
+
function makeProvider(connection, payer) {
|
|
6
|
+
return new core_1.AnchorProvider(connection, new core_1.Wallet(payer), {
|
|
7
|
+
commitment: "confirmed",
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider.js","sourceRoot":"","sources":["../../src/utils/provider.ts"],"names":[],"mappings":";;AAGA,oCAOC;AAVD,4CAA2D;AAG3D,SAAgB,YAAY,CAC1B,UAAsB,EACtB,KAAc;IAEd,OAAO,IAAI,qBAAc,CAAC,UAAU,EAAE,IAAI,aAAM,CAAC,KAAK,CAAC,EAAE;QACvD,UAAU,EAAE,WAAW;KACxB,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc.d.ts","sourceRoot":"","sources":["../../src/utils/rpc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAmB,KAAK,GAAG,EAAE,KAAK,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAElD,wBAAgB,uBAAuB,CACrC,UAAU,EAAE,UAAU,GACrB,GAAG,CAAC,YAAY,CAAC,CAEnB"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createRpcFromConnection = createRpcFromConnection;
|
|
4
|
+
const kit_1 = require("@solana/kit");
|
|
5
|
+
function createRpcFromConnection(connection) {
|
|
6
|
+
return (0, kit_1.createSolanaRpc)(connection.rpcEndpoint);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=rpc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rpc.js","sourceRoot":"","sources":["../../src/utils/rpc.ts"],"names":[],"mappings":";;AAGA,0DAIC;AAPD,qCAA2E;AAG3E,SAAgB,uBAAuB,CACrC,UAAsB;IAEtB,OAAO,IAAA,qBAAe,EAAC,UAAU,CAAC,WAAW,CAAC,CAAC;AACjD,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Connection, Keypair, PublicKey } from "@solana/web3.js";
|
|
2
|
+
import type { Address } from "@solana/kit";
|
|
3
|
+
/** Creates a fresh SPL Token-2022 mint with `payer` as mint authority. */
|
|
4
|
+
export declare function createTokenMint(connection: Connection, payer: Keypair, decimals: number, tokenProgram?: PublicKey): Promise<PublicKey>;
|
|
5
|
+
export declare function mintTokensTo(connection: Connection, payer: Keypair, mint: PublicKey, destination: PublicKey, amount: bigint, tokenProgram?: PublicKey | Address, allowOwnerOffCurve?: boolean): Promise<void>;
|
|
6
|
+
//# sourceMappingURL=token.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.d.ts","sourceRoot":"","sources":["../../src/utils/token.ts"],"names":[],"mappings":"AAUA,OAAO,EACL,UAAU,EACV,OAAO,EACP,SAAS,EAIV,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAG3C,0EAA0E;AAC1E,wBAAsB,eAAe,CACnC,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,OAAO,EACd,QAAQ,EAAE,MAAM,EAChB,YAAY,YAAwB,GACnC,OAAO,CAAC,SAAS,CAAC,CAqBpB;AAED,wBAAsB,YAAY,CAChC,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,OAAO,EACd,IAAI,EAAE,SAAS,EACf,WAAW,EAAE,SAAS,EACtB,MAAM,EAAE,MAAM,EACd,YAAY,GAAE,SAAS,GAAG,OAA+B,EACzD,kBAAkB,UAAQ,GACzB,OAAO,CAAC,IAAI,CAAC,CA4Bf"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createTokenMint = createTokenMint;
|
|
4
|
+
exports.mintTokensTo = mintTokensTo;
|
|
5
|
+
const spl_token_1 = require("@solana/spl-token");
|
|
6
|
+
const web3_js_1 = require("@solana/web3.js");
|
|
7
|
+
const common_1 = require("common");
|
|
8
|
+
/** Creates a fresh SPL Token-2022 mint with `payer` as mint authority. */
|
|
9
|
+
async function createTokenMint(connection, payer, decimals, tokenProgram = spl_token_1.TOKEN_2022_PROGRAM_ID) {
|
|
10
|
+
const mint = web3_js_1.Keypair.generate();
|
|
11
|
+
const lamports = await (0, spl_token_1.getMinimumBalanceForRentExemptMint)(connection);
|
|
12
|
+
const tx = new web3_js_1.Transaction().add(web3_js_1.SystemProgram.createAccount({
|
|
13
|
+
fromPubkey: payer.publicKey,
|
|
14
|
+
newAccountPubkey: mint.publicKey,
|
|
15
|
+
space: spl_token_1.MINT_SIZE,
|
|
16
|
+
lamports,
|
|
17
|
+
programId: tokenProgram,
|
|
18
|
+
}), (0, spl_token_1.createInitializeMint2Instruction)(mint.publicKey, decimals, payer.publicKey, null, tokenProgram));
|
|
19
|
+
await connection.sendTransaction(tx, [payer, mint], { skipPreflight: false });
|
|
20
|
+
return mint.publicKey;
|
|
21
|
+
}
|
|
22
|
+
async function mintTokensTo(connection, payer, mint, destination, amount, tokenProgram = spl_token_1.TOKEN_2022_PROGRAM_ID, allowOwnerOffCurve = false) {
|
|
23
|
+
const tokenProgramPk = (0, common_1.asWeb3PublicKey)(tokenProgram);
|
|
24
|
+
const ata = (0, spl_token_1.getAssociatedTokenAddressSync)(mint, destination, allowOwnerOffCurve, tokenProgramPk);
|
|
25
|
+
const ixs = [
|
|
26
|
+
(0, spl_token_1.createAssociatedTokenAccountIdempotentInstruction)(payer.publicKey, ata, destination, mint, tokenProgramPk, spl_token_1.ASSOCIATED_TOKEN_PROGRAM_ID),
|
|
27
|
+
(0, spl_token_1.createMintToInstruction)(mint, ata, payer.publicKey, Number(amount), [], tokenProgramPk),
|
|
28
|
+
];
|
|
29
|
+
const tx = new web3_js_1.Transaction().add(...ixs);
|
|
30
|
+
await connection.sendTransaction(tx, [payer]);
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=token.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"token.js","sourceRoot":"","sources":["../../src/utils/token.ts"],"names":[],"mappings":";;AAsBA,0CA0BC;AAED,oCAoCC;AAtFD,iDAS2B;AAC3B,6CAOyB;AAEzB,mCAAyC;AAEzC,0EAA0E;AACnE,KAAK,UAAU,eAAe,CACnC,UAAsB,EACtB,KAAc,EACd,QAAgB,EAChB,YAAY,GAAG,iCAAqB;IAEpC,MAAM,IAAI,GAAG,iBAAO,CAAC,QAAQ,EAAE,CAAC;IAChC,MAAM,QAAQ,GAAG,MAAM,IAAA,8CAAkC,EAAC,UAAU,CAAC,CAAC;IACtE,MAAM,EAAE,GAAG,IAAI,qBAAW,EAAE,CAAC,GAAG,CAC9B,uBAAa,CAAC,aAAa,CAAC;QAC1B,UAAU,EAAE,KAAK,CAAC,SAAS;QAC3B,gBAAgB,EAAE,IAAI,CAAC,SAAS;QAChC,KAAK,EAAE,qBAAS;QAChB,QAAQ;QACR,SAAS,EAAE,YAAY;KACxB,CAAC,EACF,IAAA,4CAAgC,EAC9B,IAAI,CAAC,SAAS,EACd,QAAQ,EACR,KAAK,CAAC,SAAS,EACf,IAAI,EACJ,YAAY,CACb,CACF,CAAC;IACF,MAAM,UAAU,CAAC,eAAe,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9E,OAAO,IAAI,CAAC,SAAS,CAAC;AACxB,CAAC;AAEM,KAAK,UAAU,YAAY,CAChC,UAAsB,EACtB,KAAc,EACd,IAAe,EACf,WAAsB,EACtB,MAAc,EACd,eAAoC,iCAAqB,EACzD,kBAAkB,GAAG,KAAK;IAE1B,MAAM,cAAc,GAAG,IAAA,wBAAe,EAAC,YAAY,CAAC,CAAC;IACrD,MAAM,GAAG,GAAG,IAAA,yCAA6B,EACvC,IAAI,EACJ,WAAW,EACX,kBAAkB,EAClB,cAAc,CACf,CAAC;IACF,MAAM,GAAG,GAA6B;QACpC,IAAA,6DAAiD,EAC/C,KAAK,CAAC,SAAS,EACf,GAAG,EACH,WAAW,EACX,IAAI,EACJ,cAAc,EACd,uCAA2B,CAC5B;QACD,IAAA,mCAAuB,EACrB,IAAI,EACJ,GAAG,EACH,KAAK,CAAC,SAAS,EACf,MAAM,CAAC,MAAM,CAAC,EACd,EAAE,EACF,cAAc,CACf;KACF,CAAC;IACF,MAAM,EAAE,GAAG,IAAI,qBAAW,EAAE,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;IACzC,MAAM,UAAU,CAAC,eAAe,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;AAChD,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "perena-vault-sdk",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"description": "Vault program helpers for Bankineco integrations.",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"files": [
|
|
8
|
+
"dist/**/*"
|
|
9
|
+
],
|
|
10
|
+
"scripts": {
|
|
11
|
+
"build": "rm -rf dist && tsc -p tsconfig.json",
|
|
12
|
+
"typecheck:scripts": "tsc --noEmit -p tsconfig.scripts.json",
|
|
13
|
+
"typecheck:lp": "tsc --noEmit -p tsconfig.lp.json",
|
|
14
|
+
"generate:idl": "bash ../../scripts/copy-vault-idl.sh",
|
|
15
|
+
"lint:fix": "prettier */*.js \"*/**/*{.js,.ts}\" -w",
|
|
16
|
+
"lint": "prettier */*.js \"*/**/*{.js,.ts}\" --check",
|
|
17
|
+
"deposit": "tsx scripts/deposit.ts",
|
|
18
|
+
"withdraw": "tsx scripts/withdraw.ts",
|
|
19
|
+
"tranche-deposit": "tsx scripts/trancheDeposit.ts",
|
|
20
|
+
"tranche-withdraw": "tsx scripts/trancheWithdraw.ts",
|
|
21
|
+
"request-junior-withdraw": "tsx scripts/requestJuniorWithdraw.ts",
|
|
22
|
+
"cancel-junior-withdraw": "tsx scripts/cancelJuniorWithdraw.ts",
|
|
23
|
+
"fulfill-junior-withdraw": "tsx scripts/fulfillJuniorWithdraw.ts",
|
|
24
|
+
"update-asset-price": "tsx scripts/updateAssetPrice.ts",
|
|
25
|
+
"run-consensus-oracle": "tsx scripts/runConsensusOracle.ts",
|
|
26
|
+
"update-oracles": "tsx scripts/updateOracles.ts",
|
|
27
|
+
"consensus-oracle-selfcheck": "tsx scripts/consensusOracle/selfCheck.ts",
|
|
28
|
+
"reallocate": "tsx scripts/reallocate.ts",
|
|
29
|
+
"manager-withdraw-asset": "tsx scripts/managerWithdrawAsset.ts",
|
|
30
|
+
"circuit-breaker": "tsx scripts/circuitBreaker.ts",
|
|
31
|
+
"set-vault-config": "tsx scripts/setVaultConfig.ts",
|
|
32
|
+
"inspect": "tsx scripts/inspect.ts"
|
|
33
|
+
},
|
|
34
|
+
"dependencies": {
|
|
35
|
+
"@anchor-lang/core": "^1.0.2",
|
|
36
|
+
"@solana/kit": "=2.3.0",
|
|
37
|
+
"@solana/spl-token": "^0.4.13",
|
|
38
|
+
"@solana/web3.js": "^1.98.4",
|
|
39
|
+
"common": "workspace:*"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@kamino-finance/klend-sdk": "^7.3.9",
|
|
43
|
+
"@mrgnlabs/marginfi-client-v2": "=6.4.1",
|
|
44
|
+
"@types/node": "^24.3.1",
|
|
45
|
+
"prettier": "^2.6.2",
|
|
46
|
+
"tsx": "^4.19.2",
|
|
47
|
+
"typescript": "^5.6.3"
|
|
48
|
+
},
|
|
49
|
+
"license": "ISC"
|
|
50
|
+
}
|