tx · 23uNSTdLVq9AJYdPTqaUC1sWqEtuiRFqzz63v1XtuaHh 3N8M61KCm8G72mK8PjacFbnnxdbFsyqQDeT: -0.01400000 Waves 2019.06.23 14:06 [554604] smart account 3N8M61KCm8G72mK8PjacFbnnxdbFsyqQDeT > SELF 0.00000000 Waves
{ "type": 13, "id": "23uNSTdLVq9AJYdPTqaUC1sWqEtuiRFqzz63v1XtuaHh", "fee": 1400000, "feeAssetId": null, "timestamp": 1561288059932, "version": 1, "sender": "3N8M61KCm8G72mK8PjacFbnnxdbFsyqQDeT", "senderPublicKey": "Bhyvkx4xdbEi4KPJNZSzx9gZgzgyLEsavuj2kYSt7SST", "proofs": [ "38LE3WA8oW37AQ53t59atfDdBFvMogEK1Ec69bp4CQmAQ9BQySGnNFphmky24oAKCQTDEpiBV7XMLPyP7Lk8Be8R" ], "script": "base64:AAIDAAAAAAAAAAAAAAADAAAAABZFcnJvck9ubHlXYXZlc0FjY2VwdGVkAgAAABllcnJvcl9vbmx5X3dhdmVzX2FjY2VwdGVkAAAAAA9TZXJ2ZXJQdWJsaWNLZXkBAAAAGgFUyizbHfX10DqIle41wD/n3rZAR7k35/dEAAAAABBSb3VsZXR0ZVNlY3Rpb25zAAAAAAAAAAAVAAAAAgAAAAFpAQAAAA9HZW5lcmF0ZVJhbmRJbnQAAAACAAAABmdhbWVJZAAAAAdyc2FTaWduBAAAAAtyc2FTaWdWYWxpZAkAAfQAAAADCQACWQAAAAEFAAAABmdhbWVJZAkAAlkAAAABBQAAAAdyc2FTaWduBQAAAA9TZXJ2ZXJQdWJsaWNLZXkDBQAAAAtyc2FTaWdWYWxpZAQAAAAEcmFuZAkAAGoAAAACCQAEsQAAAAEJAAH3AAAAAQkAAZsAAAABBQAAAAdyc2FTaWduBQAAABBSb3VsZXR0ZVNlY3Rpb25zCQEAAAAIV3JpdGVTZXQAAAABCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACAgAAAARvcmlnCQAEsQAAAAEJAAH3AAAAAQkAAZsAAAABBQAAAAdyc2FTaWduCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACAgAAAARyYW5kBQAAAARyYW5kBQAAAANuaWwJAAACAAAAAQIAAAAVSW52YWxpZCBSU0Egc2lnbmF0dXJlAAAAAWkBAAAAA2JldAAAAAEAAAAOZXhwZWN0ZWRSZXN1bHQEAAAAEGxhc3RBdWN0aW9uSWRLZXkCAAAAD2xhc3RfYXVjdGlvbl9pZAQAAAANbGFzdEF1Y3Rpb25JZAQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAABBsYXN0QXVjdGlvbklkS2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEAAAAAAAAAAAAEAAAAAmlkCQAAZAAAAAIFAAAADWxhc3RBdWN0aW9uSWQAAAAAAAAAAAEEAAAADG5ld0F1Y3Rpb25JZAkAAaQAAAABBQAAAAJpZAQAAAALb3duZXJXYWxsZXQJAAJYAAAAAQgIBQAAAAFpAAAABmNhbGxlcgAAAAVieXRlcwQAAAADcG10CQEAAAAFdmFsdWUAAAABCAUAAAABaQAAAAdwYXltZW50AwkBAAAACWlzRGVmaW5lZAAAAAEIBQAAAANwbXQAAAAHYXNzZXRJZAkAAAIAAAABBQAAABZFcnJvck9ubHlXYXZlc0FjY2VwdGVkBAAAAAdhc3NldElkCQACWAAAAAEJAQAAAAV2YWx1ZQAAAAEIBQAAAANwbXQAAAAHYXNzZXRJZAQAAAASYXVjdGlvbkR1cmF0aW9uS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAJX2R1cmF0aW9uBAAAABBhdWN0aW9uTWluQmlkS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAIX21pbl9iaWQEAAAAEWF1Y3Rpb25MYXN0QmlkS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAJX2xhc3RfYmlkBAAAABZhdWN0aW9uTGFzdEJpZE93bmVyS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAPX2xhc3RfYmlkX293bmVyBAAAAA9hdWN0aW9uT3duZXJLZXkJAAEsAAAAAgkAASwAAAACAgAAAAhhdWN0aW9uXwUAAAAMbmV3QXVjdGlvbklkAgAAAAZfb3duZXIEAAAAEGF1Y3Rpb25BbW91bnRLZXkJAAEsAAAAAgkAASwAAAACAgAAAAhhdWN0aW9uXwUAAAAMbmV3QXVjdGlvbklkAgAAAAdfYW1vdW50BAAAABFhdWN0aW9uQXNzZXRJZEtleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAACV9hc3NldF9pZAQAAAASYXVjdGlvbklzQWN0aXZlS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAKX2lzX2FjdGl2ZQQAAAAOdXNlckJhbGFuY2VLZXkJAAEsAAAAAgkAASwAAAACCQABLAAAAAICAAAACGJhbGFuY2VfBQAAAAtvd25lcldhbGxldAIAAAABXwUAAAAHYXNzZXRJZAQAAAANY3VycmVudEFtb3VudAQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAA51c2VyQmFsYW5jZUtleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAABAAAAAluZXdBbW91bnQJAABkAAAAAgUAAAANY3VycmVudEFtb3VudAgFAAAAA3BtdAAAAAZhbW91bnQJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAEWF1Y3Rpb25MYXN0QmlkS2V5AAAAAAAAAAAACQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAAA9hdWN0aW9uT3duZXJLZXkFAAAAC293bmVyV2FsbGV0CQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAABBhdWN0aW9uQW1vdW50S2V5CAUAAAADcG10AAAABmFtb3VudAkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAARYXVjdGlvbkFzc2V0SWRLZXkFAAAAB2Fzc2V0SWQJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAADnVzZXJCYWxhbmNlS2V5BQAAAAluZXdBbW91bnQJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAEmF1Y3Rpb25Jc0FjdGl2ZUtleQYJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAFmF1Y3Rpb25MYXN0QmlkT3duZXJLZXkCAAAAAAkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAQbGFzdEF1Y3Rpb25JZEtleQUAAAACaWQFAAAAA25pbAAAAAEAAAACdHgBAAAABnZlcmlmeQAAAAADCQAB9AAAAAMIBQAAAAJ0eAAAAAlib2R5Qnl0ZXMJAAGRAAAAAggFAAAAAnR4AAAABnByb29mcwAAAAAAAAAAAAgFAAAAAnR4AAAAD3NlbmRlclB1YmxpY0tleQQAAAAHJG1hdGNoMAUAAAACdHgDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAE1RyYW5zZmVyVHJhbnNhY3Rpb24EAAAAA3R0eAUAAAAHJG1hdGNoMAkAAGcAAAACCQAAZQAAAAIJAQAAAAx3YXZlc0JhbGFuY2UAAAABBQAAAAR0aGlzCAUAAAADdHR4AAAABmFtb3VudAAAAAAAAAAAAAMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAUU2V0U2NyaXB0VHJhbnNhY3Rpb24EAAAAA3N0eAUAAAAHJG1hdGNoMAYHBxmnuTI=", "chainId": 84, "height": 554604, "spentComplexity": 0 } View: original | compacted Prev: 31GxSwSmiVzH3wLTdCjjLf2WZjKuRhXvejftbzSt2Dqb Next: 469nR6kLbqvmHhEbJJUes3SiKNzuykLrQXUuhqW9G8Dx Diff:
Old | New | Differences | |
---|---|---|---|
5 | 5 | ||
6 | 6 | let b = base58'3N8M61KCm8G72mK8PjacFbnnxdbFsyqQDeT' | |
7 | 7 | ||
8 | - | @Callable(c) | |
9 | - | func GenerateRandInt (d,e) = { | |
10 | - | let f = sigVerify(fromBase58String(d), fromBase58String(e), c.callerPublicKey) | |
11 | - | if (f) | |
8 | + | let c = 21 | |
9 | + | ||
10 | + | @Callable(d) | |
11 | + | func GenerateRandInt (e,f) = { | |
12 | + | let g = sigVerify(fromBase58String(e), fromBase58String(f), b) | |
13 | + | if (g) | |
12 | 14 | then { | |
13 | - | let | |
14 | - | WriteSet([DataEntry("orig", toInt(sha256(toBytes( | |
15 | + | let h = (toInt(sha256(toBytes(f))) % c) | |
16 | + | WriteSet([DataEntry("orig", toInt(sha256(toBytes(f)))), DataEntry("rand", h)]) | |
15 | 17 | } | |
16 | 18 | else throw("Invalid RSA signature") | |
17 | 19 | } | |
18 | 20 | ||
19 | 21 | ||
20 | 22 | ||
21 | - | @Callable(c) | |
22 | - | func SetData (h,i) = if ((h == "hello")) | |
23 | - | then throw("NONONON!!") | |
24 | - | else WriteSet([DataEntry(h, i)]) | |
25 | - | ||
26 | - | ||
27 | - | ||
28 | - | @Callable(c) | |
29 | - | func bet (j) = { | |
30 | - | let k = "last_auction_id" | |
31 | - | let l = { | |
32 | - | let m = getInteger(this, k) | |
33 | - | if ($isInstanceOf(m, "Int")) | |
23 | + | @Callable(d) | |
24 | + | func bet (i) = { | |
25 | + | let j = "last_auction_id" | |
26 | + | let k = { | |
27 | + | let l = getInteger(this, j) | |
28 | + | if ($isInstanceOf(l, "Int")) | |
34 | 29 | then { | |
35 | - | let | |
36 | - | | |
30 | + | let m = l | |
31 | + | m | |
37 | 32 | } | |
38 | 33 | else 0 | |
39 | 34 | } | |
40 | - | let | |
41 | - | let | |
42 | - | let | |
43 | - | let | |
44 | - | if (isDefined( | |
35 | + | let n = (k + 1) | |
36 | + | let o = toString(n) | |
37 | + | let p = toBase58String(d.caller.bytes) | |
38 | + | let q = value(d.payment) | |
39 | + | if (isDefined(q.assetId)) | |
45 | 40 | then throw(a) | |
46 | 41 | else { | |
47 | - | let | |
48 | - | let | |
49 | - | let | |
50 | - | let | |
51 | - | let | |
52 | - | let | |
53 | - | let | |
54 | - | let | |
55 | - | let | |
56 | - | let | |
57 | - | let | |
58 | - | let | |
59 | - | if ($isInstanceOf( | |
42 | + | let r = toBase58String(value(q.assetId)) | |
43 | + | let s = (("auction_" + o) + "_duration") | |
44 | + | let t = (("auction_" + o) + "_min_bid") | |
45 | + | let u = (("auction_" + o) + "_last_bid") | |
46 | + | let v = (("auction_" + o) + "_last_bid_owner") | |
47 | + | let w = (("auction_" + o) + "_owner") | |
48 | + | let x = (("auction_" + o) + "_amount") | |
49 | + | let y = (("auction_" + o) + "_asset_id") | |
50 | + | let z = (("auction_" + o) + "_is_active") | |
51 | + | let A = ((("balance_" + p) + "_") + r) | |
52 | + | let B = { | |
53 | + | let l = getInteger(this, A) | |
54 | + | if ($isInstanceOf(l, "Int")) | |
60 | 55 | then { | |
61 | - | let | |
62 | - | | |
56 | + | let m = l | |
57 | + | m | |
63 | 58 | } | |
64 | 59 | else 0 | |
65 | 60 | } | |
66 | - | let | |
67 | - | WriteSet([DataEntry( | |
61 | + | let C = (B + q.amount) | |
62 | + | WriteSet([DataEntry(u, 0), DataEntry(w, p), DataEntry(x, q.amount), DataEntry(y, r), DataEntry(A, C), DataEntry(z, true), DataEntry(v, ""), DataEntry(j, n)]) | |
68 | 63 | } | |
69 | 64 | } | |
70 | 65 | ||
66 | + | ||
67 | + | @Verifier(D) | |
68 | + | func E () = if (sigVerify(D.bodyBytes, D.proofs[0], D.senderPublicKey)) | |
69 | + | then { | |
70 | + | let l = D | |
71 | + | if ($isInstanceOf(l, "TransferTransaction")) | |
72 | + | then { | |
73 | + | let F = l | |
74 | + | ((wavesBalance(this) - F.amount) >= 0) | |
75 | + | } | |
76 | + | else if ($isInstanceOf(l, "SetScriptTransaction")) | |
77 | + | then { | |
78 | + | let G = l | |
79 | + | true | |
80 | + | } | |
81 | + | else false | |
82 | + | } | |
83 | + | else false | |
71 | 84 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = "error_only_waves_accepted" | |
5 | 5 | ||
6 | 6 | let b = base58'3N8M61KCm8G72mK8PjacFbnnxdbFsyqQDeT' | |
7 | 7 | ||
8 | - | @Callable(c) | |
9 | - | func GenerateRandInt (d,e) = { | |
10 | - | let f = sigVerify(fromBase58String(d), fromBase58String(e), c.callerPublicKey) | |
11 | - | if (f) | |
8 | + | let c = 21 | |
9 | + | ||
10 | + | @Callable(d) | |
11 | + | func GenerateRandInt (e,f) = { | |
12 | + | let g = sigVerify(fromBase58String(e), fromBase58String(f), b) | |
13 | + | if (g) | |
12 | 14 | then { | |
13 | - | let | |
14 | - | WriteSet([DataEntry("orig", toInt(sha256(toBytes( | |
15 | + | let h = (toInt(sha256(toBytes(f))) % c) | |
16 | + | WriteSet([DataEntry("orig", toInt(sha256(toBytes(f)))), DataEntry("rand", h)]) | |
15 | 17 | } | |
16 | 18 | else throw("Invalid RSA signature") | |
17 | 19 | } | |
18 | 20 | ||
19 | 21 | ||
20 | 22 | ||
21 | - | @Callable(c) | |
22 | - | func SetData (h,i) = if ((h == "hello")) | |
23 | - | then throw("NONONON!!") | |
24 | - | else WriteSet([DataEntry(h, i)]) | |
25 | - | ||
26 | - | ||
27 | - | ||
28 | - | @Callable(c) | |
29 | - | func bet (j) = { | |
30 | - | let k = "last_auction_id" | |
31 | - | let l = { | |
32 | - | let m = getInteger(this, k) | |
33 | - | if ($isInstanceOf(m, "Int")) | |
23 | + | @Callable(d) | |
24 | + | func bet (i) = { | |
25 | + | let j = "last_auction_id" | |
26 | + | let k = { | |
27 | + | let l = getInteger(this, j) | |
28 | + | if ($isInstanceOf(l, "Int")) | |
34 | 29 | then { | |
35 | - | let | |
36 | - | | |
30 | + | let m = l | |
31 | + | m | |
37 | 32 | } | |
38 | 33 | else 0 | |
39 | 34 | } | |
40 | - | let | |
41 | - | let | |
42 | - | let | |
43 | - | let | |
44 | - | if (isDefined( | |
35 | + | let n = (k + 1) | |
36 | + | let o = toString(n) | |
37 | + | let p = toBase58String(d.caller.bytes) | |
38 | + | let q = value(d.payment) | |
39 | + | if (isDefined(q.assetId)) | |
45 | 40 | then throw(a) | |
46 | 41 | else { | |
47 | - | let | |
48 | - | let | |
49 | - | let | |
50 | - | let | |
51 | - | let | |
52 | - | let | |
53 | - | let | |
54 | - | let | |
55 | - | let | |
56 | - | let | |
57 | - | let | |
58 | - | let | |
59 | - | if ($isInstanceOf( | |
42 | + | let r = toBase58String(value(q.assetId)) | |
43 | + | let s = (("auction_" + o) + "_duration") | |
44 | + | let t = (("auction_" + o) + "_min_bid") | |
45 | + | let u = (("auction_" + o) + "_last_bid") | |
46 | + | let v = (("auction_" + o) + "_last_bid_owner") | |
47 | + | let w = (("auction_" + o) + "_owner") | |
48 | + | let x = (("auction_" + o) + "_amount") | |
49 | + | let y = (("auction_" + o) + "_asset_id") | |
50 | + | let z = (("auction_" + o) + "_is_active") | |
51 | + | let A = ((("balance_" + p) + "_") + r) | |
52 | + | let B = { | |
53 | + | let l = getInteger(this, A) | |
54 | + | if ($isInstanceOf(l, "Int")) | |
60 | 55 | then { | |
61 | - | let | |
62 | - | | |
56 | + | let m = l | |
57 | + | m | |
63 | 58 | } | |
64 | 59 | else 0 | |
65 | 60 | } | |
66 | - | let | |
67 | - | WriteSet([DataEntry( | |
61 | + | let C = (B + q.amount) | |
62 | + | WriteSet([DataEntry(u, 0), DataEntry(w, p), DataEntry(x, q.amount), DataEntry(y, r), DataEntry(A, C), DataEntry(z, true), DataEntry(v, ""), DataEntry(j, n)]) | |
68 | 63 | } | |
69 | 64 | } | |
70 | 65 | ||
66 | + | ||
67 | + | @Verifier(D) | |
68 | + | func E () = if (sigVerify(D.bodyBytes, D.proofs[0], D.senderPublicKey)) | |
69 | + | then { | |
70 | + | let l = D | |
71 | + | if ($isInstanceOf(l, "TransferTransaction")) | |
72 | + | then { | |
73 | + | let F = l | |
74 | + | ((wavesBalance(this) - F.amount) >= 0) | |
75 | + | } | |
76 | + | else if ($isInstanceOf(l, "SetScriptTransaction")) | |
77 | + | then { | |
78 | + | let G = l | |
79 | + | true | |
80 | + | } | |
81 | + | else false | |
82 | + | } | |
83 | + | else false | |
71 | 84 |
github/deemru/w8io/169f3d6 65.25 ms ◑![]()