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.
Files changed (242) hide show
  1. package/README.md +396 -0
  2. package/dist/client/account.d.ts +59 -0
  3. package/dist/client/account.d.ts.map +1 -0
  4. package/dist/client/account.js +94 -0
  5. package/dist/client/account.js.map +1 -0
  6. package/dist/client/builders/activateCircuitBreaker.d.ts +12 -0
  7. package/dist/client/builders/activateCircuitBreaker.d.ts.map +1 -0
  8. package/dist/client/builders/activateCircuitBreaker.js +27 -0
  9. package/dist/client/builders/activateCircuitBreaker.js.map +1 -0
  10. package/dist/client/builders/anchorArgs.d.ts +59 -0
  11. package/dist/client/builders/anchorArgs.d.ts.map +1 -0
  12. package/dist/client/builders/anchorArgs.js +43 -0
  13. package/dist/client/builders/anchorArgs.js.map +1 -0
  14. package/dist/client/builders/args.d.ts +754 -0
  15. package/dist/client/builders/args.d.ts.map +1 -0
  16. package/dist/client/builders/args.js +3 -0
  17. package/dist/client/builders/args.js.map +1 -0
  18. package/dist/client/builders/base.d.ts +10 -0
  19. package/dist/client/builders/base.d.ts.map +1 -0
  20. package/dist/client/builders/base.js +20 -0
  21. package/dist/client/builders/base.js.map +1 -0
  22. package/dist/client/builders/cancelJuniorTrancheWithdraw.d.ts +13 -0
  23. package/dist/client/builders/cancelJuniorTrancheWithdraw.d.ts.map +1 -0
  24. package/dist/client/builders/cancelJuniorTrancheWithdraw.js +57 -0
  25. package/dist/client/builders/cancelJuniorTrancheWithdraw.js.map +1 -0
  26. package/dist/client/builders/crankNav.d.ts +29 -0
  27. package/dist/client/builders/crankNav.d.ts.map +1 -0
  28. package/dist/client/builders/crankNav.js +88 -0
  29. package/dist/client/builders/crankNav.js.map +1 -0
  30. package/dist/client/builders/crankPerformanceFees.d.ts +19 -0
  31. package/dist/client/builders/crankPerformanceFees.d.ts.map +1 -0
  32. package/dist/client/builders/crankPerformanceFees.js +80 -0
  33. package/dist/client/builders/crankPerformanceFees.js.map +1 -0
  34. package/dist/client/builders/createAssetHolding.d.ts +13 -0
  35. package/dist/client/builders/createAssetHolding.d.ts.map +1 -0
  36. package/dist/client/builders/createAssetHolding.js +47 -0
  37. package/dist/client/builders/createAssetHolding.js.map +1 -0
  38. package/dist/client/builders/createTrancheState.d.ts +13 -0
  39. package/dist/client/builders/createTrancheState.d.ts.map +1 -0
  40. package/dist/client/builders/createTrancheState.js +57 -0
  41. package/dist/client/builders/createTrancheState.js.map +1 -0
  42. package/dist/client/builders/createVault.d.ts +9 -0
  43. package/dist/client/builders/createVault.d.ts.map +1 -0
  44. package/dist/client/builders/createVault.js +75 -0
  45. package/dist/client/builders/createVault.js.map +1 -0
  46. package/dist/client/builders/disableCircuitBreaker.d.ts +12 -0
  47. package/dist/client/builders/disableCircuitBreaker.d.ts.map +1 -0
  48. package/dist/client/builders/disableCircuitBreaker.js +27 -0
  49. package/dist/client/builders/disableCircuitBreaker.js.map +1 -0
  50. package/dist/client/builders/executeDeposit.d.ts +15 -0
  51. package/dist/client/builders/executeDeposit.d.ts.map +1 -0
  52. package/dist/client/builders/executeDeposit.js +86 -0
  53. package/dist/client/builders/executeDeposit.js.map +1 -0
  54. package/dist/client/builders/executeTrancheDeposit.d.ts +16 -0
  55. package/dist/client/builders/executeTrancheDeposit.d.ts.map +1 -0
  56. package/dist/client/builders/executeTrancheDeposit.js +84 -0
  57. package/dist/client/builders/executeTrancheDeposit.js.map +1 -0
  58. package/dist/client/builders/executeTrancheWithdraw.d.ts +16 -0
  59. package/dist/client/builders/executeTrancheWithdraw.d.ts.map +1 -0
  60. package/dist/client/builders/executeTrancheWithdraw.js +83 -0
  61. package/dist/client/builders/executeTrancheWithdraw.js.map +1 -0
  62. package/dist/client/builders/executeWithdraw.d.ts +14 -0
  63. package/dist/client/builders/executeWithdraw.d.ts.map +1 -0
  64. package/dist/client/builders/executeWithdraw.js +86 -0
  65. package/dist/client/builders/executeWithdraw.js.map +1 -0
  66. package/dist/client/builders/feeCollector.d.ts +17 -0
  67. package/dist/client/builders/feeCollector.d.ts.map +1 -0
  68. package/dist/client/builders/feeCollector.js +66 -0
  69. package/dist/client/builders/feeCollector.js.map +1 -0
  70. package/dist/client/builders/fulfillJuniorTrancheWithdraw.d.ts +14 -0
  71. package/dist/client/builders/fulfillJuniorTrancheWithdraw.d.ts.map +1 -0
  72. package/dist/client/builders/fulfillJuniorTrancheWithdraw.js +82 -0
  73. package/dist/client/builders/fulfillJuniorTrancheWithdraw.js.map +1 -0
  74. package/dist/client/builders/index.d.ts +31 -0
  75. package/dist/client/builders/index.d.ts.map +1 -0
  76. package/dist/client/builders/index.js +47 -0
  77. package/dist/client/builders/index.js.map +1 -0
  78. package/dist/client/builders/initializeVaultRoles.d.ts +12 -0
  79. package/dist/client/builders/initializeVaultRoles.d.ts.map +1 -0
  80. package/dist/client/builders/initializeVaultRoles.js +37 -0
  81. package/dist/client/builders/initializeVaultRoles.js.map +1 -0
  82. package/dist/client/builders/managerRedepositAsset.d.ts +12 -0
  83. package/dist/client/builders/managerRedepositAsset.d.ts.map +1 -0
  84. package/dist/client/builders/managerRedepositAsset.js +52 -0
  85. package/dist/client/builders/managerRedepositAsset.js.map +1 -0
  86. package/dist/client/builders/managerWithdrawAsset.d.ts +12 -0
  87. package/dist/client/builders/managerWithdrawAsset.d.ts.map +1 -0
  88. package/dist/client/builders/managerWithdrawAsset.js +47 -0
  89. package/dist/client/builders/managerWithdrawAsset.js.map +1 -0
  90. package/dist/client/builders/protocolInteraction.d.ts +22 -0
  91. package/dist/client/builders/protocolInteraction.d.ts.map +1 -0
  92. package/dist/client/builders/protocolInteraction.js +157 -0
  93. package/dist/client/builders/protocolInteraction.js.map +1 -0
  94. package/dist/client/builders/removeAssetHolding.d.ts +13 -0
  95. package/dist/client/builders/removeAssetHolding.d.ts.map +1 -0
  96. package/dist/client/builders/removeAssetHolding.js +37 -0
  97. package/dist/client/builders/removeAssetHolding.js.map +1 -0
  98. package/dist/client/builders/requestJuniorTrancheWithdraw.d.ts +14 -0
  99. package/dist/client/builders/requestJuniorTrancheWithdraw.d.ts.map +1 -0
  100. package/dist/client/builders/requestJuniorTrancheWithdraw.js +72 -0
  101. package/dist/client/builders/requestJuniorTrancheWithdraw.js.map +1 -0
  102. package/dist/client/builders/setAssetPriceOracle.d.ts +12 -0
  103. package/dist/client/builders/setAssetPriceOracle.d.ts.map +1 -0
  104. package/dist/client/builders/setAssetPriceOracle.js +40 -0
  105. package/dist/client/builders/setAssetPriceOracle.js.map +1 -0
  106. package/dist/client/builders/setExternalLiquidity.d.ts +12 -0
  107. package/dist/client/builders/setExternalLiquidity.d.ts.map +1 -0
  108. package/dist/client/builders/setExternalLiquidity.js +49 -0
  109. package/dist/client/builders/setExternalLiquidity.js.map +1 -0
  110. package/dist/client/builders/setProtocolFee.d.ts +12 -0
  111. package/dist/client/builders/setProtocolFee.d.ts.map +1 -0
  112. package/dist/client/builders/setProtocolFee.js +37 -0
  113. package/dist/client/builders/setProtocolFee.js.map +1 -0
  114. package/dist/client/builders/setVaultConfig.d.ts +12 -0
  115. package/dist/client/builders/setVaultConfig.d.ts.map +1 -0
  116. package/dist/client/builders/setVaultConfig.js +54 -0
  117. package/dist/client/builders/setVaultConfig.js.map +1 -0
  118. package/dist/client/builders/trancheState.d.ts +28 -0
  119. package/dist/client/builders/trancheState.d.ts.map +1 -0
  120. package/dist/client/builders/trancheState.js +75 -0
  121. package/dist/client/builders/trancheState.js.map +1 -0
  122. package/dist/client/builders/updateAssetPrice.d.ts +18 -0
  123. package/dist/client/builders/updateAssetPrice.d.ts.map +1 -0
  124. package/dist/client/builders/updateAssetPrice.js +50 -0
  125. package/dist/client/builders/updateAssetPrice.js.map +1 -0
  126. package/dist/client/builders/updateConsensusOracle.d.ts +20 -0
  127. package/dist/client/builders/updateConsensusOracle.d.ts.map +1 -0
  128. package/dist/client/builders/updateConsensusOracle.js +64 -0
  129. package/dist/client/builders/updateConsensusOracle.js.map +1 -0
  130. package/dist/client/builders/updateConsensusSigners.d.ts +13 -0
  131. package/dist/client/builders/updateConsensusSigners.d.ts.map +1 -0
  132. package/dist/client/builders/updateConsensusSigners.js +38 -0
  133. package/dist/client/builders/updateConsensusSigners.js.map +1 -0
  134. package/dist/client/builders/updateTrancheConfig.d.ts +13 -0
  135. package/dist/client/builders/updateTrancheConfig.d.ts.map +1 -0
  136. package/dist/client/builders/updateTrancheConfig.js +50 -0
  137. package/dist/client/builders/updateTrancheConfig.js.map +1 -0
  138. package/dist/client/builders/vaultReallocation.d.ts +15 -0
  139. package/dist/client/builders/vaultReallocation.d.ts.map +1 -0
  140. package/dist/client/builders/vaultReallocation.js +148 -0
  141. package/dist/client/builders/vaultReallocation.js.map +1 -0
  142. package/dist/client/client.d.ts +34 -0
  143. package/dist/client/client.d.ts.map +1 -0
  144. package/dist/client/client.js +75 -0
  145. package/dist/client/client.js.map +1 -0
  146. package/dist/client/index.d.ts +8 -0
  147. package/dist/client/index.d.ts.map +1 -0
  148. package/dist/client/index.js +24 -0
  149. package/dist/client/index.js.map +1 -0
  150. package/dist/client/pda.d.ts +42 -0
  151. package/dist/client/pda.d.ts.map +1 -0
  152. package/dist/client/pda.js +88 -0
  153. package/dist/client/pda.js.map +1 -0
  154. package/dist/client/transaction.d.ts +36 -0
  155. package/dist/client/transaction.d.ts.map +1 -0
  156. package/dist/client/transaction.js +39 -0
  157. package/dist/client/transaction.js.map +1 -0
  158. package/dist/client/types/builders.d.ts +12 -0
  159. package/dist/client/types/builders.d.ts.map +1 -0
  160. package/dist/client/types/builders.js +3 -0
  161. package/dist/client/types/builders.js.map +1 -0
  162. package/dist/client/types/tx.d.ts +13 -0
  163. package/dist/client/types/tx.d.ts.map +1 -0
  164. package/dist/client/types/tx.js +3 -0
  165. package/dist/client/types/tx.js.map +1 -0
  166. package/dist/constants.d.ts +45 -0
  167. package/dist/constants.d.ts.map +1 -0
  168. package/dist/constants.js +49 -0
  169. package/dist/constants.js.map +1 -0
  170. package/dist/env.d.ts +70 -0
  171. package/dist/env.d.ts.map +1 -0
  172. package/dist/env.js +117 -0
  173. package/dist/env.js.map +1 -0
  174. package/dist/idl/index.d.ts +3 -0
  175. package/dist/idl/index.d.ts.map +1 -0
  176. package/dist/idl/index.js +6 -0
  177. package/dist/idl/index.js.map +1 -0
  178. package/dist/idl/vault.d.ts +9617 -0
  179. package/dist/idl/vault.d.ts.map +1 -0
  180. package/dist/idl/vault.js +7917 -0
  181. package/dist/idl/vault.js.map +1 -0
  182. package/dist/index.d.ts +7 -0
  183. package/dist/index.d.ts.map +1 -0
  184. package/dist/index.js +23 -0
  185. package/dist/index.js.map +1 -0
  186. package/dist/services/consensusOracle/consensusOracleService.d.ts +38 -0
  187. package/dist/services/consensusOracle/consensusOracleService.d.ts.map +1 -0
  188. package/dist/services/consensusOracle/consensusOracleService.js +270 -0
  189. package/dist/services/consensusOracle/consensusOracleService.js.map +1 -0
  190. package/dist/services/consensusOracle/externalPositions.d.ts +26 -0
  191. package/dist/services/consensusOracle/externalPositions.d.ts.map +1 -0
  192. package/dist/services/consensusOracle/externalPositions.js +37 -0
  193. package/dist/services/consensusOracle/externalPositions.js.map +1 -0
  194. package/dist/services/consensusOracle/index.d.ts +7 -0
  195. package/dist/services/consensusOracle/index.d.ts.map +1 -0
  196. package/dist/services/consensusOracle/index.js +23 -0
  197. package/dist/services/consensusOracle/index.js.map +1 -0
  198. package/dist/services/consensusOracle/jupiterBalanceSource.d.ts +34 -0
  199. package/dist/services/consensusOracle/jupiterBalanceSource.d.ts.map +1 -0
  200. package/dist/services/consensusOracle/jupiterBalanceSource.js +80 -0
  201. package/dist/services/consensusOracle/jupiterBalanceSource.js.map +1 -0
  202. package/dist/services/consensusOracle/jupiterPriceSource.d.ts +25 -0
  203. package/dist/services/consensusOracle/jupiterPriceSource.d.ts.map +1 -0
  204. package/dist/services/consensusOracle/jupiterPriceSource.js +63 -0
  205. package/dist/services/consensusOracle/jupiterPriceSource.js.map +1 -0
  206. package/dist/services/consensusOracle/mockYieldTracker.d.ts +44 -0
  207. package/dist/services/consensusOracle/mockYieldTracker.d.ts.map +1 -0
  208. package/dist/services/consensusOracle/mockYieldTracker.js +107 -0
  209. package/dist/services/consensusOracle/mockYieldTracker.js.map +1 -0
  210. package/dist/services/consensusOracle/types.d.ts +180 -0
  211. package/dist/services/consensusOracle/types.d.ts.map +1 -0
  212. package/dist/services/consensusOracle/types.js +5 -0
  213. package/dist/services/consensusOracle/types.js.map +1 -0
  214. package/dist/services/index.d.ts +4 -0
  215. package/dist/services/index.d.ts.map +1 -0
  216. package/dist/services/index.js +20 -0
  217. package/dist/services/index.js.map +1 -0
  218. package/dist/services/oracleService.d.ts +72 -0
  219. package/dist/services/oracleService.d.ts.map +1 -0
  220. package/dist/services/oracleService.js +93 -0
  221. package/dist/services/oracleService.js.map +1 -0
  222. package/dist/services/withdrawalQueueService.d.ts +76 -0
  223. package/dist/services/withdrawalQueueService.d.ts.map +1 -0
  224. package/dist/services/withdrawalQueueService.js +138 -0
  225. package/dist/services/withdrawalQueueService.js.map +1 -0
  226. package/dist/utils/index.d.ts +4 -0
  227. package/dist/utils/index.d.ts.map +1 -0
  228. package/dist/utils/index.js +20 -0
  229. package/dist/utils/index.js.map +1 -0
  230. package/dist/utils/provider.d.ts +4 -0
  231. package/dist/utils/provider.d.ts.map +1 -0
  232. package/dist/utils/provider.js +10 -0
  233. package/dist/utils/provider.js.map +1 -0
  234. package/dist/utils/rpc.d.ts +4 -0
  235. package/dist/utils/rpc.d.ts.map +1 -0
  236. package/dist/utils/rpc.js +8 -0
  237. package/dist/utils/rpc.js.map +1 -0
  238. package/dist/utils/token.d.ts +6 -0
  239. package/dist/utils/token.d.ts.map +1 -0
  240. package/dist/utils/token.js +32 -0
  241. package/dist/utils/token.js.map +1 -0
  242. package/package.json +50 -0
