2022.04.24 07:01 [3087453] smart account 3P3jbpfBQ95gwKga8Nk4GbCB21R3Z66gHJc > SELF 0.00000000 Waves
{
"type": 13,
"id": "J8xHnK5zWS2URbR7SpM8EMhkJNrT9anpz7wFZhCdpzpA",
"fee": 1000000,
"feeAssetId": null,
"timestamp": 1650772953348,
"version": 2,
"chainId": 87,
"sender": "3P3jbpfBQ95gwKga8Nk4GbCB21R3Z66gHJc",
"senderPublicKey": "BtEpTJKCNdpyvw4hDiXTx6VFSKKkFp5phwbfxtek1KRm",
"proofs": [
"56rku7h1D6cacAaQR8xVrQP4qChd7wwngHcQACiwWBmX8k76jZpUKv7AUWy6CdZsJbXevYwrbG8P9j5DDj2WzD3C"
],
"script": "base64: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",
"height": 3087453,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: 6iyzQDqrx4Yqoq9Jp7s5bRVvsKtNHMYAQ7YLhHJMQ2fy
Next: 7YYY4swUeS2FM4bjxAm7GQpgHdiU3k6foNN26uJYRjaZ
Diff:
Old | New | | Differences |
---|
19 | 19 | | |
---|
20 | 20 | | let main = addressFromStringValue("3PAZv9tgK1PX7dKR7b4kchq5qdpUS3G5sYT") |
---|
21 | 21 | | |
---|
22 | | - | let assetStringUsdc = "6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" |
---|
23 | | - | |
---|
24 | | - | let reserveUsdc = addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S") |
---|
25 | | - | |
---|
26 | | - | let assetStringUsdt = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" |
---|
27 | | - | |
---|
28 | | - | let reserveUsdt = addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR") |
---|
29 | | - | |
---|
30 | 22 | | let assetStrings = ["6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ", "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"] |
---|
31 | 23 | | |
---|
32 | 24 | | let reserves = [addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
|
34 | 26 | | @Callable(i) |
---|
35 | 27 | | func withdraw (coinid,min_amount) = { |
---|
36 | 28 | | let assetIdString = assetStrings[coinid] |
---|
37 | | - | let reserve = addressFromStringValue(assetIdString) |
---|
38 | | - | let available = assetBalance(reserve, toBytes(assetIdString)) |
---|
39 | | - | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
40 | | - | let depositUsd = userbalancedata._3 |
---|
| 29 | + | let assetId = fromBase58String(assetIdString) |
---|
| 30 | + | let reserve = reserves[coinid] |
---|
| 31 | + | let available = assetBalance(reserve, assetId) |
---|
41 | 32 | | if ((min_amount > available)) |
---|
42 | | - | then throw(((((((((((((("this:" + toString(this)) + "assetId:") + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount))) |
---|
| 33 | + | then throw(((((((((((("this:" + toString(this)) + "assetId:") + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount))) |
---|
43 | 34 | | else { |
---|
| 35 | + | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
| 36 | + | let depositUsd = userbalancedata._3 |
---|
44 | 37 | | let v = if ((available > depositUsd)) |
---|
45 | 38 | | then depositUsd |
---|
46 | 39 | | else available |
---|
47 | 40 | | if ((min_amount > v)) |
---|
48 | | - | then throw(((("min amount: " + toString(min_amount)) + ", v:") + toString(v))) |
---|
| 41 | + | then throw(toString(v)) |
---|
49 | 42 | | else { |
---|
50 | 43 | | let amount = asInt(invoke(main, "withdraw", [assetIdString, v], nil)) |
---|
51 | 44 | | $Tuple2(nil, amount) |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 5 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | func asInt (value) = match value { |
---|
5 | 5 | | case int: Int => |
---|
6 | 6 | | int |
---|
7 | 7 | | case _ => |
---|
8 | 8 | | throw("expected: Int") |
---|
9 | 9 | | } |
---|
10 | 10 | | |
---|
11 | 11 | | |
---|
12 | 12 | | func asUserBalanceData (value) = match value { |
---|
13 | 13 | | case x: (Int, Int, Int, Int, Int, Boolean) => |
---|
14 | 14 | | x |
---|
15 | 15 | | case t => |
---|
16 | 16 | | throw("wrong type, expected: Int5&Boolean") |
---|
17 | 17 | | } |
---|
18 | 18 | | |
---|
19 | 19 | | |
---|
20 | 20 | | let main = addressFromStringValue("3PAZv9tgK1PX7dKR7b4kchq5qdpUS3G5sYT") |
---|
21 | 21 | | |
---|
22 | | - | let assetStringUsdc = "6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" |
---|
23 | | - | |
---|
24 | | - | let reserveUsdc = addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S") |
---|
25 | | - | |
---|
26 | | - | let assetStringUsdt = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" |
---|
27 | | - | |
---|
28 | | - | let reserveUsdt = addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR") |
---|
29 | | - | |
---|
30 | 22 | | let assetStrings = ["6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ", "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"] |
---|
31 | 23 | | |
---|
32 | 24 | | let reserves = [addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
33 | 25 | | |
---|
34 | 26 | | @Callable(i) |
---|
35 | 27 | | func withdraw (coinid,min_amount) = { |
---|
36 | 28 | | let assetIdString = assetStrings[coinid] |
---|
37 | | - | let reserve = addressFromStringValue(assetIdString) |
---|
38 | | - | let available = assetBalance(reserve, toBytes(assetIdString)) |
---|
39 | | - | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
40 | | - | let depositUsd = userbalancedata._3 |
---|
| 29 | + | let assetId = fromBase58String(assetIdString) |
---|
| 30 | + | let reserve = reserves[coinid] |
---|
| 31 | + | let available = assetBalance(reserve, assetId) |
---|
41 | 32 | | if ((min_amount > available)) |
---|
42 | | - | then throw(((((((((((((("this:" + toString(this)) + "assetId:") + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount))) |
---|
| 33 | + | then throw(((((((((((("this:" + toString(this)) + "assetId:") + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount))) |
---|
43 | 34 | | else { |
---|
| 35 | + | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
| 36 | + | let depositUsd = userbalancedata._3 |
---|
44 | 37 | | let v = if ((available > depositUsd)) |
---|
45 | 38 | | then depositUsd |
---|
46 | 39 | | else available |
---|
47 | 40 | | if ((min_amount > v)) |
---|
48 | | - | then throw(((("min amount: " + toString(min_amount)) + ", v:") + toString(v))) |
---|
| 41 | + | then throw(toString(v)) |
---|
49 | 42 | | else { |
---|
50 | 43 | | let amount = asInt(invoke(main, "withdraw", [assetIdString, v], nil)) |
---|
51 | 44 | | $Tuple2(nil, amount) |
---|
52 | 45 | | } |
---|
53 | 46 | | } |
---|
54 | 47 | | } |
---|
55 | 48 | | |
---|
56 | 49 | | |
---|