@affluent-org/sdk 0.0.1

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 (218) hide show
  1. package/.prettierrc +11 -0
  2. package/Refactoring.md +548 -0
  3. package/dist/_compiled/Account.compiled.json +1 -0
  4. package/dist/_compiled/Receipt.compiled.json +1 -0
  5. package/dist/_compiled/WTONWallet.compiled.json +1 -0
  6. package/dist/_compiled/index.d.ts +4 -0
  7. package/dist/_compiled/index.js +12 -0
  8. package/dist/affluent.d.ts +14 -0
  9. package/dist/affluent.js +20 -0
  10. package/dist/constants/constants.d.ts +2 -0
  11. package/dist/constants/constants.js +5 -0
  12. package/dist/constants/contracts.d.ts +9 -0
  13. package/dist/constants/contracts.js +18 -0
  14. package/dist/context.d.ts +43 -0
  15. package/dist/context.js +90 -0
  16. package/dist/contracts/common/type.d.ts +16 -0
  17. package/dist/contracts/common/type.js +2 -0
  18. package/dist/contracts/common/utils.d.ts +3 -0
  19. package/dist/contracts/common/utils.js +16 -0
  20. package/dist/contracts/core/account/index.d.ts +38 -0
  21. package/dist/contracts/core/account/index.js +128 -0
  22. package/dist/contracts/core/account/type.d.ts +18 -0
  23. package/dist/contracts/core/account/type.js +2 -0
  24. package/dist/contracts/core/pool/index.d.ts +149 -0
  25. package/dist/contracts/core/pool/index.js +379 -0
  26. package/dist/contracts/core/pool/serializer.d.ts +15 -0
  27. package/dist/contracts/core/pool/serializer.js +307 -0
  28. package/dist/contracts/core/pool/type.d.ts +136 -0
  29. package/dist/contracts/core/pool/type.js +2 -0
  30. package/dist/contracts/dedust-farm/MockDedustFarm.d.ts +41 -0
  31. package/dist/contracts/dedust-farm/MockDedustFarm.js +79 -0
  32. package/dist/contracts/external/tonstaker.d.ts +18 -0
  33. package/dist/contracts/external/tonstaker.js +26 -0
  34. package/dist/contracts/factory/factory.d.ts +24 -0
  35. package/dist/contracts/factory/factory.js +58 -0
  36. package/dist/contracts/factory/type.d.ts +11 -0
  37. package/dist/contracts/factory/type.js +2 -0
  38. package/dist/contracts/farm/distributor.d.ts +43 -0
  39. package/dist/contracts/farm/distributor.js +83 -0
  40. package/dist/contracts/farm/receipt.d.ts +40 -0
  41. package/dist/contracts/farm/receipt.js +68 -0
  42. package/dist/contracts/irm/jump-irm/serializer.d.ts +4 -0
  43. package/dist/contracts/irm/jump-irm/serializer.js +26 -0
  44. package/dist/contracts/irm/jump-irm/type.d.ts +8 -0
  45. package/dist/contracts/irm/jump-irm/type.js +2 -0
  46. package/dist/contracts/jetton/jetton-minter.d.ts +23 -0
  47. package/dist/contracts/jetton/jetton-minter.js +46 -0
  48. package/dist/contracts/jetton/jetton-wallet.d.ts +67 -0
  49. package/dist/contracts/jetton/jetton-wallet.js +119 -0
  50. package/dist/contracts/jetton/type.d.ts +7 -0
  51. package/dist/contracts/jetton/type.js +2 -0
  52. package/dist/contracts/liquid_token/dedust/minter.d.ts +56 -0
  53. package/dist/contracts/liquid_token/dedust/minter.js +112 -0
  54. package/dist/contracts/liquid_token/dedust/wallet.d.ts +127 -0
  55. package/dist/contracts/liquid_token/dedust/wallet.js +213 -0
  56. package/dist/contracts/liquid_token/stonfi/LFStonfiJettonMinter.d.ts +53 -0
  57. package/dist/contracts/liquid_token/stonfi/LFStonfiJettonMinter.js +110 -0
  58. package/dist/contracts/liquid_token/stonfi/LFStonfiJettonWallet.d.ts +169 -0
  59. package/dist/contracts/liquid_token/stonfi/LFStonfiJettonWallet.js +288 -0
  60. package/dist/contracts/oracle/composite-onchain-oracle/index.d.ts +108 -0
  61. package/dist/contracts/oracle/composite-onchain-oracle/index.js +185 -0
  62. package/dist/contracts/oracle/parser.d.ts +7 -0
  63. package/dist/contracts/oracle/parser.js +77 -0
  64. package/dist/contracts/oracle/redstone-onchain-oracle/index.d.ts +56 -0
  65. package/dist/contracts/oracle/redstone-onchain-oracle/index.js +159 -0
  66. package/dist/contracts/oracle/redstone-onchain-oracle/serializer.d.ts +4 -0
  67. package/dist/contracts/oracle/redstone-onchain-oracle/serializer.js +137 -0
  68. package/dist/contracts/oracle/redstone-onchain-oracle/type.d.ts +57 -0
  69. package/dist/contracts/oracle/redstone-onchain-oracle/type.js +18 -0
  70. package/dist/contracts/oracle/redstone-oracle/serializer.d.ts +3 -0
  71. package/dist/contracts/oracle/redstone-oracle/serializer.js +30 -0
  72. package/dist/contracts/oracle/redstone-oracle/type.d.ts +9 -0
  73. package/dist/contracts/oracle/redstone-oracle/type.js +2 -0
  74. package/dist/contracts/oracle/redstone-parser.d.ts +9 -0
  75. package/dist/contracts/oracle/redstone-parser.js +58 -0
  76. package/dist/contracts/rfq/rfq_auction/index.d.ts +216 -0
  77. package/dist/contracts/rfq/rfq_auction/index.js +334 -0
  78. package/dist/contracts/rfq/rfq_batch/index.d.ts +346 -0
  79. package/dist/contracts/rfq/rfq_batch/index.js +448 -0
  80. package/dist/contracts/rfq/rfq_event_emitter/index.d.ts +132 -0
  81. package/dist/contracts/rfq/rfq_event_emitter/index.js +143 -0
  82. package/dist/contracts/stonfi-farm/MockStonfiFarmItem.d.ts +41 -0
  83. package/dist/contracts/stonfi-farm/MockStonfiFarmItem.js +83 -0
  84. package/dist/contracts/stonfi-farm/MockStonfiFarmMinter.d.ts +45 -0
  85. package/dist/contracts/stonfi-farm/MockStonfiFarmMinter.js +92 -0
  86. package/dist/contracts/unknown-contract/index.d.ts +14 -0
  87. package/dist/contracts/unknown-contract/index.js +18 -0
  88. package/dist/contracts/vault/share-vault/index.d.ts +206 -0
  89. package/dist/contracts/vault/share-vault/index.js +373 -0
  90. package/dist/contracts/vault/strategy-vault/codec.d.ts +710 -0
  91. package/dist/contracts/vault/strategy-vault/codec.js +1256 -0
  92. package/dist/contracts/vault/strategy-vault/computation.d.ts +11 -0
  93. package/dist/contracts/vault/strategy-vault/computation.js +56 -0
  94. package/dist/contracts/vault/strategy-vault/constants.d.ts +163 -0
  95. package/dist/contracts/vault/strategy-vault/constants.js +170 -0
  96. package/dist/contracts/vault/strategy-vault/index.d.ts +587 -0
  97. package/dist/contracts/vault/strategy-vault/index.js +406 -0
  98. package/dist/contracts/vault/strategy-vault/type.d.ts +115 -0
  99. package/dist/contracts/vault/strategy-vault/type.js +2 -0
  100. package/dist/contracts/wton/jetton-minter.d.ts +35 -0
  101. package/dist/contracts/wton/jetton-minter.js +71 -0
  102. package/dist/contracts/wton/jetton-wallet.d.ts +90 -0
  103. package/dist/contracts/wton/jetton-wallet.js +153 -0
  104. package/dist/contracts/wton/type.d.ts +7 -0
  105. package/dist/contracts/wton/type.js +2 -0
  106. package/dist/index.d.ts +34 -0
  107. package/dist/index.js +65 -0
  108. package/dist/lib/assert.d.ts +1 -0
  109. package/dist/lib/assert.js +9 -0
  110. package/dist/lib/query-cache.d.ts +5 -0
  111. package/dist/lib/query-cache.js +57 -0
  112. package/dist/lib/send-msg.d.ts +11 -0
  113. package/dist/lib/send-msg.js +9 -0
  114. package/dist/services/composite-oracle/computation.d.ts +55 -0
  115. package/dist/services/composite-oracle/computation.js +295 -0
  116. package/dist/services/composite-oracle/index.d.ts +45 -0
  117. package/dist/services/composite-oracle/index.js +110 -0
  118. package/dist/services/composite-oracle/query.d.ts +36 -0
  119. package/dist/services/composite-oracle/query.js +251 -0
  120. package/dist/services/composite-oracle/types.d.ts +82 -0
  121. package/dist/services/composite-oracle/types.js +11 -0
  122. package/dist/services/pool/computation.d.ts +75 -0
  123. package/dist/services/pool/computation.js +219 -0
  124. package/dist/services/pool/index.d.ts +94 -0
  125. package/dist/services/pool/index.js +139 -0
  126. package/dist/services/pool/oracle.d.ts +20 -0
  127. package/dist/services/pool/oracle.js +61 -0
  128. package/dist/services/pool/owner/index.d.ts +37 -0
  129. package/dist/services/pool/owner/index.js +76 -0
  130. package/dist/services/pool/owner/types.d.ts +18 -0
  131. package/dist/services/pool/owner/types.js +2 -0
  132. package/dist/services/pool/query.d.ts +64 -0
  133. package/dist/services/pool/query.js +282 -0
  134. package/dist/services/pool/user/index.d.ts +86 -0
  135. package/dist/services/pool/user/index.js +285 -0
  136. package/dist/services/pool/user/types.d.ts +44 -0
  137. package/dist/services/pool/user/types.js +2 -0
  138. package/dist/services/rfq-auction/index.d.ts +81 -0
  139. package/dist/services/rfq-auction/index.js +93 -0
  140. package/dist/services/rfq-auction/oracle.d.ts +19 -0
  141. package/dist/services/rfq-auction/oracle.js +60 -0
  142. package/dist/services/rfq-auction/query.d.ts +50 -0
  143. package/dist/services/rfq-auction/query.js +19 -0
  144. package/dist/services/rfq-auction/user/index.d.ts +63 -0
  145. package/dist/services/rfq-auction/user/index.js +218 -0
  146. package/dist/services/rfq-auction/user/types.d.ts +29 -0
  147. package/dist/services/rfq-auction/user/types.js +2 -0
  148. package/dist/services/rfq-batch/index.d.ts +78 -0
  149. package/dist/services/rfq-batch/index.js +132 -0
  150. package/dist/services/rfq-batch/oracle.d.ts +22 -0
  151. package/dist/services/rfq-batch/oracle.js +54 -0
  152. package/dist/services/rfq-batch/query.d.ts +46 -0
  153. package/dist/services/rfq-batch/query.js +34 -0
  154. package/dist/services/rfq-batch/user/index.d.ts +79 -0
  155. package/dist/services/rfq-batch/user/index.js +171 -0
  156. package/dist/services/rfq-batch/user/types.d.ts +37 -0
  157. package/dist/services/rfq-batch/user/types.js +2 -0
  158. package/dist/services/share-vault/computation.d.ts +24 -0
  159. package/dist/services/share-vault/computation.js +42 -0
  160. package/dist/services/share-vault/index.d.ts +90 -0
  161. package/dist/services/share-vault/index.js +128 -0
  162. package/dist/services/share-vault/manager/index.d.ts +40 -0
  163. package/dist/services/share-vault/manager/index.js +111 -0
  164. package/dist/services/share-vault/manager/types.d.ts +23 -0
  165. package/dist/services/share-vault/manager/types.js +2 -0
  166. package/dist/services/share-vault/owner/index.d.ts +64 -0
  167. package/dist/services/share-vault/owner/index.js +122 -0
  168. package/dist/services/share-vault/owner/types.d.ts +33 -0
  169. package/dist/services/share-vault/owner/types.js +2 -0
  170. package/dist/services/share-vault/query.d.ts +34 -0
  171. package/dist/services/share-vault/query.js +138 -0
  172. package/dist/services/share-vault/user/index.d.ts +33 -0
  173. package/dist/services/share-vault/user/index.js +106 -0
  174. package/dist/services/share-vault/user/types.d.ts +13 -0
  175. package/dist/services/share-vault/user/types.js +2 -0
  176. package/dist/services/strategy-vault/index.d.ts +2124 -0
  177. package/dist/services/strategy-vault/index.js +268 -0
  178. package/dist/services/strategy-vault/manager/index.d.ts +1968 -0
  179. package/dist/services/strategy-vault/manager/index.js +475 -0
  180. package/dist/services/strategy-vault/manager/types.d.ts +144 -0
  181. package/dist/services/strategy-vault/manager/types.js +2 -0
  182. package/dist/services/strategy-vault/oracle.d.ts +66 -0
  183. package/dist/services/strategy-vault/oracle.js +162 -0
  184. package/dist/services/strategy-vault/owner/index.d.ts +277 -0
  185. package/dist/services/strategy-vault/owner/index.js +333 -0
  186. package/dist/services/strategy-vault/owner/types.d.ts +146 -0
  187. package/dist/services/strategy-vault/owner/types.js +2 -0
  188. package/dist/services/strategy-vault/query.d.ts +138 -0
  189. package/dist/services/strategy-vault/query.js +59 -0
  190. package/dist/services/strategy-vault/user/index.d.ts +89 -0
  191. package/dist/services/strategy-vault/user/index.js +219 -0
  192. package/dist/services/strategy-vault/user/types.d.ts +46 -0
  193. package/dist/services/strategy-vault/user/types.js +2 -0
  194. package/dist/types/sender.d.ts +7 -0
  195. package/dist/types/sender.js +2 -0
  196. package/dist/utils/action-parser.d.ts +7 -0
  197. package/dist/utils/action-parser.js +20 -0
  198. package/dist/utils/external-message-hash.d.ts +45 -0
  199. package/dist/utils/external-message-hash.js +65 -0
  200. package/dist/utils/oracle/redstone/readonlyCachedRedstone.d.ts +3 -0
  201. package/dist/utils/oracle/redstone/readonlyCachedRedstone.js +25 -0
  202. package/dist/utils/oracle/redstone/redstoneHelper.d.ts +21 -0
  203. package/dist/utils/oracle/redstone/redstoneHelper.js +228 -0
  204. package/dist/utils/parser.d.ts +40 -0
  205. package/dist/utils/parser.js +580 -0
  206. package/dist/utils/pending-tracker/index.d.ts +14 -0
  207. package/dist/utils/pending-tracker/index.js +34 -0
  208. package/dist/utils/pending-tracker/trackable-sender.d.ts +16 -0
  209. package/dist/utils/pending-tracker/trackable-sender.js +87 -0
  210. package/dist/utils/pending-tracker/type.d.ts +78 -0
  211. package/dist/utils/pending-tracker/type.js +2 -0
  212. package/dist/utils/pending-tracker/v3-client.d.ts +31 -0
  213. package/dist/utils/pending-tracker/v3-client.js +104 -0
  214. package/dist/utils/risk_calculator/risk_calculator.d.ts +45 -0
  215. package/dist/utils/risk_calculator/risk_calculator.js +332 -0
  216. package/dist/utils/utils.d.ts +5 -0
  217. package/dist/utils/utils.js +12 -0
  218. package/package.json +46 -0
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,23 @@
1
+ import { Address, Cell, Contract, ContractProvider, OpenedContract } from "@ton/ton";
2
+ import { JettonWallet } from "./jetton-wallet";
3
+ import { AddressInput } from "../common/type";
4
+ export declare class JettonMinter implements Contract {
5
+ readonly address: Address;
6
+ readonly init?: {
7
+ code: Cell;
8
+ data: Cell;
9
+ } | undefined;
10
+ constructor(address: Address, init?: {
11
+ code: Cell;
12
+ data: Cell;
13
+ } | undefined);
14
+ static createFromAddress(address: Address): JettonMinter;
15
+ getState(provider: ContractProvider): Promise<import("@ton/ton").ContractState>;
16
+ getWalletAddress(provider: ContractProvider, address: Address): Promise<Address>;
17
+ getJettonData(provider: ContractProvider): Promise<{
18
+ totalSupply: bigint;
19
+ admin: Address;
20
+ content: string | null;
21
+ }>;
22
+ getWallet(provider: ContractProvider, address: AddressInput): Promise<OpenedContract<JettonWallet>>;
23
+ }
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JettonMinter = void 0;
4
+ const ton_1 = require("@ton/ton");
5
+ const jetton_wallet_1 = require("./jetton-wallet");
6
+ const utils_1 = require("../common/utils");
7
+ class JettonMinter {
8
+ address;
9
+ init;
10
+ constructor(address, init) {
11
+ this.address = address;
12
+ this.init = init;
13
+ }
14
+ static createFromAddress(address) {
15
+ return new JettonMinter(address);
16
+ }
17
+ async getState(provider) {
18
+ return await provider.getState();
19
+ }
20
+ async getWalletAddress(provider, address) {
21
+ const result = await provider.get("get_wallet_address", [
22
+ {
23
+ type: "slice",
24
+ cell: (0, ton_1.beginCell)().storeAddress(address).endCell(),
25
+ },
26
+ ]);
27
+ return result.stack.readAddress();
28
+ }
29
+ async getJettonData(provider) {
30
+ const _result = await provider.get("get_jetton_data", []);
31
+ const totalSupply = _result.stack.readBigNumber();
32
+ _result.stack.readBigNumber();
33
+ const admin = _result.stack.readAddress();
34
+ const content = _result.stack.readStringOpt();
35
+ return {
36
+ totalSupply,
37
+ admin,
38
+ content,
39
+ };
40
+ }
41
+ async getWallet(provider, address) {
42
+ const walletAddress = await this.getWalletAddress(provider, (0, utils_1.toAddress)(address));
43
+ return provider.open(jetton_wallet_1.JettonWallet.createFromAddress(walletAddress));
44
+ }
45
+ }
46
+ exports.JettonMinter = JettonMinter;
@@ -0,0 +1,67 @@
1
+ import { Address, Cell, Contract, ContractProvider, Sender } from "@ton/ton";
2
+ import { WalletState } from "./type";
3
+ export declare class JettonWallet implements Contract {
4
+ readonly address: Address;
5
+ readonly init?: {
6
+ code: Cell;
7
+ data: Cell;
8
+ } | undefined;
9
+ constructor(address: Address, init?: {
10
+ code: Cell;
11
+ data: Cell;
12
+ } | undefined);
13
+ static Op: {
14
+ TransferNotification: number;
15
+ InternalTransfer: number;
16
+ Transfer: number;
17
+ Burn: number;
18
+ Excesses: number;
19
+ BurnNotification: number;
20
+ };
21
+ static Gas: {
22
+ Transfer: bigint;
23
+ };
24
+ static createFromAddress(address: Address): JettonWallet;
25
+ sendTransfer(provider: ContractProvider, via: Sender, value: bigint, opts: {
26
+ amount: bigint;
27
+ recipient: Address;
28
+ response: Address;
29
+ forwardTonAmount: bigint;
30
+ forwardPayload?: Cell;
31
+ queryId?: bigint;
32
+ }): Promise<Cell>;
33
+ createTransferBody(opts: {
34
+ queryId?: bigint;
35
+ recipient: Address;
36
+ response: Address;
37
+ amount: bigint;
38
+ forwardTonAmount: bigint;
39
+ forwardPayload?: Cell;
40
+ }): Cell;
41
+ static createTransferBody(opts: {
42
+ queryId?: bigint;
43
+ recipient: Address;
44
+ response: Address;
45
+ amount: bigint;
46
+ forwardTonAmount: bigint;
47
+ forwardPayload?: Cell;
48
+ }): Cell;
49
+ static getBurnMsgBody(opts: {
50
+ amount: bigint;
51
+ response: Address;
52
+ }): Cell;
53
+ sendBurn(provider: ContractProvider, via: Sender, value: bigint, opts: {
54
+ amount: bigint;
55
+ response: Address;
56
+ forwardPayload?: Cell;
57
+ queryId?: bigint;
58
+ }): Promise<Cell>;
59
+ getState(provider: ContractProvider): Promise<import("@ton/ton").ContractState>;
60
+ getWalletData(provider: ContractProvider): Promise<WalletState>;
61
+ createBurnBody(opts: {
62
+ amount: bigint;
63
+ response: Address;
64
+ forwardPayload?: Cell;
65
+ queryId?: bigint;
66
+ }): Cell;
67
+ }
@@ -0,0 +1,119 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JettonWallet = void 0;
4
+ const ton_1 = require("@ton/ton");
5
+ class JettonWallet {
6
+ address;
7
+ init;
8
+ constructor(address, init) {
9
+ this.address = address;
10
+ this.init = init;
11
+ }
12
+ static Op = {
13
+ TransferNotification: 0x7362d09c,
14
+ InternalTransfer: 0x178d4519,
15
+ Transfer: 0xf8a7ea5,
16
+ Burn: 0x595f07bc,
17
+ Excesses: 0xd53276db,
18
+ BurnNotification: 0x7bdd97de,
19
+ };
20
+ static Gas = {
21
+ Transfer: (0, ton_1.toNano)(0.05),
22
+ };
23
+ static createFromAddress(address) {
24
+ return new JettonWallet(address);
25
+ }
26
+ async sendTransfer(provider, via, value, opts) {
27
+ const body = (0, ton_1.beginCell)()
28
+ .storeUint(JettonWallet.Op.Transfer, 32)
29
+ .storeUint(opts.queryId ?? 0, 64)
30
+ .storeCoins(opts.amount)
31
+ .storeAddress(opts.recipient)
32
+ .storeAddress(opts.response)
33
+ .storeDict(null)
34
+ .storeCoins(opts.forwardTonAmount)
35
+ .storeMaybeRef(opts.forwardPayload)
36
+ .endCell();
37
+ await provider.internal(via, {
38
+ value: value,
39
+ sendMode: ton_1.SendMode.PAY_GAS_SEPARATELY,
40
+ body: body,
41
+ });
42
+ return body;
43
+ }
44
+ createTransferBody(opts) {
45
+ const body = (0, ton_1.beginCell)()
46
+ .storeUint(JettonWallet.Op.Transfer, 32)
47
+ .storeUint(opts.queryId ?? 0, 64)
48
+ .storeCoins(opts.amount)
49
+ .storeAddress(opts.recipient)
50
+ .storeAddress(opts.response)
51
+ .storeDict(null)
52
+ .storeCoins(opts.forwardTonAmount)
53
+ .storeMaybeRef(opts.forwardPayload)
54
+ .endCell();
55
+ return body;
56
+ }
57
+ static createTransferBody(opts) {
58
+ const body = (0, ton_1.beginCell)()
59
+ .storeUint(JettonWallet.Op.Transfer, 32)
60
+ .storeUint(opts.queryId ?? 0, 64)
61
+ .storeCoins(opts.amount)
62
+ .storeAddress(opts.recipient)
63
+ .storeAddress(opts.response)
64
+ .storeDict(null)
65
+ .storeCoins(opts.forwardTonAmount)
66
+ .storeMaybeRef(opts.forwardPayload)
67
+ .endCell();
68
+ return body;
69
+ }
70
+ static getBurnMsgBody(opts) {
71
+ const body = (0, ton_1.beginCell)()
72
+ .storeUint(JettonWallet.Op.Burn, 32)
73
+ .storeUint(0, 64)
74
+ .storeCoins(opts.amount)
75
+ .storeAddress(opts.response)
76
+ .endCell();
77
+ return body;
78
+ }
79
+ async sendBurn(provider, via, value, opts) {
80
+ const body = (0, ton_1.beginCell)()
81
+ .storeUint(JettonWallet.Op.Burn, 32)
82
+ .storeUint(opts.queryId ?? 0, 64)
83
+ .storeCoins(opts.amount)
84
+ .storeAddress(opts.response)
85
+ .storeMaybeRef(opts.forwardPayload)
86
+ .endCell();
87
+ await provider.internal(via, {
88
+ value: value,
89
+ sendMode: ton_1.SendMode.PAY_GAS_SEPARATELY,
90
+ body: body,
91
+ });
92
+ return body;
93
+ }
94
+ async getState(provider) {
95
+ return await provider.getState();
96
+ }
97
+ async getWalletData(provider) {
98
+ const _result = await provider.get("get_wallet_data", []);
99
+ const balance = _result.stack.readBigNumber();
100
+ const owner = _result.stack.readAddress();
101
+ const jetton = _result.stack.readAddress();
102
+ return {
103
+ address: this.address,
104
+ balance,
105
+ owner,
106
+ jetton,
107
+ };
108
+ }
109
+ createBurnBody(opts) {
110
+ return (0, ton_1.beginCell)()
111
+ .storeUint(JettonWallet.Op.Burn, 32)
112
+ .storeUint(opts.queryId ?? 0, 64)
113
+ .storeCoins(opts.amount)
114
+ .storeAddress(opts.response)
115
+ .storeMaybeRef(opts.forwardPayload ?? null)
116
+ .endCell();
117
+ }
118
+ }
119
+ exports.JettonWallet = JettonWallet;
@@ -0,0 +1,7 @@
1
+ import { Address } from "@ton/core";
2
+ export type WalletState = {
3
+ address: Address;
4
+ balance: bigint;
5
+ owner: Address;
6
+ jetton: Address;
7
+ };
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,56 @@
1
+ import { Address, Cell, Contract, ContractProvider, Sender } from "@ton/core";
2
+ export type JettonMinterConfig = {
3
+ admin: Address;
4
+ content?: Cell;
5
+ walletCode: Cell;
6
+ asset: Address;
7
+ pool: Address;
8
+ };
9
+ export type JettonMinterContent = {
10
+ type: 0 | 1;
11
+ uri: string;
12
+ };
13
+ export declare function jettonContentToCell(content: JettonMinterContent): Cell;
14
+ export declare function jettonMinterConfigToCell(config: JettonMinterConfig): Cell;
15
+ export declare const Opcodes: {
16
+ Mint: number;
17
+ InternalTransfer: number;
18
+ DeployWallet: number;
19
+ };
20
+ export declare class LFDedustJettonMinter implements Contract {
21
+ readonly address: Address;
22
+ readonly init?: {
23
+ code: Cell;
24
+ data: Cell;
25
+ } | undefined;
26
+ constructor(address: Address, init?: {
27
+ code: Cell;
28
+ data: Cell;
29
+ } | undefined);
30
+ static Op: {
31
+ Mint: number;
32
+ InternalTransfer: number;
33
+ DeployWallet: number;
34
+ };
35
+ static createFromAddress(address: Address): LFDedustJettonMinter;
36
+ static createFromConfig(config: JettonMinterConfig, code: Cell, workchain?: number): LFDedustJettonMinter;
37
+ sendDeploy(provider: ContractProvider, via: Sender, value: bigint): Promise<void>;
38
+ sendDeployWallet(provider: ContractProvider, via: Sender, opts: {
39
+ recipient: Address;
40
+ value: bigint;
41
+ opcode?: number;
42
+ queryId?: bigint;
43
+ }): Promise<void>;
44
+ getState(provider: ContractProvider): Promise<import("@ton/core").ContractState>;
45
+ getWLPJettonData(provider: ContractProvider): Promise<{
46
+ totalSupply: bigint;
47
+ adminAddress: Address;
48
+ assetAddress: Address;
49
+ poolAddress: Address;
50
+ }>;
51
+ getWalletAddress(provider: ContractProvider, address: Address): Promise<Address>;
52
+ getJettonData(provider: ContractProvider): Promise<{
53
+ totalSupply: bigint;
54
+ admin: Address;
55
+ }>;
56
+ }
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LFDedustJettonMinter = exports.Opcodes = void 0;
4
+ exports.jettonContentToCell = jettonContentToCell;
5
+ exports.jettonMinterConfigToCell = jettonMinterConfigToCell;
6
+ const core_1 = require("@ton/core");
7
+ function jettonContentToCell(content) {
8
+ return (0, core_1.beginCell)()
9
+ .storeUint(content.type, 8)
10
+ .storeStringTail(content.uri) //Snake logic under the hood
11
+ .endCell();
12
+ }
13
+ function jettonMinterConfigToCell(config) {
14
+ return (0, core_1.beginCell)()
15
+ .storeCoins(0)
16
+ .storeAddress(config.admin)
17
+ .storeAddress(config.asset)
18
+ .storeAddress(config.pool)
19
+ .storeRef(config.content ? config.content : (0, core_1.beginCell)().endCell())
20
+ .storeRef(config.walletCode)
21
+ .endCell();
22
+ }
23
+ exports.Opcodes = {
24
+ Mint: 0x1674b0a0,
25
+ InternalTransfer: 0x178d4519,
26
+ DeployWallet: 0x12171766,
27
+ };
28
+ class LFDedustJettonMinter {
29
+ address;
30
+ init;
31
+ constructor(address, init) {
32
+ this.address = address;
33
+ this.init = init;
34
+ }
35
+ static Op = {
36
+ Mint: 0x1674b0a0,
37
+ InternalTransfer: 0x178d4519,
38
+ DeployWallet: 0x12171766,
39
+ };
40
+ static createFromAddress(address) {
41
+ return new LFDedustJettonMinter(address);
42
+ }
43
+ static createFromConfig(config, code, workchain = 0) {
44
+ const data = jettonMinterConfigToCell(config);
45
+ const init = { code, data };
46
+ return new LFDedustJettonMinter((0, core_1.contractAddress)(workchain, init), init);
47
+ }
48
+ async sendDeploy(provider, via, value) {
49
+ await provider.internal(via, {
50
+ value,
51
+ sendMode: core_1.SendMode.PAY_GAS_SEPARATELY,
52
+ body: (0, core_1.beginCell)().endCell(),
53
+ });
54
+ }
55
+ async sendDeployWallet(provider, via, opts) {
56
+ await provider.internal(via, {
57
+ value: opts.value,
58
+ sendMode: core_1.SendMode.PAY_GAS_SEPARATELY,
59
+ body: (0, core_1.beginCell)()
60
+ .storeUint(opts.opcode ? opts.opcode : exports.Opcodes.DeployWallet, 32) // opcode
61
+ .storeUint(opts.queryId ?? 0, 64) // query id
62
+ .storeAddress(opts.recipient) //
63
+ .endCell(),
64
+ });
65
+ }
66
+ async getState(provider) {
67
+ return await provider.getState();
68
+ }
69
+ async getWLPJettonData(provider) {
70
+ const state = await provider.getState();
71
+ if (state.state.type !== "active")
72
+ throw "not active";
73
+ if (!state.state.data)
74
+ throw "not active";
75
+ const data = core_1.Cell.fromBoc(state.state.data)[0].beginParse();
76
+ const totalSupply = data.loadCoins(); // Load total supply
77
+ const adminAddress = data.loadAddress(); // Load admin address
78
+ const assetAddress = data.loadAddress(); // Load asset address
79
+ const poolAddress = data.loadAddress(); // Load pool address
80
+ const content = data.loadRef(); // Load content cell
81
+ const jettonWalletCode = data.loadRef(); // Load jetton wallet code cell
82
+ const dedustPoolWalletCode = data.loadRef(); // Load dedust pool wallet code cell
83
+ return {
84
+ totalSupply,
85
+ adminAddress,
86
+ assetAddress,
87
+ poolAddress,
88
+ // content,
89
+ // jettonWalletCode,
90
+ // dedustPoolWalletCode,
91
+ };
92
+ }
93
+ async getWalletAddress(provider, address) {
94
+ const tis = {
95
+ type: "slice",
96
+ cell: (0, core_1.beginCell)().storeAddress(address).endCell(),
97
+ };
98
+ const result = await provider.get("get_wallet_address", [tis]);
99
+ return result.stack.readAddress();
100
+ }
101
+ async getJettonData(provider) {
102
+ const _result = await provider.get("get_jetton_data", []);
103
+ const totalSupply = _result.stack.readBigNumber();
104
+ _result.stack.readBigNumber();
105
+ const admin = _result.stack.readAddress();
106
+ return {
107
+ totalSupply,
108
+ admin,
109
+ };
110
+ }
111
+ }
112
+ exports.LFDedustJettonMinter = LFDedustJettonMinter;
@@ -0,0 +1,127 @@
1
+ import { Address, Cell, Contract, ContractProvider, Sender } from "@ton/core";
2
+ export type JettonWalletConfig = {
3
+ owner: Address;
4
+ minter: Address;
5
+ lockedAsset: Address;
6
+ pool: Address;
7
+ };
8
+ export declare function jettonWalletConfigToCell(config: JettonWalletConfig): Cell;
9
+ export declare const Opcodes: {
10
+ Mint: number;
11
+ InternalTransfer: number;
12
+ Transfer: number;
13
+ Burn: number;
14
+ };
15
+ export declare class LFDedustJettonWallet implements Contract {
16
+ readonly address: Address;
17
+ readonly init?: {
18
+ code: Cell;
19
+ data: Cell;
20
+ } | undefined;
21
+ constructor(address: Address, init?: {
22
+ code: Cell;
23
+ data: Cell;
24
+ } | undefined);
25
+ static Op: {
26
+ Mint: number;
27
+ InternalTransfer: number;
28
+ Transfer: number;
29
+ Burn: number;
30
+ Initialize: number;
31
+ Seize: number;
32
+ SeizeInternal: number;
33
+ SeizeFail: number;
34
+ ConnectPoolAccount: number;
35
+ TransferNotification: number;
36
+ ClaimRewards: number;
37
+ WithdrawTons: number;
38
+ WithdrawJettons: number;
39
+ DedustClaim: number;
40
+ };
41
+ static Error: {
42
+ InvalidWalletAddress: number;
43
+ Unauthorized: number;
44
+ NotEnoughBalance: number;
45
+ NotEnoughLockedAssetBalance: number;
46
+ EnoughLockedAssetBalance: number;
47
+ };
48
+ static createFromAddress(address: Address): LFDedustJettonWallet;
49
+ static createFromConfig(config: JettonWalletConfig, code: Cell, workchain?: number): LFDedustJettonWallet;
50
+ sendDeploy(provider: ContractProvider, via: Sender, value: bigint): Promise<void>;
51
+ sendInitialize(provider: ContractProvider, via: Sender, value: bigint): Promise<void>;
52
+ sendConnectPoolAccount(provider: ContractProvider, via: Sender, value: bigint): Promise<void>;
53
+ sendTransfer(provider: ContractProvider, via: Sender, opts: {
54
+ notificationGas?: bigint;
55
+ recipient: Address;
56
+ response?: Address;
57
+ amount: bigint;
58
+ value: bigint;
59
+ additional?: Cell;
60
+ queryId?: number;
61
+ }): Promise<void>;
62
+ sendBurn(provider: ContractProvider, via: Sender, opts: {
63
+ amount: bigint;
64
+ value: bigint;
65
+ recipientAddress: Address;
66
+ responseAddress: Address;
67
+ opcode?: number;
68
+ queryId?: bigint;
69
+ }): Promise<void>;
70
+ sendSeize(provider: ContractProvider, via: Sender, opts: {
71
+ amount: bigint;
72
+ value: bigint;
73
+ targetAddress: Address;
74
+ responseAddress: Address;
75
+ opcode?: number;
76
+ queryId?: bigint;
77
+ }): Promise<void>;
78
+ sendClaimRewards(provider: ContractProvider, via: Sender, opts: {
79
+ value: bigint;
80
+ distributorAddress: Address;
81
+ proof: Cell;
82
+ queryId?: bigint;
83
+ }): Promise<void>;
84
+ sendWithdrawTons(provider: ContractProvider, via: Sender, opts: {
85
+ value: bigint;
86
+ queryId?: bigint;
87
+ }): Promise<void>;
88
+ sendWithdrawJettons(provider: ContractProvider, via: Sender, opts: {
89
+ queryId?: bigint;
90
+ value: bigint;
91
+ wallet: Address;
92
+ amount: bigint;
93
+ }): Promise<void>;
94
+ getState(provider: ContractProvider): Promise<import("@ton/core").ContractState>;
95
+ getWalletData(provider: ContractProvider): Promise<{
96
+ balance: bigint;
97
+ owner: Address;
98
+ jetton: Address;
99
+ } | {
100
+ balance: bigint;
101
+ owner?: undefined;
102
+ jetton?: undefined;
103
+ }>;
104
+ getLiquidFarmData(provider: ContractProvider): Promise<{
105
+ deployed: boolean;
106
+ balance: bigint;
107
+ lockedAssetBalance: bigint;
108
+ jettonAddress: Address;
109
+ assetWalletAddress: Address | null;
110
+ poolAccountAddress: Address | null;
111
+ connectedWithPoolAccount: boolean;
112
+ ownerAddress: Address;
113
+ assetAddress: Address;
114
+ poolAddress: Address;
115
+ } | {
116
+ deployed: boolean;
117
+ balance: bigint;
118
+ lockedAssetBalance: bigint;
119
+ jettonAddress?: undefined;
120
+ assetWalletAddress?: undefined;
121
+ poolAccountAddress?: undefined;
122
+ connectedWithPoolAccount?: undefined;
123
+ ownerAddress?: undefined;
124
+ assetAddress?: undefined;
125
+ poolAddress?: undefined;
126
+ }>;
127
+ }