@@ -0,0 +1,66 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.resolveProtocolAdmin = resolveProtocolAdmin;
4
+ exports.resolveProtocolFeeRecipient = resolveProtocolFeeRecipient;
5
+ exports.resolveVaultFeeCollector = resolveVaultFeeCollector;
6
+ exports.baseAssetMintFromVault = baseAssetMintFromVault;
7
+ exports.resolveVaultBaseAssetMint = resolveVaultBaseAssetMint;
8
+ exports.resolveFeeAssetTokenProgram = resolveFeeAssetTokenProgram;
9
+ const kit_1 = require("@solana/kit");
10
+ const spl_token_1 = require("@solana/spl-token");
11
+ const common_1 = require("common");
12
+ const constants_1 = require("../../constants");
13
+ /**
14
+ * The hardcoded protocol admin wallet that may set the protocol performance fee.
15
+ * Pass `override` only in tests that deploy a program with a different constant.
16
+ */
17
+ function resolveProtocolAdmin(override) {
18
+ return override ?? constants_1.PROTOCOL_ADMIN;
19
+ }
20
+ /**
21
+ * The hardcoded wallet that receives protocol performance fees. Pass `override`
22
+ * only in tests that deploy a program with a different constant.
23
+ */
24
+ function resolveProtocolFeeRecipient(override) {
25
+ return override ?? constants_1.PROTOCOL_FEE_RECIPIENT;
26
+ }
27
+ async function resolveVaultFeeCollector(account, vault, override) {
28
+ if (override) {
29
+ return override;
30
+ }
31
+ const vaultState = await account.fetchVault(vault);
32
+ return (0, common_1.fromWeb3Pk)(vaultState.roles.feeCollector);
33
+ }
34
+ function baseAssetMintFromVault(vaultState) {
35
+ const baseHolding = vaultState.holdings.find((holding) => holding.isBase);
36
+ if (!baseHolding) {
37
+ throw new Error("Vault has no base asset holding");
38
+ }
39
+ return (0, common_1.fromWeb3Pk)(baseHolding.mint);
40
+ }
41
+ async function resolveVaultBaseAssetMint(account, vault, override) {
42
+ if (override) {
43
+ return override;
44
+ }
45
+ const vaultState = await account.fetchVault(vault);
46
+ return baseAssetMintFromVault(vaultState);
47
+ }
48
+ function tokenProgramFromHolding(holding) {
49
+ const tokenProgram = holding.tokenProgram;
50
+ if ("token2022" in tokenProgram) {
51
+ return constants_1.TOKEN_PROGRAM_ID;
52
+ }
53
+ return (0, kit_1.address)(spl_token_1.TOKEN_PROGRAM_ID.toBase58());
54
+ }
55
+ async function resolveFeeAssetTokenProgram(account, vault, feeAssetMint, override) {
56
+ if (override) {
57
+ return override;
58
+ }
59
+ const vaultState = await account.fetchVault(vault);
60
+ const holding = vaultState.holdings.find((entry) => (0, common_1.fromWeb3Pk)(entry.mint) === feeAssetMint);
61
+ if (!holding) {
62
+ return constants_1.TOKEN_PROGRAM_ID;
63
+ }
64
+ return tokenProgramFromHolding(holding);
65
+ }
66
+ //# sourceMappingURL=feeCollector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"feeCollector.js","sourceRoot":"","sources":["../../../src/client/builders/feeCollector.ts"],"names":[],"mappings":";;AAeA,oDAEC;AAMD,kEAEC;AAED,4DAUC;AAED,wDAMC;AAED,8DAUC;AAYD,kEAiBC;AAtFD,qCAAoD;AACpD,iDAA6E;AAC7E,mCAAoC;AAEpC,+CAIyB;AAGzB;;;GAGG;AACH,SAAgB,oBAAoB,CAAC,QAAkB;IACrD,OAAO,QAAQ,IAAI,0BAAc,CAAC;AACpC,CAAC;AAED;;;GAGG;AACH,SAAgB,2BAA2B,CAAC,QAAkB;IAC5D,OAAO,QAAQ,IAAI,kCAAsB,CAAC;AAC5C,CAAC;AAEM,KAAK,UAAU,wBAAwB,CAC5C,OAAsB,EACtB,KAAc,EACd,QAAkB;IAElB,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACnD,OAAO,IAAA,mBAAU,EAAC,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;AACnD,CAAC;AAED,SAAgB,sBAAsB,CAAC,UAA4B;IACjE,MAAM,WAAW,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1E,IAAI,CAAC,WAAW,EAAE,CAAC;QACjB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;IACrD,CAAC;IACD,OAAO,IAAA,mBAAU,EAAC,WAAW,CAAC,IAAI,CAAC,CAAC;AACtC,CAAC;AAEM,KAAK,UAAU,yBAAyB,CAC7C,OAAsB,EACtB,KAAc,EACd,QAAkB;IAElB,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACnD,OAAO,sBAAsB,CAAC,UAAU,CAAC,CAAC;AAC5C,CAAC;AAED,SAAS,uBAAuB,CAC9B,OAA6C;IAE7C,MAAM,YAAY,GAAG,OAAO,CAAC,YAAuC,CAAC;IACrE,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;QAChC,OAAO,4BAAgB,CAAC;IAC1B,CAAC;IACD,OAAO,IAAA,aAAO,EAAC,4BAAoB,CAAC,QAAQ,EAAE,CAAC,CAAC;AAClD,CAAC;AAEM,KAAK,UAAU,2BAA2B,CAC/C,OAAsB,EACtB,KAAc,EACd,YAAqB,EACrB,QAAkB;IAElB,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CACtC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAA,mBAAU,EAAC,KAAK,CAAC,IAAI,CAAC,KAAK,YAAY,CACnD,CAAC;IACF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,4BAAgB,CAAC;IAC1B,CAAC;IACD,OAAO,uBAAuB,CAAC,OAAO,CAAC,CAAC;AAC1C,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { VaultBuilderBase } from "./base";
2
+ import type { FulfillJuniorTrancheWithdrawIxArgs, FulfillJuniorTrancheWithdrawTxArgs } from "./args";
3
+ export declare class FulfillJuniorTrancheWithdrawBuilder extends VaultBuilderBase<FulfillJuniorTrancheWithdrawIxArgs, FulfillJuniorTrancheWithdrawTxArgs> {
4
+ getIx(args: FulfillJuniorTrancheWithdrawIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
5
+ protected deriveIxArgs(txArgs: FulfillJuniorTrancheWithdrawTxArgs): Promise<FulfillJuniorTrancheWithdrawIxArgs>;
6
+ protected buildPlanExtras(args: FulfillJuniorTrancheWithdrawIxArgs): Promise<{
7
+ postSuccessCacheInvalidations: {
8
+ vaultPda: import("@solana/kit").Address;
9
+ vaultTrancheStatePda: import("@solana/kit").Address;
10
+ withdrawalQueuePda: import("@solana/kit").Address;
11
+ }[];
12
+ }>;
13
+ }
14
+ //# sourceMappingURL=fulfillJuniorTrancheWithdraw.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fulfillJuniorTrancheWithdraw.d.ts","sourceRoot":"","sources":["../../../src/client/builders/fulfillJuniorTrancheWithdraw.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,KAAK,EACV,kCAAkC,EAClC,kCAAkC,EACnC,MAAM,QAAQ,CAAC;AAIhB,qBAAa,mCAAoC,SAAQ,gBAAgB,CACvE,kCAAkC,EAClC,kCAAkC,CACnC;IACO,KAAK,CAAC,IAAI,EAAE,kCAAkC;cA2BpC,YAAY,CAC1B,MAAM,EAAE,kCAAkC,GACzC,OAAO,CAAC,kCAAkC,CAAC;cAsE9B,eAAe,CAAC,IAAI,EAAE,kCAAkC;;;;;;;CAWzE"}
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FulfillJuniorTrancheWithdrawBuilder = void 0;
4
+ const spl_token_1 = require("@solana/spl-token");
5
+ const web3_js_1 = require("@solana/web3.js");
6
+ const common_1 = require("common");
7
+ const base_1 = require("./base");
8
+ const feeCollector_1 = require("./feeCollector");
9
+ const trancheState_1 = require("./trancheState");
10
+ class FulfillJuniorTrancheWithdrawBuilder extends base_1.VaultBuilderBase {
11
+ async getIx(args) {
12
+ return this.program.methods
13
+ .fulfillJuniorTrancheWithdraw()
14
+ .accountsPartial({
15
+ signer: (0, common_1.toWeb3Pk)(args.signer),
16
+ owner: (0, common_1.toWeb3Pk)(args.owner),
17
+ queuePayer: (0, common_1.toWeb3Pk)(args.queuePayer),
18
+ vault: (0, common_1.toWeb3Pk)(args.vault),
19
+ vaultOracle: (0, common_1.toWeb3Pk)(args.vaultOracle),
20
+ vaultTrancheState: (0, common_1.toWeb3Pk)(args.vaultTrancheState),
21
+ withdrawalQueue: (0, common_1.toWeb3Pk)(args.withdrawalQueue),
22
+ outputMint: (0, common_1.toWeb3Pk)(args.outputMint),
23
+ inputMint: (0, common_1.toWeb3Pk)(args.inputMint),
24
+ ownerOutputAta: (0, common_1.toWeb3Pk)(args.ownerOutputAta),
25
+ vaultOutputAta: (0, common_1.toWeb3Pk)(args.vaultOutputAta),
26
+ feeCollector: (0, common_1.toWeb3Pk)(args.feeCollector),
27
+ feeCollectorOutputAta: (0, common_1.toWeb3Pk)(args.feeCollectorOutputAta),
28
+ queueInputAta: (0, common_1.toWeb3Pk)(args.queueInputAta),
29
+ assetTokenProgram: (0, common_1.toWeb3Pk)(args.assetTokenProgram),
30
+ shareTokenProgram: (0, common_1.toWeb3Pk)(args.shareTokenProgram),
31
+ associatedTokenProgram: spl_token_1.ASSOCIATED_TOKEN_PROGRAM_ID,
32
+ systemProgram: web3_js_1.SystemProgram.programId,
33
+ })
34
+ .instruction()
35
+ .then(common_1.toKitInstruction);
36
+ }
37
+ async deriveIxArgs(txArgs) {
38
+ const connection = this.program.provider.connection;
39
+ const signer = txArgs.signer ?? txArgs.owner;
40
+ const queuePayer = txArgs.queuePayer ?? txArgs.owner;
41
+ const [[vaultOracle], [vaultTrancheState], [withdrawalQueue], feeCollector, assetTokenProgram, shareTokenProgram,] = await Promise.all([
42
+ this.pda.deriveVaultOraclePda(txArgs.vault),
43
+ this.pda.deriveVaultTrancheStatePda(txArgs.vault),
44
+ this.pda.deriveVaultTrancheWithdrawalQueuePda(txArgs.vault, txArgs.owner, txArgs.queueId),
45
+ (0, feeCollector_1.resolveVaultFeeCollector)(this.account, txArgs.vault, txArgs.feeCollector),
46
+ (0, trancheState_1.resolveTokenProgramForMint)(connection, txArgs.assetMint, txArgs.assetTokenProgram),
47
+ (0, trancheState_1.resolveTokenProgramForMint)(connection, txArgs.juniorShareMint, txArgs.shareTokenProgram),
48
+ ]);
49
+ const queuePda = txArgs.withdrawalQueue ?? withdrawalQueue;
50
+ return {
51
+ signer,
52
+ owner: txArgs.owner,
53
+ queuePayer,
54
+ vault: txArgs.vault,
55
+ vaultOracle: txArgs.vaultOracle ?? vaultOracle,
56
+ vaultTrancheState: txArgs.vaultTrancheState ?? vaultTrancheState,
57
+ withdrawalQueue: queuePda,
58
+ outputMint: txArgs.assetMint,
59
+ inputMint: txArgs.juniorShareMint,
60
+ assetTokenProgram,
61
+ shareTokenProgram,
62
+ ownerOutputAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.owner, assetTokenProgram),
63
+ vaultOutputAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.vault, assetTokenProgram, true),
64
+ feeCollector,
65
+ feeCollectorOutputAta: (0, common_1.getAtaAddress)(txArgs.assetMint, feeCollector, assetTokenProgram),
66
+ queueInputAta: (0, common_1.getAtaAddress)(txArgs.juniorShareMint, queuePda, shareTokenProgram, true),
67
+ };
68
+ }
69
+ async buildPlanExtras(args) {
70
+ return {
71
+ postSuccessCacheInvalidations: [
72
+ {
73
+ vaultPda: args.vault,
74
+ vaultTrancheStatePda: args.vaultTrancheState,
75
+ withdrawalQueuePda: args.withdrawalQueue,
76
+ },
77
+ ],
78
+ };
79
+ }
80
+ }
81
+ exports.FulfillJuniorTrancheWithdrawBuilder = FulfillJuniorTrancheWithdrawBuilder;
82
+ //# sourceMappingURL=fulfillJuniorTrancheWithdraw.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fulfillJuniorTrancheWithdraw.js","sourceRoot":"","sources":["../../../src/client/builders/fulfillJuniorTrancheWithdraw.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ export * from "./args";
2
+ export * from "./base";
3
+ export * from "./cancelJuniorTrancheWithdraw";
4
+ export * from "./createAssetHolding";
5
+ export * from "./removeAssetHolding";
6
+ export * from "./updateConsensusSigners";
7
+ export * from "./createTrancheState";
8
+ export * from "./activateCircuitBreaker";
9
+ export * from "./createVault";
10
+ export * from "./initializeVaultRoles";
11
+ export * from "./disableCircuitBreaker";
12
+ export * from "./setVaultConfig";
13
+ export * from "./setProtocolFee";
14
+ export * from "./crankNav";
15
+ export * from "./crankPerformanceFees";
16
+ export * from "./setExternalLiquidity";
17
+ export * from "./setAssetPriceOracle";
18
+ export * from "./updateAssetPrice";
19
+ export * from "./updateConsensusOracle";
20
+ export * from "./executeDeposit";
21
+ export * from "./executeTrancheDeposit";
22
+ export * from "./executeTrancheWithdraw";
23
+ export * from "./executeWithdraw";
24
+ export * from "./fulfillJuniorTrancheWithdraw";
25
+ export * from "./updateTrancheConfig";
26
+ export * from "./managerRedepositAsset";
27
+ export * from "./managerWithdrawAsset";
28
+ export * from "./protocolInteraction";
29
+ export * from "./requestJuniorTrancheWithdraw";
30
+ export * from "./vaultReallocation";
31
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/client/builders/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,+BAA+B,CAAC;AAC9C,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,0BAA0B,CAAC;AACzC,cAAc,eAAe,CAAC;AAC9B,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AACxC,cAAc,kBAAkB,CAAC;AACjC,cAAc,kBAAkB,CAAC;AACjC,cAAc,YAAY,CAAC;AAC3B,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,kBAAkB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,qBAAqB,CAAC"}
@@ -0,0 +1,47 @@
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("./args"), exports);
18
+ __exportStar(require("./base"), exports);
19
+ __exportStar(require("./cancelJuniorTrancheWithdraw"), exports);
20
+ __exportStar(require("./createAssetHolding"), exports);
21
+ __exportStar(require("./removeAssetHolding"), exports);
22
+ __exportStar(require("./updateConsensusSigners"), exports);
23
+ __exportStar(require("./createTrancheState"), exports);
24
+ __exportStar(require("./activateCircuitBreaker"), exports);
25
+ __exportStar(require("./createVault"), exports);
26
+ __exportStar(require("./initializeVaultRoles"), exports);
27
+ __exportStar(require("./disableCircuitBreaker"), exports);
28
+ __exportStar(require("./setVaultConfig"), exports);
29
+ __exportStar(require("./setProtocolFee"), exports);
30
+ __exportStar(require("./crankNav"), exports);
31
+ __exportStar(require("./crankPerformanceFees"), exports);
32
+ __exportStar(require("./setExternalLiquidity"), exports);
33
+ __exportStar(require("./setAssetPriceOracle"), exports);
34
+ __exportStar(require("./updateAssetPrice"), exports);
35
+ __exportStar(require("./updateConsensusOracle"), exports);
36
+ __exportStar(require("./executeDeposit"), exports);
37
+ __exportStar(require("./executeTrancheDeposit"), exports);
38
+ __exportStar(require("./executeTrancheWithdraw"), exports);
39
+ __exportStar(require("./executeWithdraw"), exports);
40
+ __exportStar(require("./fulfillJuniorTrancheWithdraw"), exports);
41
+ __exportStar(require("./updateTrancheConfig"), exports);
42
+ __exportStar(require("./managerRedepositAsset"), exports);
43
+ __exportStar(require("./managerWithdrawAsset"), exports);
44
+ __exportStar(require("./protocolInteraction"), exports);
45
+ __exportStar(require("./requestJuniorTrancheWithdraw"), exports);
46
+ __exportStar(require("./vaultReallocation"), exports);
47
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/client/builders/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,yCAAuB;AACvB,gEAA8C;AAC9C,uDAAqC;AACrC,uDAAqC;AACrC,2DAAyC;AACzC,uDAAqC;AACrC,2DAAyC;AACzC,gDAA8B;AAC9B,yDAAuC;AACvC,0DAAwC;AACxC,mDAAiC;AACjC,mDAAiC;AACjC,6CAA2B;AAC3B,yDAAuC;AACvC,yDAAuC;AACvC,wDAAsC;AACtC,qDAAmC;AACnC,0DAAwC;AACxC,mDAAiC;AACjC,0DAAwC;AACxC,2DAAyC;AACzC,oDAAkC;AAClC,iEAA+C;AAC/C,wDAAsC;AACtC,0DAAwC;AACxC,yDAAuC;AACvC,wDAAsC;AACtC,iEAA+C;AAC/C,sDAAoC"}
@@ -0,0 +1,12 @@
1
+ import { VaultBuilderBase } from "./base";
2
+ import type { InitializeVaultRolesIxArgs, InitializeVaultRolesTxArgs } from "./args";
3
+ export declare class InitializeVaultRolesBuilder extends VaultBuilderBase<InitializeVaultRolesIxArgs, InitializeVaultRolesTxArgs> {
4
+ getIx(args: InitializeVaultRolesIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
5
+ protected deriveIxArgs(txArgs: InitializeVaultRolesTxArgs): Promise<InitializeVaultRolesIxArgs>;
6
+ protected buildPlanExtras(args: InitializeVaultRolesIxArgs): Promise<{
7
+ postSuccessCacheInvalidations: {
8
+ vaultPda: import("@solana/kit").Address;
9
+ }[];
10
+ }>;
11
+ }
12
+ //# sourceMappingURL=initializeVaultRoles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"initializeVaultRoles.d.ts","sourceRoot":"","sources":["../../../src/client/builders/initializeVaultRoles.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,KAAK,EACV,0BAA0B,EAC1B,0BAA0B,EAC3B,MAAM,QAAQ,CAAC;AAEhB,qBAAa,2BAA4B,SAAQ,gBAAgB,CAC/D,0BAA0B,EAC1B,0BAA0B,CAC3B;IACO,KAAK,CAAC,IAAI,EAAE,0BAA0B;cAc5B,YAAY,CAC1B,MAAM,EAAE,0BAA0B,GACjC,OAAO,CAAC,0BAA0B,CAAC;cAWtB,eAAe,CAAC,IAAI,EAAE,0BAA0B;;;;;CAKjE"}
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InitializeVaultRolesBuilder = void 0;
4
+ const common_1 = require("common");
5
+ const base_1 = require("./base");
6
+ class InitializeVaultRolesBuilder extends base_1.VaultBuilderBase {
7
+ async getIx(args) {
8
+ return this.program.methods
9
+ .initializeVaultRoles({
10
+ manager: (0, common_1.toWeb3Pk)(args.args.manager),
11
+ fulfiller: (0, common_1.toWeb3Pk)(args.args.fulfiller),
12
+ })
13
+ .accountsPartial({
14
+ curator: (0, common_1.toWeb3Pk)(args.curator),
15
+ vault: (0, common_1.toWeb3Pk)(args.vault),
16
+ })
17
+ .instruction()
18
+ .then(common_1.toKitInstruction);
19
+ }
20
+ async deriveIxArgs(txArgs) {
21
+ return {
22
+ curator: txArgs.curator,
23
+ vault: txArgs.vault,
24
+ args: {
25
+ manager: txArgs.manager,
26
+ fulfiller: txArgs.fulfiller,
27
+ },
28
+ };
29
+ }
30
+ async buildPlanExtras(args) {
31
+ return {
32
+ postSuccessCacheInvalidations: [{ vaultPda: args.vault }],
33
+ };
34
+ }
35
+ }
36
+ exports.InitializeVaultRolesBuilder = InitializeVaultRolesBuilder;
37
+ //# sourceMappingURL=initializeVaultRoles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"initializeVaultRoles.js","sourceRoot":"","sources":["../../../src/client/builders/initializeVaultRoles.ts"],"names":[],"mappings":";;;AAAA,mCAAoD;AAEpD,iCAA0C;AAM1C,MAAa,2BAA4B,SAAQ,uBAGhD;IACC,KAAK,CAAC,KAAK,CAAC,IAAgC;QAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO;aACxB,oBAAoB,CAAC;YACpB,OAAO,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;YACpC,SAAS,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC;SACzC,CAAC;aACD,eAAe,CAAC;YACf,OAAO,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,OAAO,CAAC;YAC/B,KAAK,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,KAAK,CAAC;SAC5B,CAAC;aACD,WAAW,EAAE;aACb,IAAI,CAAC,yBAAgB,CAAC,CAAC;IAC5B,CAAC;IAES,KAAK,CAAC,YAAY,CAC1B,MAAkC;QAElC,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,IAAI,EAAE;gBACJ,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,SAAS,EAAE,MAAM,CAAC,SAAS;aAC5B;SACF,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,eAAe,CAAC,IAAgC;QAC9D,OAAO;YACL,6BAA6B,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;SAC1D,CAAC;IACJ,CAAC;CACF;AApCD,kEAoCC"}
@@ -0,0 +1,12 @@
1
+ import { VaultBuilderBase } from "./base";
2
+ import type { ManagerRedepositAssetIxArgs, ManagerRedepositAssetTxArgs } from "./args";
3
+ export declare class ManagerRedepositAssetBuilder extends VaultBuilderBase<ManagerRedepositAssetIxArgs, ManagerRedepositAssetTxArgs> {
4
+ getIx(args: ManagerRedepositAssetIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
5
+ protected deriveIxArgs(txArgs: ManagerRedepositAssetTxArgs): Promise<ManagerRedepositAssetIxArgs>;
6
+ protected buildPlanExtras(args: ManagerRedepositAssetIxArgs): Promise<{
7
+ postSuccessCacheInvalidations: {
8
+ vaultPda: import("@solana/kit").Address;
9
+ }[];
10
+ }>;
11
+ }
12
+ //# sourceMappingURL=managerRedepositAsset.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"managerRedepositAsset.d.ts","sourceRoot":"","sources":["../../../src/client/builders/managerRedepositAsset.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,KAAK,EACV,2BAA2B,EAC3B,2BAA2B,EAC5B,MAAM,QAAQ,CAAC;AAGhB,qBAAa,4BAA6B,SAAQ,gBAAgB,CAChE,2BAA2B,EAC3B,2BAA2B,CAC5B;IACO,KAAK,CAAC,IAAI,EAAE,2BAA2B;cAoB7B,YAAY,CAC1B,MAAM,EAAE,2BAA2B,GAClC,OAAO,CAAC,2BAA2B,CAAC;cA6BvB,eAAe,CAAC,IAAI,EAAE,2BAA2B;;;;;CAKlE"}
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ManagerRedepositAssetBuilder = void 0;
4
+ const core_1 = require("@anchor-lang/core");
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
+ const base_1 = require("./base");
9
+ const trancheState_1 = require("./trancheState");
10
+ class ManagerRedepositAssetBuilder extends base_1.VaultBuilderBase {
11
+ async getIx(args) {
12
+ return this.program.methods
13
+ .managerRedepositAsset({
14
+ depositAmount: args.depositAmount,
15
+ externalAmount: args.externalAmount,
16
+ })
17
+ .accountsPartial({
18
+ manager: (0, common_1.toWeb3Pk)(args.manager),
19
+ vault: (0, common_1.toWeb3Pk)(args.vault),
20
+ assetMint: (0, common_1.toWeb3Pk)(args.assetMint),
21
+ vaultAssetAta: (0, common_1.toWeb3Pk)(args.vaultAssetAta),
22
+ managerAssetAta: (0, common_1.toWeb3Pk)(args.managerAssetAta),
23
+ assetTokenProgram: (0, common_1.toWeb3Pk)(args.assetTokenProgram),
24
+ associatedTokenProgram: spl_token_1.ASSOCIATED_TOKEN_PROGRAM_ID,
25
+ systemProgram: web3_js_1.SystemProgram.programId,
26
+ })
27
+ .instruction()
28
+ .then(common_1.toKitInstruction);
29
+ }
30
+ async deriveIxArgs(txArgs) {
31
+ const connection = this.program.provider.connection;
32
+ const assetTokenProgram = await (0, trancheState_1.resolveTokenProgramForMint)(connection, txArgs.assetMint, txArgs.assetTokenProgram);
33
+ const externalAmount = txArgs.externalAmount ?? txArgs.depositAmount;
34
+ return {
35
+ manager: txArgs.manager,
36
+ vault: txArgs.vault,
37
+ assetMint: txArgs.assetMint,
38
+ depositAmount: new core_1.BN(txArgs.depositAmount.toString()),
39
+ externalAmount: new core_1.BN(externalAmount.toString()),
40
+ assetTokenProgram,
41
+ vaultAssetAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.vault, assetTokenProgram, true),
42
+ managerAssetAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.manager, assetTokenProgram),
43
+ };
44
+ }
45
+ async buildPlanExtras(args) {
46
+ return {
47
+ postSuccessCacheInvalidations: [{ vaultPda: args.vault }],
48
+ };
49
+ }
50
+ }
51
+ exports.ManagerRedepositAssetBuilder = ManagerRedepositAssetBuilder;
52
+ //# sourceMappingURL=managerRedepositAsset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"managerRedepositAsset.js","sourceRoot":"","sources":["../../../src/client/builders/managerRedepositAsset.ts"],"names":[],"mappings":";;;AAAA,4CAAuC;AACvC,iDAAgE;AAChE,6CAAgD;AAChD,mCAAmE;AAEnE,iCAA0C;AAK1C,iDAA4D;AAE5D,MAAa,4BAA6B,SAAQ,uBAGjD;IACC,KAAK,CAAC,KAAK,CAAC,IAAiC;QAC3C,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO;aACxB,qBAAqB,CAAC;YACrB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC;aACD,eAAe,CAAC;YACf,OAAO,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,OAAO,CAAC;YAC/B,KAAK,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,KAAK,CAAC;YAC3B,SAAS,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,SAAS,CAAC;YACnC,aAAa,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,aAAa,CAAC;YAC3C,eAAe,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,eAAe,CAAC;YAC/C,iBAAiB,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,iBAAiB,CAAC;YACnD,sBAAsB,EAAE,uCAA2B;YACnD,aAAa,EAAE,uBAAa,CAAC,SAAS;SACvC,CAAC;aACD,WAAW,EAAE;aACb,IAAI,CAAC,yBAAgB,CAAC,CAAC;IAC5B,CAAC;IAES,KAAK,CAAC,YAAY,CAC1B,MAAmC;QAEnC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;QACpD,MAAM,iBAAiB,GAAG,MAAM,IAAA,yCAA0B,EACxD,UAAU,EACV,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,iBAAiB,CACzB,CAAC;QACF,MAAM,cAAc,GAAG,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,aAAa,CAAC;QACrE,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,aAAa,EAAE,IAAI,SAAE,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;YACtD,cAAc,EAAE,IAAI,SAAE,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;YACjD,iBAAiB;YACjB,aAAa,EAAE,IAAA,sBAAa,EAC1B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,KAAK,EACZ,iBAAiB,EACjB,IAAI,CACL;YACD,eAAe,EAAE,IAAA,sBAAa,EAC5B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,OAAO,EACd,iBAAiB,CAClB;SACF,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,eAAe,CAAC,IAAiC;QAC/D,OAAO;YACL,6BAA6B,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;SAC1D,CAAC;IACJ,CAAC;CACF;AA5DD,oEA4DC"}
@@ -0,0 +1,12 @@
1
+ import { VaultBuilderBase } from "./base";
2
+ import type { ManagerWithdrawAssetIxArgs, ManagerWithdrawAssetTxArgs } from "./args";
3
+ export declare class ManagerWithdrawAssetBuilder extends VaultBuilderBase<ManagerWithdrawAssetIxArgs, ManagerWithdrawAssetTxArgs> {
4
+ getIx(args: ManagerWithdrawAssetIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
5
+ protected deriveIxArgs(txArgs: ManagerWithdrawAssetTxArgs): Promise<ManagerWithdrawAssetIxArgs>;
6
+ protected buildPlanExtras(args: ManagerWithdrawAssetIxArgs): Promise<{
7
+ postSuccessCacheInvalidations: {
8
+ vaultPda: import("@solana/kit").Address;
9
+ }[];
10
+ }>;
11
+ }
12
+ //# sourceMappingURL=managerWithdrawAsset.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"managerWithdrawAsset.d.ts","sourceRoot":"","sources":["../../../src/client/builders/managerWithdrawAsset.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,KAAK,EACV,0BAA0B,EAC1B,0BAA0B,EAC3B,MAAM,QAAQ,CAAC;AAGhB,qBAAa,2BAA4B,SAAQ,gBAAgB,CAC/D,0BAA0B,EAC1B,0BAA0B,CAC3B;IACO,KAAK,CAAC,IAAI,EAAE,0BAA0B;cAiB5B,YAAY,CAC1B,MAAM,EAAE,0BAA0B,GACjC,OAAO,CAAC,0BAA0B,CAAC;cA2BtB,eAAe,CAAC,IAAI,EAAE,0BAA0B;;;;;CAKjE"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ManagerWithdrawAssetBuilder = void 0;
4
+ const core_1 = require("@anchor-lang/core");
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
+ const base_1 = require("./base");
9
+ const trancheState_1 = require("./trancheState");
10
+ class ManagerWithdrawAssetBuilder extends base_1.VaultBuilderBase {
11
+ async getIx(args) {
12
+ return this.program.methods
13
+ .managerWithdrawAsset(args.amount)
14
+ .accountsPartial({
15
+ manager: (0, common_1.toWeb3Pk)(args.manager),
16
+ vault: (0, common_1.toWeb3Pk)(args.vault),
17
+ assetMint: (0, common_1.toWeb3Pk)(args.assetMint),
18
+ vaultAssetAta: (0, common_1.toWeb3Pk)(args.vaultAssetAta),
19
+ managerAssetAta: (0, common_1.toWeb3Pk)(args.managerAssetAta),
20
+ assetTokenProgram: (0, common_1.toWeb3Pk)(args.assetTokenProgram),
21
+ associatedTokenProgram: spl_token_1.ASSOCIATED_TOKEN_PROGRAM_ID,
22
+ systemProgram: web3_js_1.SystemProgram.programId,
23
+ })
24
+ .instruction()
25
+ .then(common_1.toKitInstruction);
26
+ }
27
+ async deriveIxArgs(txArgs) {
28
+ const connection = this.program.provider.connection;
29
+ const assetTokenProgram = await (0, trancheState_1.resolveTokenProgramForMint)(connection, txArgs.assetMint, txArgs.assetTokenProgram);
30
+ return {
31
+ manager: txArgs.manager,
32
+ vault: txArgs.vault,
33
+ assetMint: txArgs.assetMint,
34
+ amount: new core_1.BN(txArgs.amount.toString()),
35
+ assetTokenProgram,
36
+ vaultAssetAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.vault, assetTokenProgram, true),
37
+ managerAssetAta: (0, common_1.getAtaAddress)(txArgs.assetMint, txArgs.manager, assetTokenProgram),
38
+ };
39
+ }
40
+ async buildPlanExtras(args) {
41
+ return {
42
+ postSuccessCacheInvalidations: [{ vaultPda: args.vault }],
43
+ };
44
+ }
45
+ }
46
+ exports.ManagerWithdrawAssetBuilder = ManagerWithdrawAssetBuilder;
47
+ //# sourceMappingURL=managerWithdrawAsset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"managerWithdrawAsset.js","sourceRoot":"","sources":["../../../src/client/builders/managerWithdrawAsset.ts"],"names":[],"mappings":";;;AAAA,4CAAuC;AACvC,iDAAgE;AAChE,6CAAgD;AAChD,mCAAmE;AAEnE,iCAA0C;AAK1C,iDAA4D;AAE5D,MAAa,2BAA4B,SAAQ,uBAGhD;IACC,KAAK,CAAC,KAAK,CAAC,IAAgC;QAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO;aACxB,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC;aACjC,eAAe,CAAC;YACf,OAAO,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,OAAO,CAAC;YAC/B,KAAK,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,KAAK,CAAC;YAC3B,SAAS,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,SAAS,CAAC;YACnC,aAAa,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,aAAa,CAAC;YAC3C,eAAe,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,eAAe,CAAC;YAC/C,iBAAiB,EAAE,IAAA,iBAAQ,EAAC,IAAI,CAAC,iBAAiB,CAAC;YACnD,sBAAsB,EAAE,uCAA2B;YACnD,aAAa,EAAE,uBAAa,CAAC,SAAS;SACvC,CAAC;aACD,WAAW,EAAE;aACb,IAAI,CAAC,yBAAgB,CAAC,CAAC;IAC5B,CAAC;IAES,KAAK,CAAC,YAAY,CAC1B,MAAkC;QAElC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC;QACpD,MAAM,iBAAiB,GAAG,MAAM,IAAA,yCAA0B,EACxD,UAAU,EACV,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,iBAAiB,CACzB,CAAC;QACF,OAAO;YACL,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,MAAM,EAAE,IAAI,SAAE,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACxC,iBAAiB;YACjB,aAAa,EAAE,IAAA,sBAAa,EAC1B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,KAAK,EACZ,iBAAiB,EACjB,IAAI,CACL;YACD,eAAe,EAAE,IAAA,sBAAa,EAC5B,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,OAAO,EACd,iBAAiB,CAClB;SACF,CAAC;IACJ,CAAC;IAES,KAAK,CAAC,eAAe,CAAC,IAAgC;QAC9D,OAAO;YACL,6BAA6B,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;SAC1D,CAAC;IACJ,CAAC;CACF;AAvDD,kEAuDC"}
@@ -0,0 +1,22 @@
1
+ import { type Address } from "@solana/kit";
2
+ import type { VaultTransactionPlan } from "../types/tx";
3
+ import { VaultBuilderBase } from "./base";
4
+ import type { JupiterSwapIxArgs, JupiterSwapTxArgs, ProtocolInteractionIxArgs, ProtocolInteractionTxArgs } from "./args";
5
+ export declare class ProtocolInteractionBuilder extends VaultBuilderBase<ProtocolInteractionIxArgs, ProtocolInteractionTxArgs> {
6
+ getIx(args: ProtocolInteractionIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
7
+ protected deriveIxArgs(txArgs: ProtocolInteractionTxArgs): Promise<ProtocolInteractionIxArgs>;
8
+ protected buildLookupTables(_args: ProtocolInteractionIxArgs, txArgs: ProtocolInteractionTxArgs): Promise<readonly Address[] | undefined>;
9
+ }
10
+ export declare class JupiterSwapBuilder extends VaultBuilderBase<JupiterSwapIxArgs, JupiterSwapTxArgs> {
11
+ getIx(args: JupiterSwapIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>>;
12
+ protected deriveIxArgs(txArgs: JupiterSwapTxArgs): Promise<JupiterSwapIxArgs>;
13
+ protected buildPreambleInstructions(args: JupiterSwapIxArgs): Promise<import("@solana/kit").Instruction<string, readonly (import("@solana/kit").AccountLookupMeta<string, string> | import("@solana/kit").AccountMeta<string>)[]>[]>;
14
+ protected buildLookupTables(_args: JupiterSwapIxArgs, txArgs: JupiterSwapTxArgs): Promise<readonly Address[] | undefined>;
15
+ protected buildPlanExtras(args: JupiterSwapIxArgs): Promise<{
16
+ postSuccessCacheInvalidations: {
17
+ vaultPda: Address;
18
+ }[];
19
+ }>;
20
+ getTx(txArgs: JupiterSwapTxArgs): Promise<VaultTransactionPlan>;
21
+ }
22
+ //# sourceMappingURL=protocolInteraction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"protocolInteraction.d.ts","sourceRoot":"","sources":["../../../src/client/builders/protocolInteraction.ts"],"names":[],"mappings":"AACA,OAAO,EAAe,KAAK,OAAO,EAAE,MAAM,aAAa,CAAC;AAiBxD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,KAAK,EAGV,iBAAiB,EACjB,iBAAiB,EACjB,yBAAyB,EACzB,yBAAyB,EAC1B,MAAM,QAAQ,CAAC;AAuChB,qBAAa,0BAA2B,SAAQ,gBAAgB,CAC9D,yBAAyB,EACzB,yBAAyB,CAC1B;IACO,KAAK,CAAC,IAAI,EAAE,yBAAyB;cA0B3B,YAAY,CAC1B,MAAM,EAAE,yBAAyB,GAChC,OAAO,CAAC,yBAAyB,CAAC;cAwBrB,iBAAiB,CAC/B,KAAK,EAAE,yBAAyB,EAChC,MAAM,EAAE,yBAAyB,GAChC,OAAO,CAAC,SAAS,OAAO,EAAE,GAAG,SAAS,CAAC;CAG3C;AAED,qBAAa,kBAAmB,SAAQ,gBAAgB,CACtD,iBAAiB,EACjB,iBAAiB,CAClB;IACO,KAAK,CAAC,IAAI,EAAE,iBAAiB;cA0BnB,YAAY,CAC1B,MAAM,EAAE,iBAAiB,GACxB,OAAO,CAAC,iBAAiB,CAAC;cAkCJ,yBAAyB,CAAC,IAAI,EAAE,iBAAiB;cAsB1D,iBAAiB,CAC/B,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,iBAAiB,GACxB,OAAO,CAAC,SAAS,OAAO,EAAE,GAAG,SAAS,CAAC;cAI1B,eAAe,CAAC,IAAI,EAAE,iBAAiB;;;;;IAMjD,KAAK,CAAC,MAAM,EAAE,iBAAiB,GAAG,OAAO,CAAC,oBAAoB,CAAC;CAYtE"}