tx · H8bp1c5cPx5EBbswp63kfDuhuqm34wnNjeYTThuBAyL8
3NCv9hyL5NUbMMkTXYnN9hL9AMQd6f2eVww: -0.01400000 Waves
2020.10.04 22:49 [1206271] smart account 3NCv9hyL5NUbMMkTXYnN9hL9AMQd6f2eVww > SELF 0.00000000 Waves
{
"type": 13,
"id": "H8bp1c5cPx5EBbswp63kfDuhuqm34wnNjeYTThuBAyL8",
"fee": 1400000,
"feeAssetId": null,
"timestamp": 1601840935267,
"version": 2,
"chainId": 84,
"sender": "3NCv9hyL5NUbMMkTXYnN9hL9AMQd6f2eVww",
"senderPublicKey": "CNQtsB6HAGUVvb5L3NshmGW2pD94ysV6dzV6Zcf6BFCq",
"proofs": [
"5FFSiL3StjE8fsk64cQncRDbxDjNGnYgCmhZRJkuizorXyZbAsiDmyM1B8r5sAPJ8r9bCC7ua2VD1qWQPCMHQaei"
],
"script": "base64:AAIDAAAAAAAAAAkIARIAEgMKAQEAAAAAAAAAAgAAAAFpAQAAAAdkZXBvc2l0AAAAAAQAAAADcG10CQEAAAAHZXh0cmFjdAAAAAEIBQAAAAFpAAAAB3BheW1lbnQEAAAABHR0eHgIBQAAAAlsYXN0QmxvY2sAAAAGaGVpZ2h0AwkBAAAACWlzRGVmaW5lZAAAAAEIBQAAAANwbXQAAAAHYXNzZXRJZAkAAAIAAAABAgAAACFjYW4gaG9kbCB3YXZlcyBvbmx5IGF0IHRoZSBtb21lbnQEAAAACmN1cnJlbnRLZXkJAAJYAAAAAQgIBQAAAAFpAAAABmNhbGxlcgAAAAVieXRlcwQAAAANY3VycmVudEFtb3VudAQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAApjdXJyZW50S2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEAAAAAAAAAAAAEAAAACW5ld0Ftb3VudAkAAGQAAAACBQAAAA1jdXJyZW50QW1vdW50CAUAAAADcG10AAAABmFtb3VudAkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAKY3VycmVudEtleQkAASwAAAACCQABLAAAAAIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAGkAAAAAQUAAAAJbmV3QW1vdW50AgAAAAEsCQABpAAAAAEJAABoAAAAAgkAAGkAAAACBQAAAAluZXdBbW91bnQAAAAAAAAAAGQAAAAAAAAAAHgCAAAAASwJAAGkAAAAAQkAAGkAAAACCQAAaAAAAAIJAABpAAAAAgUAAAAJbmV3QW1vdW50AAAAAAAAAABkAAAAAAAAAAB4AAAAAAAAAAASAgAAAAIsMAUAAAADbmlsAAAAAWkBAAAACHdpdGhkcmF3AAAAAQAAAAZhbW91bnQEAAAACmN1cnJlbnRLZXkJAAJYAAAAAQgIBQAAAAFpAAAABmNhbGxlcgAAAAVieXRlcwQAAAANY3VycmVudEFtb3VudAQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAApjdXJyZW50S2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEAAAAAAAAAAAAEAAAACW5ld0Ftb3VudAkAAGUAAAACBQAAAA1jdXJyZW50QW1vdW50BQAAAAZhbW91bnQDCQAAZgAAAAIAAAAAAAAAAAAFAAAABmFtb3VudAkAAAIAAAABAgAAAB5DYW4ndCB3aXRoZHJhdyBuZWdhdGl2ZSBhbW91bnQDCQAAZgAAAAIAAAAAAAAAAAAFAAAACW5ld0Ftb3VudAkAAAIAAAABAgAAABJOb3QgZW5vdWdoIGJhbGFuY2UJAQAAAAxTY3JpcHRSZXN1bHQAAAACCQEAAAAIV3JpdGVTZXQAAAABCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAAApjdXJyZW50S2V5BQAAAAluZXdBbW91bnQFAAAAA25pbAkBAAAAC1RyYW5zZmVyU2V0AAAAAQkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADCAUAAAABaQAAAAZjYWxsZXIFAAAABmFtb3VudAUAAAAEdW5pdAUAAAADbmlsAAAAAAQLpN8=",
"height": 1206271,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: DvYHYVpHeX1gHeamQiL5paGJis8CjZGVCVHQuiEAwjUY
Next: 2zAQ8KC6EfssexDAVmAaDwE1Ujixmtzy9LVm8Fq8msyL
Diff:
Old | New | | Differences |
---|
6 | 6 | | @Callable(a) |
---|
7 | 7 | | func deposit () = { |
---|
8 | 8 | | let b = extract(a.payment) |
---|
9 | | - | let c = toBase58String(a.transactionId) |
---|
10 | | - | let d = lastBlock.height |
---|
| 9 | + | let c = lastBlock.height |
---|
11 | 10 | | if (isDefined(b.assetId)) |
---|
12 | 11 | | then throw("can hodl waves only at the moment") |
---|
13 | 12 | | else { |
---|
14 | | - | let e = toBase58String(a.caller.bytes) |
---|
15 | | - | let f = { |
---|
16 | | - | let g = getInteger(this, e) |
---|
17 | | - | if ($isInstanceOf(g, "Int")) |
---|
| 13 | + | let d = toBase58String(a.caller.bytes) |
---|
| 14 | + | let e = { |
---|
| 15 | + | let f = getInteger(this, d) |
---|
| 16 | + | if ($isInstanceOf(f, "Int")) |
---|
18 | 17 | | then { |
---|
19 | | - | let h = g |
---|
20 | | - | h |
---|
| 18 | + | let g = f |
---|
| 19 | + | g |
---|
21 | 20 | | } |
---|
22 | 21 | | else 0 |
---|
23 | 22 | | } |
---|
24 | | - | let i = (f + b.amount) |
---|
25 | | - | WriteSet([DataEntry(e, ((((toString(i) + ",") + c) + ",") + toString(d)))]) |
---|
| 23 | + | let h = (e + b.amount) |
---|
| 24 | + | WriteSet([DataEntry(d, (((((toString(h) + ",") + toString(((h / 100) * 120))) + ",") + toString((((h / 100) * 120) / 18))) + ",0"))]) |
---|
26 | 25 | | } |
---|
27 | 26 | | } |
---|
28 | 27 | | |
---|
29 | 28 | | |
---|
30 | 29 | | |
---|
31 | 30 | | @Callable(a) |
---|
32 | | - | func withdraw (j) = { |
---|
33 | | - | let e = toBase58String(a.caller.bytes) |
---|
34 | | - | let f = { |
---|
35 | | - | let g = getInteger(this, e) |
---|
36 | | - | if ($isInstanceOf(g, "Int")) |
---|
| 31 | + | func withdraw (i) = { |
---|
| 32 | + | let d = toBase58String(a.caller.bytes) |
---|
| 33 | + | let e = { |
---|
| 34 | + | let f = getInteger(this, d) |
---|
| 35 | + | if ($isInstanceOf(f, "Int")) |
---|
37 | 36 | | then { |
---|
38 | | - | let h = g |
---|
39 | | - | h |
---|
| 37 | + | let g = f |
---|
| 38 | + | g |
---|
40 | 39 | | } |
---|
41 | 40 | | else 0 |
---|
42 | 41 | | } |
---|
43 | | - | let i = (f - j) |
---|
44 | | - | if ((0 > j)) |
---|
| 42 | + | let h = (e - i) |
---|
| 43 | + | if ((0 > i)) |
---|
45 | 44 | | then throw("Can't withdraw negative amount") |
---|
46 | | - | else if ((0 > i)) |
---|
| 45 | + | else if ((0 > h)) |
---|
47 | 46 | | then throw("Not enough balance") |
---|
48 | | - | else ScriptResult(WriteSet([DataEntry(e, i)]), TransferSet([ScriptTransfer(a.caller, j, unit)])) |
---|
| 47 | + | else ScriptResult(WriteSet([DataEntry(d, h)]), TransferSet([ScriptTransfer(a.caller, i, unit)])) |
---|
49 | 48 | | } |
---|
50 | 49 | | |
---|
51 | 50 | | |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 3 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | |
---|
5 | 5 | | |
---|
6 | 6 | | @Callable(a) |
---|
7 | 7 | | func deposit () = { |
---|
8 | 8 | | let b = extract(a.payment) |
---|
9 | | - | let c = toBase58String(a.transactionId) |
---|
10 | | - | let d = lastBlock.height |
---|
| 9 | + | let c = lastBlock.height |
---|
11 | 10 | | if (isDefined(b.assetId)) |
---|
12 | 11 | | then throw("can hodl waves only at the moment") |
---|
13 | 12 | | else { |
---|
14 | | - | let e = toBase58String(a.caller.bytes) |
---|
15 | | - | let f = { |
---|
16 | | - | let g = getInteger(this, e) |
---|
17 | | - | if ($isInstanceOf(g, "Int")) |
---|
| 13 | + | let d = toBase58String(a.caller.bytes) |
---|
| 14 | + | let e = { |
---|
| 15 | + | let f = getInteger(this, d) |
---|
| 16 | + | if ($isInstanceOf(f, "Int")) |
---|
18 | 17 | | then { |
---|
19 | | - | let h = g |
---|
20 | | - | h |
---|
| 18 | + | let g = f |
---|
| 19 | + | g |
---|
21 | 20 | | } |
---|
22 | 21 | | else 0 |
---|
23 | 22 | | } |
---|
24 | | - | let i = (f + b.amount) |
---|
25 | | - | WriteSet([DataEntry(e, ((((toString(i) + ",") + c) + ",") + toString(d)))]) |
---|
| 23 | + | let h = (e + b.amount) |
---|
| 24 | + | WriteSet([DataEntry(d, (((((toString(h) + ",") + toString(((h / 100) * 120))) + ",") + toString((((h / 100) * 120) / 18))) + ",0"))]) |
---|
26 | 25 | | } |
---|
27 | 26 | | } |
---|
28 | 27 | | |
---|
29 | 28 | | |
---|
30 | 29 | | |
---|
31 | 30 | | @Callable(a) |
---|
32 | | - | func withdraw (j) = { |
---|
33 | | - | let e = toBase58String(a.caller.bytes) |
---|
34 | | - | let f = { |
---|
35 | | - | let g = getInteger(this, e) |
---|
36 | | - | if ($isInstanceOf(g, "Int")) |
---|
| 31 | + | func withdraw (i) = { |
---|
| 32 | + | let d = toBase58String(a.caller.bytes) |
---|
| 33 | + | let e = { |
---|
| 34 | + | let f = getInteger(this, d) |
---|
| 35 | + | if ($isInstanceOf(f, "Int")) |
---|
37 | 36 | | then { |
---|
38 | | - | let h = g |
---|
39 | | - | h |
---|
| 37 | + | let g = f |
---|
| 38 | + | g |
---|
40 | 39 | | } |
---|
41 | 40 | | else 0 |
---|
42 | 41 | | } |
---|
43 | | - | let i = (f - j) |
---|
44 | | - | if ((0 > j)) |
---|
| 42 | + | let h = (e - i) |
---|
| 43 | + | if ((0 > i)) |
---|
45 | 44 | | then throw("Can't withdraw negative amount") |
---|
46 | | - | else if ((0 > i)) |
---|
| 45 | + | else if ((0 > h)) |
---|
47 | 46 | | then throw("Not enough balance") |
---|
48 | | - | else ScriptResult(WriteSet([DataEntry(e, i)]), TransferSet([ScriptTransfer(a.caller, j, unit)])) |
---|
| 47 | + | else ScriptResult(WriteSet([DataEntry(d, h)]), TransferSet([ScriptTransfer(a.caller, i, unit)])) |
---|
49 | 48 | | } |
---|
50 | 49 | | |
---|
51 | 50 | | |
---|