stackswap-front-api-test-02 1.0.87 → 1.0.90

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 (102) hide show
  1. package/README.md +10 -10
  2. package/dist/esm/index.d.ts +84 -84
  3. package/dist/esm/index.js +143 -143
  4. package/dist/esm/stackswap/config.d.ts +114 -112
  5. package/dist/esm/stackswap/config.js +188 -185
  6. package/dist/esm/stackswap/config.js.map +1 -1
  7. package/dist/esm/stackswap/manager/farm.manager.d.ts +41 -41
  8. package/dist/esm/stackswap/manager/farm.manager.js +293 -293
  9. package/dist/esm/stackswap/manager/farm2.manager.d.ts +60 -60
  10. package/dist/esm/stackswap/manager/farm2.manager.js +403 -403
  11. package/dist/esm/stackswap/manager/governance.manager.d.ts +9 -9
  12. package/dist/esm/stackswap/manager/governance.manager.js +53 -53
  13. package/dist/esm/stackswap/manager/launchpad.manager.d.ts +13 -13
  14. package/dist/esm/stackswap/manager/launchpad.manager.js +147 -147
  15. package/dist/esm/stackswap/manager/lbtc.manager.d.ts +31 -31
  16. package/dist/esm/stackswap/manager/lbtc.manager.js +326 -326
  17. package/dist/esm/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
  18. package/dist/esm/stackswap/manager/lbtcstaking.manager.js +153 -0
  19. package/dist/esm/stackswap/manager/lbtcstaking.manager.js.map +1 -0
  20. package/dist/esm/stackswap/manager/multisig.manager.d.ts +11 -11
  21. package/dist/esm/stackswap/manager/multisig.manager.js +51 -51
  22. package/dist/esm/stackswap/manager/nft.manager.d.ts +52 -52
  23. package/dist/esm/stackswap/manager/nft.manager.js +243 -243
  24. package/dist/esm/stackswap/manager/nft.manager.js.map +1 -1
  25. package/dist/esm/stackswap/manager/operator.manager.d.ts +17 -17
  26. package/dist/esm/stackswap/manager/operator.manager.js +85 -85
  27. package/dist/esm/stackswap/manager/other.manager.d.ts +9 -9
  28. package/dist/esm/stackswap/manager/other.manager.js +47 -47
  29. package/dist/esm/stackswap/manager/pool.manager.d.ts +34 -34
  30. package/dist/esm/stackswap/manager/pool.manager.js +171 -171
  31. package/dist/esm/stackswap/manager/poxl.manager.d.ts +16 -16
  32. package/dist/esm/stackswap/manager/poxl.manager.js +71 -71
  33. package/dist/esm/stackswap/manager/staking.manager.d.ts +25 -25
  34. package/dist/esm/stackswap/manager/staking.manager.js +233 -233
  35. package/dist/esm/stackswap/manager/staking.manager.js.map +1 -1
  36. package/dist/esm/stackswap/manager/swap.manager.d.ts +39 -39
  37. package/dist/esm/stackswap/manager/swap.manager.js +332 -331
  38. package/dist/esm/stackswap/manager/swap.manager.js.map +1 -1
  39. package/dist/esm/stackswap/manager/token.manager.d.ts +31 -31
  40. package/dist/esm/stackswap/manager/token.manager.js +133 -133
  41. package/dist/esm/stackswap/util.d.ts +35 -35
  42. package/dist/esm/stackswap/util.js +201 -201
  43. package/dist/index.d.ts +84 -84
  44. package/dist/index.js +152 -152
  45. package/dist/index.umd.js +1 -1
  46. package/dist/stackswap/config.d.ts +114 -112
  47. package/dist/stackswap/config.js +193 -190
  48. package/dist/stackswap/config.js.map +1 -1
  49. package/dist/stackswap/manager/farm.manager.d.ts +41 -41
  50. package/dist/stackswap/manager/farm.manager.js +301 -301
  51. package/dist/stackswap/manager/farm2.manager.d.ts +60 -60
  52. package/dist/stackswap/manager/farm2.manager.js +410 -410
  53. package/dist/stackswap/manager/governance.manager.d.ts +9 -9
  54. package/dist/stackswap/manager/governance.manager.js +60 -60
  55. package/dist/stackswap/manager/launchpad.manager.d.ts +13 -13
  56. package/dist/stackswap/manager/launchpad.manager.js +151 -151
  57. package/dist/stackswap/manager/lbtc.manager.d.ts +31 -31
  58. package/dist/stackswap/manager/lbtc.manager.js +333 -333
  59. package/dist/stackswap/manager/lbtcstaking.manager.d.ts +26 -0
  60. package/dist/stackswap/manager/lbtcstaking.manager.js +160 -0
  61. package/dist/stackswap/manager/lbtcstaking.manager.js.map +1 -0
  62. package/dist/stackswap/manager/multisig.manager.d.ts +11 -11
  63. package/dist/stackswap/manager/multisig.manager.js +55 -55
  64. package/dist/stackswap/manager/nft.manager.d.ts +52 -52
  65. package/dist/stackswap/manager/nft.manager.js +250 -250
  66. package/dist/stackswap/manager/nft.manager.js.map +1 -1
  67. package/dist/stackswap/manager/operator.manager.d.ts +17 -17
  68. package/dist/stackswap/manager/operator.manager.js +92 -92
  69. package/dist/stackswap/manager/other.manager.d.ts +9 -9
  70. package/dist/stackswap/manager/other.manager.js +54 -54
  71. package/dist/stackswap/manager/pool.manager.d.ts +34 -34
  72. package/dist/stackswap/manager/pool.manager.js +179 -179
  73. package/dist/stackswap/manager/poxl.manager.d.ts +16 -16
  74. package/dist/stackswap/manager/poxl.manager.js +78 -78
  75. package/dist/stackswap/manager/staking.manager.d.ts +25 -25
  76. package/dist/stackswap/manager/staking.manager.js +240 -240
  77. package/dist/stackswap/manager/staking.manager.js.map +1 -1
  78. package/dist/stackswap/manager/swap.manager.d.ts +39 -39
  79. package/dist/stackswap/manager/swap.manager.js +339 -338
  80. package/dist/stackswap/manager/swap.manager.js.map +1 -1
  81. package/dist/stackswap/manager/token.manager.d.ts +31 -31
  82. package/dist/stackswap/manager/token.manager.js +141 -141
  83. package/dist/stackswap/util.d.ts +35 -35
  84. package/dist/stackswap/util.js +218 -218
  85. package/package.json +43 -43
  86. package/src/index.ts +204 -204
  87. package/src/stackswap/config.ts +297 -292
  88. package/src/stackswap/manager/farm.manager.ts +399 -399
  89. package/src/stackswap/manager/farm2.manager.ts +463 -463
  90. package/src/stackswap/manager/governance.manager.ts +95 -95
  91. package/src/stackswap/manager/launchpad.manager.ts +190 -190
  92. package/src/stackswap/manager/lbtcstaking.manager.ts +219 -0
  93. package/src/stackswap/manager/multisig.manager.ts +87 -87
  94. package/src/stackswap/manager/nft.manager.ts +307 -311
  95. package/src/stackswap/manager/operator.manager.ts +123 -123
  96. package/src/stackswap/manager/other.manager.ts +71 -71
  97. package/src/stackswap/manager/pool.manager.ts +202 -202
  98. package/src/stackswap/manager/poxl.manager.ts +99 -99
  99. package/src/stackswap/manager/staking.manager.ts +321 -321
  100. package/src/stackswap/manager/swap.manager.ts +392 -391
  101. package/src/stackswap/manager/token.manager.ts +167 -167
  102. package/src/stackswap/util.ts +237 -237
