tx · FNSnVh97rgQAp9yjr6KGSGZhvimHo2kAyURVZKeYSTE7

3MuXZUkNMy6YGMACBU5RZ3cGy5zSNeokkVL:  -0.01000000 Waves

2020.10.20 19:32 [1229129] smart account 3MuXZUkNMy6YGMACBU5RZ3cGy5zSNeokkVL > SELF 0.00000000 Waves

{ "type": 13, "id": "FNSnVh97rgQAp9yjr6KGSGZhvimHo2kAyURVZKeYSTE7", "fee": 1000000, "feeAssetId": null, "timestamp": 1603211649482, "version": 2, "chainId": 84, "sender": "3MuXZUkNMy6YGMACBU5RZ3cGy5zSNeokkVL", "senderPublicKey": "FfgkGkjCSsN3Z4iaFfuMpNYARGAYXjfPCdoHeAfFh4zv", "proofs": [ "5M6XKzgjJpJHkS7pTN6zd8jE7dytMJFdhQiSBwjtMmhtZEqgAuxG1kTfAdMkCc7uGv37Edr3y1CJbfuWdn5nWiUN" ], "script": "base64:AAIEAAAAAAAAAAwIAhIAEgASBAoCAQEAAAAPAAAAAARVU0RUAgAAACwzRUptN1pOWlJqV25nalZRNnFqRlVlZjNpUlV5SlpvVDRWWW9DWWFlVmRxWgAAAAAEVVNETgIAAAAsMzdqVkhaSzJjZ2JOVEFrTUNMR2RyYnp2RzFyd01qVHJwRDJUR3praWN0d0wAAAAABmlkVVNETgkAAlkAAAABBQAAAARVU0ROAAAAAAZpZFVTRFQJAAJZAAAAAQUAAAAEVVNEVAAAAAANd2l0aGRyYXdEZWxheQAAAAAAAAAAAQAAAAAPZGVjaW1hbFBhcnRVU0ROAAAAAAAAD0JAAAAAAA9kZWNpbWFsUGFydFVTRFQAAAAAAAAPQkAAAAAAF21pbmltYWxBbW91bnRUb1N3YXBVU0RUCQAAaAAAAAIAAAAAAAAAJxAFAAAAD2RlY2ltYWxQYXJ0VVNETgAAAAAXbWluaW1hbEFtb3VudFRvU3dhcFVTRE4JAABoAAAAAgAAAAAAAAAnEAUAAAAPZGVjaW1hbFBhcnRVU0RUAQAAAApjb2xsZWN0S2V5AAAAAwAAAAdhZGRyZXNzAAAAEWFtb3VudFRvU3dhcEluS2V5AAAAFWFsbG93VG9XaXRoZHJhd0hlaWdodAkABLkAAAACCQAETAAAAAIJAAQlAAAAAQUAAAAHYWRkcmVzcwkABEwAAAACAgAAAAhXSVRIRFJBVwkABEwAAAACCQABpAAAAAEFAAAAEWFtb3VudFRvU3dhcEluS2V5CQAETAAAAAICAAAABkhFSUdIVAkABEwAAAACCQABpAAAAAEFAAAAFWFsbG93VG9XaXRoZHJhd0hlaWdodAUAAAADbmlsAgAAAAFfAQAAABFjb2xsZWN0QmFsYW5jZUtleQAAAAEAAAAHYWRkcmVzcwkABLkAAAACCQAETAAAAAIJAAQlAAAAAQUAAAAHYWRkcmVzcwkABEwAAAACAgAAAAdiYWxhbmNlBQAAAANuaWwCAAAAAV8BAAAAGGNvbGxlY3RCYWxhbmNlS2V5V2l0aEZlZQAAAAEAAAAHYWRkcmVzcwkABLkAAAACCQAETAAAAAIJAAQlAAAAAQUAAAAHYWRkcmVzcwkABEwAAAACAgAAABBiYWxhbmNlX3dpdGhfZmVlBQAAAANuaWwCAAAAAV8BAAAAFHVzZHRUb1VzZG5Bc3NldEVycm9yAAAAAAkAAAIAAAABAgAAADRUbyBzd2FwIFVTRFQgdG8gVVNETiB5b3UgbmVlZCBhdHRhY2ggcGF5bWVudCBpbiBVU0RUAQAAABR1c2RuVG9Vc2R0QXNzZXRFcnJvcgAAAAAJAAACAAAAAQIAAAA0VG8gc3dhcCBVU0ROIHRvIFVTRFQgeW91IG5lZWQgYXR0YWNoIHBheW1lbnQgaW4gVVNETgEAAAAXdXNkdFRvVXNkbkxvd0xpbWl0RXJyb3IAAAAACQAAAgAAAAEJAAEsAAAAAgkAASwAAAACAgAAABZ5b3UgY2FuIHN3YXAgYXQgbGVhc3QgCQABpAAAAAEJAABpAAAAAgUAAAAXbWluaW1hbEFtb3VudFRvU3dhcFVTRFQFAAAAD2RlY2ltYWxQYXJ0VVNEVAIAAAAHIHRva2VucwAAAAMAAAAGaW52b2tlAQAAAA5zd2FwVVNEVHRvVVNETgAAAAAEAAAACmJhbGFuY2VLZXkJAQAAABhjb2xsZWN0QmFsYW5jZUtleVdpdGhGZWUAAAABCAUAAAAGaW52b2tlAAAABmNhbGxlcgQAAAAHcGF5bWVudAkBAAAABXZhbHVlAAAAAQkAAZEAAAACCAUAAAAGaW52b2tlAAAACHBheW1lbnRzAAAAAAAAAAAAAwkBAAAAAiE9AAAAAggFAAAAB3BheW1lbnQAAAAHYXNzZXRJZAUAAAAGaWRVU0RUCQEAAAAUdXNkdFRvVXNkbkFzc2V0RXJyb3IAAAAABAAAAAZhbW91bnQIBQAAAAdwYXltZW50AAAABmFtb3VudAQAAAAYY3VycmVudENsaWVudEJhbGFuY2VVU0RUCQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAACmJhbGFuY2VLZXkAAAAAAAAAAAADCQAAZgAAAAIFAAAAF21pbmltYWxBbW91bnRUb1N3YXBVU0RUBQAAAAZhbW91bnQJAQAAABd1c2R0VG9Vc2RuTG93TGltaXRFcnJvcgAAAAAJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAACmJhbGFuY2VLZXkJAABkAAAAAgUAAAAYY3VycmVudENsaWVudEJhbGFuY2VVU0RUBQAAAAZhbW91bnQJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwgFAAAABmludm9rZQAAAAZjYWxsZXIFAAAABmFtb3VudAUAAAAGaWRVU0ROBQAAAANuaWwAAAAGaW52b2tlAQAAABxpbml0aWFsaXphdGlvblVTRE50b1VTRFRzd2FwAAAAAAQAAAAHcGF5bWVudAkBAAAABXZhbHVlAAAAAQkAAZEAAAACCAUAAAAGaW52b2tlAAAACHBheW1lbnRzAAAAAAAAAAAAAwkBAAAAAiE9AAAAAggFAAAAB3BheW1lbnQAAAAHYXNzZXRJZAUAAAAGaWRVU0ROCQEAAAAUdXNkblRvVXNkdEFzc2V0RXJyb3IAAAAABAAAAAZhbW91bnQIBQAAAAdwYXltZW50AAAABmFtb3VudAQAAAALdXNlckFkZHJlc3MIBQAAAAZpbnZva2UAAAAGY2FsbGVyBAAAAApiYWxhbmNlS2V5CQEAAAARY29sbGVjdEJhbGFuY2VLZXkAAAABCAUAAAAGaW52b2tlAAAABmNhbGxlcgQAAAARYmFsYW5jZVdpdGhGZWVLZXkJAQAAABhjb2xsZWN0QmFsYW5jZUtleVdpdGhGZWUAAAABCAUAAAAGaW52b2tlAAAABmNhbGxlcgQAAAAUY3VycmVudENsaWVudEJhbGFuY2UJAQAAAAt2YWx1ZU9yRWxzZQAAAAIJAAQaAAAAAgUAAAAEdGhpcwUAAAAKYmFsYW5jZUtleQAAAAAAAAAAAAQAAAAbY3VycmVudENsaWVudEJhbGFuY2VXaXRoRmVlCQEAAAALdmFsdWVPckVsc2UAAAACCQAEGgAAAAIFAAAABHRoaXMFAAAAEWJhbGFuY2VXaXRoRmVlS2V5AAAAAAAAAAAABAAAAAt1c2VyQmFsYW5jZQkAAGQAAAACBQAAABRjdXJyZW50Q2xpZW50QmFsYW5jZQUAAAAbY3VycmVudENsaWVudEJhbGFuY2VXaXRoRmVlBAAAABh1c2VyQmFsYW5jZUFmdGVyV2l0aGRyYXcJAAGWAAAAAQkABEwAAAACCQAAZQAAAAIFAAAAFGN1cnJlbnRDbGllbnRCYWxhbmNlBQAAAAZhbW91bnQJAARMAAAAAgAAAAAAAAAAAAUAAAADbmlsBAAAAB91c2VyQmFsYW5jZVdpdGhGZWVBZnRlcldpdGhkcmF3CQABlgAAAAEJAARMAAAAAgkAAGQAAAACBQAAABtjdXJyZW50Q2xpZW50QmFsYW5jZVdpdGhGZWUJAAGXAAAAAQkABEwAAAACCQAAZQAAAAIFAAAAFGN1cnJlbnRDbGllbnRCYWxhbmNlBQAAAAZhbW91bnQJAARMAAAAAgAAAAAAAAAAAAUAAAADbmlsBQAAAANuaWwEAAAAA2ZlZQkAAGgAAAACCQAAaQAAAAIJAABlAAAAAgUAAAAbY3VycmVudENsaWVudEJhbGFuY2VXaXRoRmVlBQAAAB91c2VyQmFsYW5jZVdpdGhGZWVBZnRlcldpdGhkcmF3AAAAAAAAAABkAAAAAAAAAABjAwMJAABmAAAAAgUAAAAGYW1vdW50BQAAAAt1c2VyQmFsYW5jZQYJAABmAAAAAgUAAAAXbWluaW1hbEFtb3VudFRvU3dhcFVTRE4FAAAABmFtb3VudAkAAAIAAAABAgAAABBzd2FwIGFtb3VudCBmYWlsBAAAABVhbGxvd1RvV2l0aERyYXdIZWlnaHQJAABkAAAAAgUAAAAGaGVpZ2h0BQAAAA13aXRoZHJhd0RlbGF5AwkBAAAACWlzRGVmaW5lZAAAAAEJAAQdAAAAAgUAAAAEdGhpcwkBAAAACmNvbGxlY3RLZXkAAAADCAUAAAAGaW52b2tlAAAABmNhbGxlcgUAAAAGYW1vdW50BQAAABVhbGxvd1RvV2l0aERyYXdIZWlnaHQJAAACAAAAAQIAAAA9WW91IGhhdmUgYWxyZWFkeSBzdGFydGVkIHdpdGhkcmF3YWwgcHJvY2Vzcywgd2FpdCBuZXh0IGJsb2NrLgkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgUAAAAKYmFsYW5jZUtleQUAAAAYdXNlckJhbGFuY2VBZnRlcldpdGhkcmF3CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACBQAAABFiYWxhbmNlV2l0aEZlZUtleQUAAAAfdXNlckJhbGFuY2VXaXRoRmVlQWZ0ZXJXaXRoZHJhdwkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQEAAAAKY29sbGVjdEtleQAAAAMIBQAAAAZpbnZva2UAAAAGY2FsbGVyBQAAAAZhbW91bnQFAAAAFWFsbG93VG9XaXRoRHJhd0hlaWdodAkABLkAAAACCQAETAAAAAICAAAADW5vdF93aXRoZHJhd24JAARMAAAAAgkAAaQAAAABCQAAZQAAAAIFAAAABmFtb3VudAUAAAADZmVlBQAAAANuaWwCAAAAAV8FAAAAA25pbAAAAAZpbnZva2UBAAAADnN3YXBVU0ROdG9VU0RUAAAAAgAAAAZhbW91bnQAAAALaGVpZ2h0SW5LZXkEAAAAA2tleQkBAAAACmNvbGxlY3RLZXkAAAADCAUAAAAGaW52b2tlAAAABmNhbGxlcgUAAAAGYW1vdW50BQAAAAtoZWlnaHRJbktleQQAAAANd2l0aGRyYXduSW5mbwkBAAAAE3ZhbHVlT3JFcnJvck1lc3NhZ2UAAAACCQAEHQAAAAIFAAAABHRoaXMFAAAAA2tleQkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAAYVGhpcyBrZXkgZG9lc24ndCBleGlzdHMgBQAAAANrZXkCAAAADSBhdCBhZGRyZXNzICAJAAQlAAAAAQUAAAAEdGhpcwQAAAAKdG9XaXRoZHJhdwkBAAAAC3ZhbHVlT3JFbHNlAAAAAgkAAZEAAAACCQAEtQAAAAIFAAAADXdpdGhkcmF3bkluZm8CAAAAAV8AAAAAAAAAAAIJAAGkAAAAAQUAAAAGYW1vdW50AwMJAABnAAAAAgUAAAAGaGVpZ2h0BQAAAAtoZWlnaHRJbktleQkBAAAACGNvbnRhaW5zAAAAAgUAAAANd2l0aGRyYXduSW5mbwIAAAANbm90X3dpdGhkcmF3bgcJAARMAAAAAgkBAAAAC0RlbGV0ZUVudHJ5AAAAAQUAAAADa2V5CQAETAAAAAIJAQAAAA5TY3JpcHRUcmFuc2ZlcgAAAAMIBQAAAAZpbnZva2UAAAAGY2FsbGVyCQEAAAATdmFsdWVPckVycm9yTWVzc2FnZQAAAAIJAAS2AAAAAQUAAAAKdG9XaXRoZHJhdwIAAAAUV3Jvbmcgd2l0aGRyYXcgZGF0YSEFAAAABmlkVVNEVAUAAAADbmlsCQAAAgAAAAEJAAEsAAAAAgkAASwAAAACAgAAAB13aXRoZHJhd2FsIGlzIHBvc3NpYmxlIGFmdGVyIAkAAaQAAAABBQAAAAtoZWlnaHRJbktleQIAAAAqIGhlaWdodCBvciB5b3UgaGF2ZSBhbHJlYWR5IHdpdGhkcmF3biBVU0RUAAAAAGetUCY=", "height": 1229129, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 4 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let USDT = "3EJm7ZNZRjWngjVQ6qjFUef3iRUyJZoT4VYoCYaeVdqZ"
5+
6+let USDN = "37jVHZK2cgbNTAkMCLGdrbzvG1rwMjTrpD2TGzkictwL"
7+
8+let idUSDN = fromBase58String(USDN)
9+
10+let idUSDT = fromBase58String(USDT)
11+
12+let withdrawDelay = 1
13+
14+let decimalPartUSDN = 1000000
15+
16+let decimalPartUSDT = 1000000
17+
18+let minimalAmountToSwapUSDT = (10000 * decimalPartUSDN)
19+
20+let minimalAmountToSwapUSDN = (10000 * decimalPartUSDT)
21+
22+func collectKey (address,amountToSwapInKey,allowToWithdrawHeight) = makeString([toString(address), "WITHDRAW", toString(amountToSwapInKey), "HEIGHT", toString(allowToWithdrawHeight)], "_")
23+
24+
25+func collectBalanceKey (address) = makeString([toString(address), "balance"], "_")
26+
27+
28+func collectBalanceKeyWithFee (address) = makeString([toString(address), "balance_with_fee"], "_")
29+
30+
31+func usdtToUsdnAssetError () = throw("To swap USDT to USDN you need attach payment in USDT")
32+
33+
34+func usdnToUsdtAssetError () = throw("To swap USDN to USDT you need attach payment in USDN")
35+
36+
37+func usdtToUsdnLowLimitError () = throw((("you can swap at least " + toString((minimalAmountToSwapUSDT / decimalPartUSDT))) + " tokens"))
38+
39+
40+@Callable(invoke)
41+func swapUSDTtoUSDN () = {
42+ let balanceKey = collectBalanceKeyWithFee(invoke.caller)
43+ let payment = value(invoke.payments[0])
44+ if ((payment.assetId != idUSDT))
45+ then usdtToUsdnAssetError()
46+ else {
47+ let amount = payment.amount
48+ let currentClientBalanceUSDT = valueOrElse(getInteger(this, balanceKey), 0)
49+ if ((minimalAmountToSwapUSDT > amount))
50+ then usdtToUsdnLowLimitError()
51+ else [IntegerEntry(balanceKey, (currentClientBalanceUSDT + amount)), ScriptTransfer(invoke.caller, amount, idUSDN)]
52+ }
53+ }
54+
55+
56+
57+@Callable(invoke)
58+func initializationUSDNtoUSDTswap () = {
59+ let payment = value(invoke.payments[0])
60+ if ((payment.assetId != idUSDN))
61+ then usdnToUsdtAssetError()
62+ else {
63+ let amount = payment.amount
64+ let userAddress = invoke.caller
65+ let balanceKey = collectBalanceKey(invoke.caller)
66+ let balanceWithFeeKey = collectBalanceKeyWithFee(invoke.caller)
67+ let currentClientBalance = valueOrElse(getInteger(this, balanceKey), 0)
68+ let currentClientBalanceWithFee = valueOrElse(getInteger(this, balanceWithFeeKey), 0)
69+ let userBalance = (currentClientBalance + currentClientBalanceWithFee)
70+ let userBalanceAfterWithdraw = max([(currentClientBalance - amount), 0])
71+ let userBalanceWithFeeAfterWithdraw = max([(currentClientBalanceWithFee + min([(currentClientBalance - amount), 0]))])
72+ let fee = (((currentClientBalanceWithFee - userBalanceWithFeeAfterWithdraw) / 100) * 99)
73+ if (if ((amount > userBalance))
74+ then true
75+ else (minimalAmountToSwapUSDN > amount))
76+ then throw("swap amount fail")
77+ else {
78+ let allowToWithDrawHeight = (height + withdrawDelay)
79+ if (isDefined(getString(this, collectKey(invoke.caller, amount, allowToWithDrawHeight))))
80+ then throw("You have already started withdrawal process, wait next block.")
81+ else [IntegerEntry(balanceKey, userBalanceAfterWithdraw), IntegerEntry(balanceWithFeeKey, userBalanceWithFeeAfterWithdraw), StringEntry(collectKey(invoke.caller, amount, allowToWithDrawHeight), makeString(["not_withdrawn", toString((amount - fee))], "_"))]
82+ }
83+ }
84+ }
85+
86+
87+
88+@Callable(invoke)
89+func swapUSDNtoUSDT (amount,heightInKey) = {
90+ let key = collectKey(invoke.caller, amount, heightInKey)
91+ let withdrawnInfo = valueOrErrorMessage(getString(this, key), ((("This key doesn't exists " + key) + " at address ") + toString(this)))
92+ let toWithdraw = valueOrElse(split(withdrawnInfo, "_")[2], toString(amount))
93+ if (if ((height >= heightInKey))
94+ then contains(withdrawnInfo, "not_withdrawn")
95+ else false)
96+ then [DeleteEntry(key), ScriptTransfer(invoke.caller, valueOrErrorMessage(parseInt(toWithdraw), "Wrong withdraw data!"), idUSDT)]
97+ else throw((("withdrawal is possible after " + toString(heightInKey)) + " height or you have already withdrawn USDT"))
98+ }
99+
100+

github/deemru/w8io/026f985 
15.78 ms