tx · 6ybBNoYiXhAtnuucwE5xAUeqvEWa6VtmaWs9A6L6DSba
3P3jbpfBQ95gwKga8Nk4GbCB21R3Z66gHJc: -0.01000000 Waves
2022.04.19 10:00 [3080415] smart account 3P3jbpfBQ95gwKga8Nk4GbCB21R3Z66gHJc > SELF 0.00000000 Waves
{
"type": 13,
"id": "6ybBNoYiXhAtnuucwE5xAUeqvEWa6VtmaWs9A6L6DSba",
"fee": 1000000,
"feeAssetId": null,
"timestamp": 1650351657489,
"version": 2,
"chainId": 87,
"sender": "3P3jbpfBQ95gwKga8Nk4GbCB21R3Z66gHJc",
"senderPublicKey": "BtEpTJKCNdpyvw4hDiXTx6VFSKKkFp5phwbfxtek1KRm",
"proofs": [
"42vCMSqYFcbY9JJhfRmJaniSoXXt2X2YSYH43Lg7Kr2aFuH8zkBuf8bFCSxmk9ZY66fc7S8gZv72WUfnteo9t7Ke"
],
"script": "base64:AAIFAAAAAAAAAAgIAhIECgIBAQAAAAkBAAAABWFzSW50AAAAAQAAAAV2YWx1ZQQAAAAHJG1hdGNoMAUAAAAFdmFsdWUDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAADaW50BQAAAAckbWF0Y2gwBQAAAANpbnQJAAACAAAAAQIAAAANZXhwZWN0ZWQ6IEludAEAAAARYXNVc2VyQmFsYW5jZURhdGEAAAABAAAABXZhbHVlBAAAAAckbWF0Y2gwBQAAAAV2YWx1ZQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAiKEludCwgSW50LCBJbnQsIEludCwgSW50LCBCb29sZWFuKQQAAAABeAUAAAAHJG1hdGNoMAUAAAABeAQAAAABdAUAAAAHJG1hdGNoMAkAAAIAAAABAgAAACJ3cm9uZyB0eXBlLCBleHBlY3RlZDogSW50NSZCb29sZWFuAAAAAARtYWluCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABAgAAACMzUEFadjl0Z0sxUFg3ZEtSN2I0a2NocTVxZHBVUzNHNXNZVAAAAAAPYXNzZXRTdHJpbmdVc2RjAgAAACxERzJ4RmtQZER3S1VvQmt6R0FoUXRMcFNHemZYTGlDWVBFemVLSDJBZDI0cAAAAAALcmVzZXJ2ZVVzZGMJAQAAABFAZXh0ck5hdGl2ZSgxMDYyKQAAAAECAAAAIzNQTmlrTTZ5cDROcWNTVThndXhRdG1SNW9ucjJENGU4eVRKAAAAAA9hc3NldFN0cmluZ1VzZHQCAAAALDM0TjlZY0VFVExXbjkzcVlRNjRFc1AxeDg5dFNydUpVNDRSckVNU1hYRVBKAAAAAAtyZXNlcnZlVXNkdAkBAAAAEUBleHRyTmF0aXZlKDEwNjIpAAAAAQIAAAAjM1BFaUQxekpXVE1aTldTQ3l6aHZCdzlweHhBV2VFd2FnaFIAAAAADGFzc2V0U3RyaW5ncwkABEwAAAACAgAAACw2WHRIanBYYnM5UlJKUDJTcjlHVXlWcXpBQ2NieTlUa1RoSFhualZDNUNESgkABEwAAAACAgAAACwzNE45WWNFRVRMV245M3FZUTY0RXNQMXg4OXRTcnVKVTQ0UnJFTVNYWEVQSgUAAAADbmlsAAAAAAhyZXNlcnZlcwkABEwAAAACCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABAgAAACMzUE5pa002eXA0TnFjU1U4Z3V4UXRtUjVvbnIyRDRlOHlUSgkABEwAAAACCQEAAAARQGV4dHJOYXRpdmUoMTA2MikAAAABAgAAACMzUEVpRDF6SldUTVpOV1NDeXpodkJ3OXB4eEFXZUV3YWdoUgUAAAADbmlsAAAAAQAAAAFpAQAAAAh3aXRoZHJhdwAAAAIAAAAGY29pbmlkAAAACm1pbl9hbW91bnQEAAAADWFzc2V0SWRTdHJpbmcJAAGRAAAAAgUAAAAMYXNzZXRTdHJpbmdzBQAAAAZjb2luaWQEAAAAB2Fzc2V0SWQJAAJZAAAAAQUAAAANYXNzZXRJZFN0cmluZwQAAAAHcmVzZXJ2ZQkAAZEAAAACBQAAAAhyZXNlcnZlcwUAAAAGY29pbmlkBAAAAAlhdmFpbGFibGUJAAPwAAAAAgUAAAAHcmVzZXJ2ZQUAAAAHYXNzZXRJZAQAAAAPdXNlcmJhbGFuY2VkYXRhCQEAAAARYXNVc2VyQmFsYW5jZURhdGEAAAABCQAD/AAAAAQFAAAAB3Jlc2VydmUCAAAAC3VzZXJCYWxhbmNlCQAETAAAAAIJAAQlAAAAAQUAAAAEdGhpcwUAAAADbmlsBQAAAANuaWwEAAAACmRlcG9zaXRVc2QIBQAAAA91c2VyYmFsYW5jZWRhdGEAAAACXzMDCQAAZgAAAAIFAAAACm1pbl9hbW91bnQFAAAACWF2YWlsYWJsZQkAAAIAAAABCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAICAAAACGFzc2V0SWQ6BQAAAA1hc3NldElkU3RyaW5nAgAAAAlyZXNlcnZlOiAJAAQlAAAAAQUAAAAHcmVzZXJ2ZQIAAAANLHVzZXJBZGRyZXNzOgkABCUAAAABBQAAAAR0aGlzAgAAAA0sIGRlcG9zaXRVc2Q6CQABpAAAAAEFAAAACmRlcG9zaXRVc2QCAAAAEmN1cnJlbnRBdmFpbGFibGU6IAkAAaQAAAABBQAAAAlhdmFpbGFibGUCAAAADiwgbWluX2Ftb3VudDogCQABpAAAAAEFAAAACm1pbl9hbW91bnQCAAAACiwgZXJyX21zZzoJAAGkAAAAAQUAAAAJYXZhaWxhYmxlBAAAAAF2AwkAAGYAAAACBQAAAAlhdmFpbGFibGUFAAAACmRlcG9zaXRVc2QFAAAACmRlcG9zaXRVc2QFAAAACWF2YWlsYWJsZQMJAABmAAAAAgUAAAAKbWluX2Ftb3VudAUAAAABdgkAAAIAAAABCQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAAAxtaW4gYW1vdW50OiAJAAGkAAAAAQUAAAAKbWluX2Ftb3VudAIAAAAELCB2OgkAAaQAAAABBQAAAAF2BAAAAAZhbW91bnQJAQAAAAVhc0ludAAAAAEJAAP8AAAABAUAAAAEbWFpbgIAAAAId2l0aGRyYXcJAARMAAAAAgUAAAANYXNzZXRJZFN0cmluZwkABEwAAAACBQAAAAF2BQAAAANuaWwFAAAAA25pbAkABRQAAAACBQAAAANuaWwFAAAABmFtb3VudAAAAAC+1XAV",
"height": 3080415,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: 7AFqNzyt771cqnkS1FMRp5dDcyjTmoJUHSgoti9ANYpB
Next: GaV7yczaKW68PM7thmFc6HBVvBvECwq3TaYwKzbgtdm6
Diff:
Old | New | | Differences |
---|
19 | 19 | | |
---|
20 | 20 | | let main = addressFromStringValue("3PAZv9tgK1PX7dKR7b4kchq5qdpUS3G5sYT") |
---|
21 | 21 | | |
---|
22 | | - | let assetStringUsdc = "6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" |
---|
| 22 | + | let assetStringUsdc = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" |
---|
23 | 23 | | |
---|
24 | | - | let reserveUsdc = addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S") |
---|
| 24 | + | let reserveUsdc = addressFromStringValue("3PNikM6yp4NqcSU8guxQtmR5onr2D4e8yTJ") |
---|
25 | 25 | | |
---|
26 | 26 | | let assetStringUsdt = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" |
---|
27 | 27 | | |
---|
|
29 | 29 | | |
---|
30 | 30 | | let assetStrings = ["6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ", "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"] |
---|
31 | 31 | | |
---|
32 | | - | let reserves = [addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
| 32 | + | let reserves = [addressFromStringValue("3PNikM6yp4NqcSU8guxQtmR5onr2D4e8yTJ"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
33 | 33 | | |
---|
34 | 34 | | @Callable(i) |
---|
35 | 35 | | func withdraw (coinid,min_amount) = { |
---|
|
40 | 40 | | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
41 | 41 | | let depositUsd = userbalancedata._3 |
---|
42 | 42 | | if ((min_amount > available)) |
---|
43 | | - | then throw(((((((((((((("assetId:" + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvaliable: ") + toString(available)) + ", min_amount: ") + toString(min_amount)) + ", err_msg:") + toString(available))) |
---|
| 43 | + | then throw(((((((((((((("assetId:" + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount)) + ", err_msg:") + toString(available))) |
---|
44 | 44 | | else { |
---|
45 | 45 | | let v = if ((available > depositUsd)) |
---|
46 | 46 | | then depositUsd |
---|
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" |
---|
| 22 | + | let assetStringUsdc = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" |
---|
23 | 23 | | |
---|
24 | | - | let reserveUsdc = addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S") |
---|
| 24 | + | let reserveUsdc = addressFromStringValue("3PNikM6yp4NqcSU8guxQtmR5onr2D4e8yTJ") |
---|
25 | 25 | | |
---|
26 | 26 | | let assetStringUsdt = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" |
---|
27 | 27 | | |
---|
28 | 28 | | let reserveUsdt = addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR") |
---|
29 | 29 | | |
---|
30 | 30 | | let assetStrings = ["6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ", "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"] |
---|
31 | 31 | | |
---|
32 | | - | let reserves = [addressFromStringValue("3PGCkrHBxFMi7tz1xqnxgBpeNvn5E4M4g8S"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
| 32 | + | let reserves = [addressFromStringValue("3PNikM6yp4NqcSU8guxQtmR5onr2D4e8yTJ"), addressFromStringValue("3PEiD1zJWTMZNWSCyzhvBw9pxxAWeEwaghR")] |
---|
33 | 33 | | |
---|
34 | 34 | | @Callable(i) |
---|
35 | 35 | | func withdraw (coinid,min_amount) = { |
---|
36 | 36 | | let assetIdString = assetStrings[coinid] |
---|
37 | 37 | | let assetId = fromBase58String(assetIdString) |
---|
38 | 38 | | let reserve = reserves[coinid] |
---|
39 | 39 | | let available = assetBalance(reserve, assetId) |
---|
40 | 40 | | let userbalancedata = asUserBalanceData(invoke(reserve, "userBalance", [toString(this)], nil)) |
---|
41 | 41 | | let depositUsd = userbalancedata._3 |
---|
42 | 42 | | if ((min_amount > available)) |
---|
43 | | - | then throw(((((((((((((("assetId:" + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvaliable: ") + toString(available)) + ", min_amount: ") + toString(min_amount)) + ", err_msg:") + toString(available))) |
---|
| 43 | + | then throw(((((((((((((("assetId:" + assetIdString) + "reserve: ") + toString(reserve)) + ",userAddress:") + toString(this)) + ", depositUsd:") + toString(depositUsd)) + "currentAvailable: ") + toString(available)) + ", min_amount: ") + toString(min_amount)) + ", err_msg:") + toString(available))) |
---|
44 | 44 | | else { |
---|
45 | 45 | | let v = if ((available > depositUsd)) |
---|
46 | 46 | | then depositUsd |
---|
47 | 47 | | else available |
---|
48 | 48 | | if ((min_amount > v)) |
---|
49 | 49 | | then throw(((("min amount: " + toString(min_amount)) + ", v:") + toString(v))) |
---|
50 | 50 | | else { |
---|
51 | 51 | | let amount = asInt(invoke(main, "withdraw", [assetIdString, v], nil)) |
---|
52 | 52 | | $Tuple2(nil, amount) |
---|
53 | 53 | | } |
---|
54 | 54 | | } |
---|
55 | 55 | | } |
---|
56 | 56 | | |
---|
57 | 57 | | |
---|