@@ -1,311 +1,307 @@
1
-
2
- import {StackswapAPI} from "../../index";
3
- import {getPostConditionFromAsset, getReadOptions, getWriteOptions} from "../util";
4
- import {openContractCall} from "@stacks/connect";
5
- import {
6
- callReadOnlyFunction, contractPrincipalCV,
7
- cvToValue,
8
- FungibleConditionCode,
9
- listCV,
10
- makeStandardNonFungiblePostCondition, NonFungibleConditionCode, standardPrincipalCV,
11
- TupleCV,
12
- uintCV
13
- } from "@stacks/transactions";
14
- import BigNumber from "bignumber.js";
15
- import axios from "axios";
16
-
17
-
18
- export class NftManager {
19
- stackswap : StackswapAPI;
20
-
21
- constructor(stackswap: StackswapAPI) {
22
- this.stackswap = stackswap;
23
- }
24
-
25
- async getNFTAsset(tokenStr: string) {
26
- // console.log(tokenStr);
27
- const token_addr = tokenStr.split('.');
28
- const url = this.stackswap.config.STACKS_API_URL() + '/v2/contracts/interface/' + token_addr[0] + '/' + token_addr[1];
29
- const result = await axios.get(url);
30
- // console.log(tokenStr,result);
31
- if (result.data.non_fungible_tokens.length === 1) {
32
- // console.log(tokenStr+'::'+result.data.non_fungible_tokens[0].name);
33
- return tokenStr + '::' + result.data.non_fungible_tokens[0].name;
34
- } else {
35
- // TODO one contract with more than one ft
36
- // console.log(tokenStr+'::'+result.data.non_fungible_tokens[0].name);
37
- return tokenStr + '::' + result.data.non_fungible_tokens[0].name;
38
- }
39
- }
40
- async getPostConditionFromAssetNFT(account: string, tokenStr: string, condition: NonFungibleConditionCode, id: string) {
41
- const assetString = await this.getNFTAsset(tokenStr);
42
- // console.log('account', account);
43
- // console.log('condition', condition);
44
- // console.log('assetString', assetString);
45
- // console.log(' uintCV(id)', bufferCVFromString(id));
46
- return makeStandardNonFungiblePostCondition(account, condition, assetString, uintCV(id));
47
- }
48
-
49
- async mintNFT(price: string | number, addr: string, callback: any = null){
50
- const post_condition = [];
51
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, price, FungibleConditionCode.Equal));
52
- const function_option : any = getWriteOptions(
53
- this.stackswap, addr, 'mint', [
54
- standardPrincipalCV(this.stackswap.getSenderAddress()), callback
55
- ], post_condition, callback);
56
- await openContractCall(function_option);
57
- }
58
-
59
- async mintNFT2(mint_fee: number, callback: any = null){
60
- const post_condition = [];
61
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, mint_fee*1000000, FungibleConditionCode.Equal));
62
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
63
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
64
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
65
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
66
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'mint', [
67
- standardPrincipalCV(this.stackswap.getSenderAddress()),
68
- ],post_condition, callback);
69
- await openContractCall(function_option);
70
- }
71
-
72
- async batchSetMintPass(lists: TupleCV[], addr: string, callback: any = null){
73
- const function_option : any = getWriteOptions(this.stackswap, addr, 'batch-set-mint-pass', [
74
- listCV(lists),
75
- ],[], callback);
76
- await openContractCall(function_option);
77
- }
78
-
79
- async listInUstx(id : number, price: string, comm : string = this.stackswap.config.CONTRACT_NAME_COMMISSION(), callback: any = null){
80
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(),'list-in-ustx', [
81
- uintCV(id),
82
- uintCV(price),
83
- this.stackswap.getQualifiedAddress(comm),
84
- ],[], callback);
85
- await openContractCall(function_option);
86
- }
87
-
88
- async unlistInUstx(id : number, callback: any = null){
89
-
90
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'unlist-in-ustx', [
91
- uintCV(id),
92
- ],[], callback);
93
- await openContractCall(function_option);
94
- }
95
-
96
- async buyInUstx(id : number, price: number, owner: string, comm : string = this.stackswap.config.CONTRACT_NAME_COMMISSION(), callback: any = null){
97
- const post_condition = [];
98
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, new BigNumber(price).multipliedBy(1.075).toFixed(), FungibleConditionCode.LessEqual));
99
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
100
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
101
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
102
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
103
- // post_condition.push(await getPostConditionFromAssetNFT(owner, STACKSWAP_ADDRESS()+'.'+CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, id));
104
- post_condition.push(await this.getPostConditionFromAssetNFT(owner, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
105
- // console.log(await getNFTAsset(STACKSWAP_ADDRESS()+'.'+CONTRACT_NAME_AINFT()))
106
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'buy-in-ustx', [
107
- uintCV(id),
108
- contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(),comm),
109
- ],post_condition, callback);
110
-
111
- await openContractCall(function_option);
112
- }
113
-
114
- async reTouchNFT(id: number, amount: string, callback: any = null){
115
- const post_condition = [];
116
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, amount, FungibleConditionCode.Equal));
117
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
118
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
119
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
120
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
121
- post_condition.push(await this.getPostConditionFromAssetNFT(this.stackswap.getSenderAddress(), this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
122
-
123
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 're-touch', [
124
- uintCV(id)
125
- ],post_condition, callback);
126
- await openContractCall(function_option);
127
- }
128
-
129
- async regressNFT(id: number, price: string = '90000000', callback: any = null){
130
- const post_condition = [];
131
- post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_LBTC_DATA().addr, price, FungibleConditionCode.Equal));
132
- post_condition.push(await this.getPostConditionFromAssetNFT(this.stackswap.getSenderAddress(), this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
133
-
134
-
135
- const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'regress-token', [
136
- uintCV(id)
137
- ],post_condition, callback);
138
- await openContractCall(function_option);
139
- }
140
-
141
- async getNFTData( id: number){
142
- const function_option:any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-nft-data', [
143
- uintCV(id),
144
- ]);
145
- const result_raw = await callReadOnlyFunction(function_option);
146
- const result = cvToValue(result_raw);
147
- // console.log(result);
148
- return result.value;
149
- }
150
-
151
- async getOwner( id: number){
152
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-owner', [
153
- uintCV(id),
154
- ]);
155
- const result_raw = await callReadOnlyFunction(function_option);
156
- const result = cvToValue(result_raw);
157
- try{
158
- return result.value.value;
159
- }catch (e) {
160
- return ''
161
- }
162
- }
163
-
164
- async getMintPass( contract: string){
165
- const function_option : any = getReadOptions(this.stackswap, contract, 'get-mint-pass-balance', [
166
- standardPrincipalCV(this.stackswap.getSenderAddress()),
167
- ]);
168
- const result_raw = await callReadOnlyFunction(function_option);
169
- const result = cvToValue(result_raw);
170
- try{
171
- return result;
172
- }catch (e) {
173
- return ''
174
- }
175
- }
176
-
177
- async getPassBalance( contract: string){
178
- const function_option : any = getReadOptions(this.stackswap, contract, 'get-balance', [
179
- standardPrincipalCV(this.stackswap.getSenderAddress()),
180
- ]);
181
- const result_raw = await callReadOnlyFunction(function_option);
182
- try{
183
- // console.log('result_raw', result_raw);
184
- // const result = cvToValue(result_raw);
185
- // console.log(result);
186
- // return result;
187
- return cvToValue(result_raw);
188
- }catch (e) {
189
- return '0';
190
- }
191
- }
192
-
193
- async getReserveAmount( id: number){
194
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-reserve-amount', [
195
- uintCV(id),
196
- ]);
197
- const result_raw = await callReadOnlyFunction(function_option);
198
- const result = cvToValue(result_raw);
199
- // console.log(result);
200
- return result.value;
201
- }
202
-
203
- async getTokenURI( id: number){
204
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-token-uri', [
205
- uintCV(id),
206
- ]);
207
- const result_raw = await callReadOnlyFunction(function_option);
208
- const result = cvToValue(result_raw);
209
- // console.log(result);
210
- return result.value;
211
- }
212
-
213
- async getTotalList(){
214
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-total-list', [
215
- ]);
216
- const result_raw = await callReadOnlyFunction(function_option);
217
- try{
218
- const result = cvToValue(result_raw);
219
- return result;
220
- } catch (e) {
221
- return [];
222
- }
223
- }
224
-
225
- async getMarketList(){
226
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-market-list', [
227
- ], );
228
- const result_raw = await callReadOnlyFunction(function_option);
229
- try{
230
- const result = cvToValue(result_raw);
231
- return result;
232
- } catch (e) {
233
- return [];
234
- }
235
- }
236
-
237
- async getMarketListing( id: number){
238
- const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-listing-in-ustx', [
239
- uintCV(id),
240
- ]);
241
- const result_raw = await callReadOnlyFunction(function_option);
242
- const result = cvToValue(result_raw);
243
- try{
244
- // console.log(result.value.price.value);
245
- return result.value.price.value;
246
- } catch (e) {
247
- return 0;
248
- }
249
- }
250
-
251
- async getPASSData(isGold: boolean) {
252
- const contractaddr = isGold ? this.stackswap.config.CONTRACT_NAME_GOLD_PASS() : this.stackswap.config.CONTRACT_NAME_SILVER_PASS();
253
- const temp =
254
- {
255
- id: 0,
256
- name: 'loading...',
257
- img_url: `loading...`,
258
- json_url: isGold ? 'https://gateway.ipfs.io/ipfs/QmQtSMAPvKFEr11VfKio2NHqwayJk4CTUkfmkxgXTR7Q2w' : 'https://gateway.ipfs.io/ipfs/QmQMArAThFXsFtDUyBWBepThCUbANjomWSw9cnmLALLcaM',
259
- desc: 'loading...',
260
- attr:
261
- {
262
- },
263
- price: 0,
264
- owner: 'loading...',
265
- locked_amt: 0,
266
- addr : contractaddr,
267
- contract_name : this.stackswap.config.STACKSWAP_ADDRESS() + '.' + contractaddr
268
- };
269
- const json_result = await axios.get(temp.json_url);
270
- // console.log(json_result.data);
271
- temp.desc = json_result.data.description;
272
- temp.name = json_result.data.name;
273
- temp.img_url = 'https://gateway.ipfs/ipfs/'+json_result.data.image.substr(7, json_result.data.image.length);
274
- // temp.attr.reTouch = json_result.data.attributes[0].value;
275
- // temp.price = await getMarketListing(source, id);
276
- // temp.locked_amt = await getReserveAmount(source, id);
277
-
278
- return temp
279
- }
280
-
281
- async getNFTDataFromID(id_: number) {
282
- const temp =
283
- {
284
- id: id_,
285
- name: 'loading...',
286
- img_url: `loading...`,
287
- json_url: `https://gateway.ipfs.io/ipfs/Qmaa5RRUMa9HQRHWJw3HWG3i1NUmb5VgJXT9Zqqg5VHQjX/${id_}.json`,
288
- desc: 'loading...',
289
- attr:
290
- {
291
- reTouch: 0,
292
- },
293
- price: 0,
294
- owner: 'loading...',
295
- locked_amt: 0,
296
- contract_name : this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_AINFT()
297
- };
298
- const json_result = await axios.get(`https://gateway.ipfs.io/ipfs/Qmaa5RRUMa9HQRHWJw3HWG3i1NUmb5VgJXT9Zqqg5VHQjX/${id_}.json`);
299
- // console.log(json_result.data);
300
- temp.img_url = 'https://gateway.ipfs.io/ipfs/'+json_result.data.image.substr(7, json_result.data.image.length);
301
- temp.desc = json_result.data.description;
302
- temp.name = json_result.data.name;
303
- temp.attr.reTouch = json_result.data.attributes[0].value;
304
-
305
- temp.price = await this.getMarketListing(id_);
306
- temp.locked_amt = await this.getReserveAmount(id_);
307
-
308
- return temp
309
- }
310
-
311
- }
1
+
2
+ import {StackswapAPI} from "../../index";
3
+ import {getPostConditionFromAsset, getReadOptions, getWriteOptions} from "../util";
4
+ import {openContractCall} from "@stacks/connect";
5
+ import {
6
+ callReadOnlyFunction, contractPrincipalCV,
7
+ cvToValue,
8
+ FungibleConditionCode,
9
+ listCV,
10
+ makeStandardNonFungiblePostCondition, NonFungibleConditionCode, standardPrincipalCV,
11
+ TupleCV,
12
+ uintCV
13
+ } from "@stacks/transactions";
14
+ import BigNumber from "bignumber.js";
15
+ import axios from "axios";
16
+
17
+
18
+ export class NftManager {
19
+ stackswap : StackswapAPI;
20
+
21
+ constructor(stackswap: StackswapAPI) {
22
+ this.stackswap = stackswap;
23
+ }
24
+
25
+ async getNFTAsset(tokenStr: string) {
26
+ // console.log(tokenStr);
27
+ const token_addr = tokenStr.split('.');
28
+ const url = this.stackswap.config.STACKS_API_URL() + '/v2/contracts/interface/' + token_addr[0] + '/' + token_addr[1];
29
+ const result = await axios.get(url);
30
+ // console.log(tokenStr,result);
31
+ if (result.data.non_fungible_tokens.length === 1) {
32
+ // console.log(tokenStr+'::'+result.data.non_fungible_tokens[0].name);
33
+ return tokenStr + '::' + result.data.non_fungible_tokens[0].name;
34
+ } else {
35
+ // TODO one contract with more than one ft
36
+ // console.log(tokenStr+'::'+result.data.non_fungible_tokens[0].name);
37
+ return tokenStr + '::' + result.data.non_fungible_tokens[0].name;
38
+ }
39
+ }
40
+ async getPostConditionFromAssetNFT(account: string, tokenStr: string, condition: NonFungibleConditionCode, id: string) {
41
+ const assetString = await this.getNFTAsset(tokenStr);
42
+ return makeStandardNonFungiblePostCondition(account, condition, assetString, uintCV(id));
43
+ }
44
+
45
+ async mintNFT(price: string | number, addr: string, callback: any = null){
46
+ const post_condition = [];
47
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, price, FungibleConditionCode.Equal));
48
+ const function_option : any = getWriteOptions(
49
+ this.stackswap, addr, 'mint', [
50
+ standardPrincipalCV(this.stackswap.getSenderAddress()), callback
51
+ ], post_condition, callback);
52
+ await openContractCall(function_option);
53
+ }
54
+
55
+ async mintNFT2(mint_fee: number, callback: any = null){
56
+ const post_condition = [];
57
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, mint_fee*1000000, FungibleConditionCode.Equal));
58
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
59
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
60
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
61
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
62
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'mint', [
63
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
64
+ ],post_condition, callback);
65
+ await openContractCall(function_option);
66
+ }
67
+
68
+ async batchSetMintPass(lists: TupleCV[], addr: string, callback: any = null){
69
+ const function_option : any = getWriteOptions(this.stackswap, addr, 'batch-set-mint-pass', [
70
+ listCV(lists),
71
+ ],[], callback);
72
+ await openContractCall(function_option);
73
+ }
74
+
75
+ async listInUstx(id : number, price: string, comm : string = this.stackswap.config.CONTRACT_NAME_COMMISSION(), callback: any = null){
76
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(),'list-in-ustx', [
77
+ uintCV(id),
78
+ uintCV(price),
79
+ this.stackswap.getQualifiedAddress(comm),
80
+ ],[], callback);
81
+ await openContractCall(function_option);
82
+ }
83
+
84
+ async unlistInUstx(id : number, callback: any = null){
85
+
86
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'unlist-in-ustx', [
87
+ uintCV(id),
88
+ ],[], callback);
89
+ await openContractCall(function_option);
90
+ }
91
+
92
+ async buyInUstx(id : number, price: number, owner: string, comm : string = this.stackswap.config.CONTRACT_NAME_COMMISSION(), callback: any = null){
93
+ const post_condition = [];
94
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS(), this.stackswap.config.BASE_WSTX_DATA().addr, new BigNumber(price).multipliedBy(1.075).toFixed(), FungibleConditionCode.LessEqual));
95
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
96
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
97
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
98
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
99
+ // post_condition.push(await getPostConditionFromAssetNFT(owner, STACKSWAP_ADDRESS()+'.'+CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, id));
100
+ post_condition.push(await this.getPostConditionFromAssetNFT(owner, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
101
+ // console.log(await getNFTAsset(STACKSWAP_ADDRESS()+'.'+CONTRACT_NAME_AINFT()))
102
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'buy-in-ustx', [
103
+ uintCV(id),
104
+ contractPrincipalCV(this.stackswap.config.STACKSWAP_ADDRESS(),comm),
105
+ ],post_condition, callback);
106
+
107
+ await openContractCall(function_option);
108
+ }
109
+
110
+ async reTouchNFT(id: number, amount: string, callback: any = null){
111
+ const post_condition = [];
112
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.getSenderAddress(), this.stackswap.config.BASE_WSTX_DATA().addr, amount, FungibleConditionCode.Equal));
113
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_WSTX_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
114
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STX_STSW_LP(), this.stackswap.config.BASE_STSW_DATA().addr,0, FungibleConditionCode.GreaterEqual));
115
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_STSW_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
116
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STSW_LBTC_LP(), this.stackswap.config.BASE_LBTC_DATA().addr, 0, FungibleConditionCode.GreaterEqual));
117
+ post_condition.push(await this.getPostConditionFromAssetNFT(this.stackswap.getSenderAddress(), this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
118
+
119
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 're-touch', [
120
+ uintCV(id)
121
+ ],post_condition, callback);
122
+ await openContractCall(function_option);
123
+ }
124
+
125
+ async regressNFT(id: number, price: string = '90000000', callback: any = null){
126
+ const post_condition = [];
127
+ post_condition.push(await getPostConditionFromAsset(this.stackswap, this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), this.stackswap.config.BASE_LBTC_DATA().addr, price, FungibleConditionCode.Equal));
128
+ post_condition.push(await this.getPostConditionFromAssetNFT(this.stackswap.getSenderAddress(), this.stackswap.config.STACKSWAP_ADDRESS()+'.'+this.stackswap.config.CONTRACT_NAME_AINFT(), NonFungibleConditionCode.DoesNotOwn, ''+id));
129
+
130
+
131
+ const function_option : any = getWriteOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'regress-token', [
132
+ uintCV(id)
133
+ ],post_condition, callback);
134
+ await openContractCall(function_option);
135
+ }
136
+
137
+ async getNFTData( id: number){
138
+ const function_option:any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-nft-data', [
139
+ uintCV(id),
140
+ ]);
141
+ const result_raw = await callReadOnlyFunction(function_option);
142
+ const result = cvToValue(result_raw);
143
+ // console.log(result);
144
+ return result.value;
145
+ }
146
+
147
+ async getOwner( id: number){
148
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-owner', [
149
+ uintCV(id),
150
+ ]);
151
+ const result_raw = await callReadOnlyFunction(function_option);
152
+ const result = cvToValue(result_raw);
153
+ try{
154
+ return result.value.value;
155
+ }catch (e) {
156
+ return ''
157
+ }
158
+ }
159
+
160
+ async getMintPass( contract: string){
161
+ const function_option : any = getReadOptions(this.stackswap, contract, 'get-mint-pass-balance', [
162
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
163
+ ]);
164
+ const result_raw = await callReadOnlyFunction(function_option);
165
+ const result = cvToValue(result_raw);
166
+ try{
167
+ return result;
168
+ }catch (e) {
169
+ return ''
170
+ }
171
+ }
172
+
173
+ async getPassBalance( contract: string){
174
+ const function_option : any = getReadOptions(this.stackswap, contract, 'get-balance', [
175
+ standardPrincipalCV(this.stackswap.getSenderAddress()),
176
+ ]);
177
+ const result_raw = await callReadOnlyFunction(function_option);
178
+ try{
179
+ // console.log('result_raw', result_raw);
180
+ // const result = cvToValue(result_raw);
181
+ // console.log(result);
182
+ // return result;
183
+ return cvToValue(result_raw);
184
+ }catch (e) {
185
+ return '0';
186
+ }
187
+ }
188
+
189
+ async getReserveAmount( id: number){
190
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-reserve-amount', [
191
+ uintCV(id),
192
+ ]);
193
+ const result_raw = await callReadOnlyFunction(function_option);
194
+ const result = cvToValue(result_raw);
195
+ // console.log(result);
196
+ return result.value;
197
+ }
198
+
199
+ async getTokenURI( id: number){
200
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-token-uri', [
201
+ uintCV(id),
202
+ ]);
203
+ const result_raw = await callReadOnlyFunction(function_option);
204
+ const result = cvToValue(result_raw);
205
+ // console.log(result);
206
+ return result.value;
207
+ }
208
+
209
+ async getTotalList(){
210
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-total-list', [
211
+ ]);
212
+ const result_raw = await callReadOnlyFunction(function_option);
213
+ try{
214
+ const result = cvToValue(result_raw);
215
+ return result;
216
+ } catch (e) {
217
+ return [];
218
+ }
219
+ }
220
+
221
+ async getMarketList(){
222
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-market-list', [
223
+ ], );
224
+ const result_raw = await callReadOnlyFunction(function_option);
225
+ try{
226
+ const result = cvToValue(result_raw);
227
+ return result;
228
+ } catch (e) {
229
+ return [];
230
+ }
231
+ }
232
+
233
+ async getMarketListing( id: number){
234
+ const function_option : any = getReadOptions(this.stackswap, this.stackswap.config.CONTRACT_NAME_AINFT(), 'get-listing-in-ustx', [
235
+ uintCV(id),
236
+ ]);
237
+ const result_raw = await callReadOnlyFunction(function_option);
238
+ const result = cvToValue(result_raw);
239
+ try{
240
+ // console.log(result.value.price.value);
241
+ return result.value.price.value;
242
+ } catch (e) {
243
+ return 0;
244
+ }
245
+ }
246
+
247
+ async getPASSData(isGold: boolean) {
248
+ const contractaddr = isGold ? this.stackswap.config.CONTRACT_NAME_GOLD_PASS() : this.stackswap.config.CONTRACT_NAME_SILVER_PASS();
249
+ const temp =
250
+ {
251
+ id: 0,
252
+ name: 'loading...',
253
+ img_url: `loading...`,
254
+ json_url: isGold ? 'https://gateway.ipfs.io/ipfs/QmQtSMAPvKFEr11VfKio2NHqwayJk4CTUkfmkxgXTR7Q2w' : 'https://gateway.ipfs.io/ipfs/QmQMArAThFXsFtDUyBWBepThCUbANjomWSw9cnmLALLcaM',
255
+ desc: 'loading...',
256
+ attr:
257
+ {
258
+ },
259
+ price: 0,
260
+ owner: 'loading...',
261
+ locked_amt: 0,
262
+ addr : contractaddr,
263
+ contract_name : this.stackswap.config.STACKSWAP_ADDRESS() + '.' + contractaddr
264
+ };
265
+ const json_result = await axios.get(temp.json_url);
266
+ // console.log(json_result.data);
267
+ temp.desc = json_result.data.description;
268
+ temp.name = json_result.data.name;
269
+ temp.img_url = 'https://gateway.ipfs/ipfs/'+json_result.data.image.substr(7, json_result.data.image.length);
270
+ // temp.attr.reTouch = json_result.data.attributes[0].value;
271
+ // temp.price = await getMarketListing(source, id);
272
+ // temp.locked_amt = await getReserveAmount(source, id);
273
+
274
+ return temp
275
+ }
276
+
277
+ async getNFTDataFromID(id_: number) {
278
+ const temp =
279
+ {
280
+ id: id_,
281
+ name: 'loading...',
282
+ img_url: `loading...`,
283
+ json_url: `https://gateway.ipfs.io/ipfs/Qmaa5RRUMa9HQRHWJw3HWG3i1NUmb5VgJXT9Zqqg5VHQjX/${id_}.json`,
284
+ desc: 'loading...',
285
+ attr:
286
+ {
287
+ reTouch: 0,
288
+ },
289
+ price: 0,
290
+ owner: 'loading...',
291
+ locked_amt: 0,
292
+ contract_name : this.stackswap.config.STACKSWAP_ADDRESS() + '.' + this.stackswap.config.CONTRACT_NAME_AINFT()
293
+ };
294
+ const json_result = await axios.get(`https://gateway.ipfs.io/ipfs/Qmaa5RRUMa9HQRHWJw3HWG3i1NUmb5VgJXT9Zqqg5VHQjX/${id_}.json`);
295
+ // console.log(json_result.data);
296
+ temp.img_url = 'https://gateway.ipfs.io/ipfs/'+json_result.data.image.substr(7, json_result.data.image.length);
297
+ temp.desc = json_result.data.description;
298
+ temp.name = json_result.data.name;
299
+ temp.attr.reTouch = json_result.data.attributes[0].value;
300
+
301
+ temp.price = await this.getMarketListing(id_);
302
+ temp.locked_amt = await this.getReserveAmount(id_);
303
+
304
+ return temp
305
+ }
306
+
307
+ }