tx · 5TVpqqawz38EnWFQhzpoZoR7WGXrcYAF5Jj33sD2K9C3

3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ:  -0.01400000 Waves

2021.05.13 17:32 [1524013] smart account 3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ > SELF 0.00000000 Waves

{ "type": 13, "id": "5TVpqqawz38EnWFQhzpoZoR7WGXrcYAF5Jj33sD2K9C3", "fee": 1400000, "feeAssetId": null, "timestamp": 1620916403032, "version": 1, "sender": "3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ", "senderPublicKey": "ALG9JVGNn9aCL68dbg1AmW6yDQv1b8EDLq99pQS8L1k6", "proofs": [ "3rtazoJ3oXjbmLDLZvffkx1MxJ6r5eHGd3apP4BXi4B7hi4qwE3mak48aZyv1Fc1XJNrMe7k2CL6JERPz8A6gmch" ], "script": "base64:AAIEAAAAAAAAAA8IAhIAEgMKAQgSBAoCCAEAAAAWAAAAABNnYW1lTWFzdGVyUHVibGljS2V5AQAAACCKqFcQ1VSNQa7ZONz4ZD59H7wLfuowVwcQ1qI/fK6ACwAAAAAKZGljZU51bWJlcgkABEwAAAACAAAAAAAAAAACCQAETAAAAAIAAAAAAAAAAAMJAARMAAAAAgAAAAAAAAAABAkABEwAAAACAAAAAAAAAAAFCQAETAAAAAIAAAAAAAAAAAYJAARMAAAAAgAAAAAAAAAABwkABEwAAAACAAAAAAAAAAAICQAETAAAAAIAAAAAAAAAAAkJAARMAAAAAgAAAAAAAAAACgkABEwAAAACAAAAAAAAAAALCQAETAAAAAIAAAAAAAAAAAwFAAAAA25pbAAAAAAJZ2FtZVRva2VuAQAAACCvQNOoGbkt3wVk9kpr+yD9dOUY7LBdGNCbLK5MVkSodQAAAAAJUlNBUFVCTElDCQACWwAAAAECAAABkmJhc2U2NDpNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DQVE4QU1JSUJDZ0tDQVFFQWpudDJQZE4xUGRqZDoKN3JzWHpiYXBndWNuOWUxWGZmVXgxbzdnckFsdzhDNk5GdXYxUFBqN0tuUTZSdE45eGhuaUxGNHhLbGM3Ly9UWVhkMXVIV214OXZ1OWhqY2lZWDlVTVJKbmhsWk8ycTM0bXhQZGNnTERLaEpIRE43MjZLSTB3SHBGUTVkSE15em9NTGRXc2FoRmMxV3gvWHhyb0syS2MxeTJKQldOMmFrUmxreFNEY2x1cWJiVWNXTXlyd0c2aVd1VmxoZWo1eGZjdWVyZy9wc0szNVdHbjdTTEYyOXRXdVIyeCsyNG5NK0JKVXN1Ukc3eUJaVWhHcll6SmsyZ3ZwdWNSTGVhNkFGUnZvdzdSZHlNWUF3S0ZycjZtZ1EwVmNVdzJUNzUwZTFvR2FuWTBVZFUzTlBzS0lndlU0RnQ0dWliTWxNTUJKdmNyc0ViRFFIZkRsd0lEQVFBQgAAAAAJR0FNRVNUQVJUAAAAAAAAAAAAAAAAAA5HQU1FSU5QUk9HUkVTUwAAAAAAAAAAAQAAAAAMR0FNRUZJTklTSEVEAAAAAAAAAAACAAAAABBnYW1lQ291bnRlckxhYmVsAgAAAA1HX0dBTUVDT1VOVEVSAAAAABJnYW1lVG90YWxCZXRzTGFiZWwCAAAAEEdfVE9UQUxDUkFQU0JFVFMAAAAAEGxhc3RSb2xsZWROdW1iZXIAAAAAAAAAAAABAAAAE2F1dGhvcml6ZVBlcm1pc3Npb24AAAABAAAAD2NhbGxlclB1YmxpY0tleQkBAAAAAiE9AAAAAgUAAAAPY2FsbGVyUHVibGljS2V5BQAAABNnYW1lTWFzdGVyUHVibGljS2V5AQAAABlnYW1lQ3VycmVudFBvaW50RGljZUxhYmVsAAAAAQAAAAtnYW1lQ291bnRlcgkAASwAAAACCQABLAAAAAICAAAAAkdfCQABpAAAAAEFAAAAC2dhbWVDb3VudGVyAgAAAAtfRklSU1RQT0lOVAEAAAAXZ2FtZUZpcnN0UG9pbnREaWNlTGFiZWwAAAABAAAAC2dhbWVDb3VudGVyCQABLAAAAAIJAAEsAAAAAgIAAAACR18JAAGkAAAAAQUAAAALZ2FtZUNvdW50ZXICAAAADV9DVVJSRU5UUE9JTlQBAAAADmdhbWVTdGF0ZUxhYmVsAAAAAQAAAAtnYW1lQ291bnRlcgkAASwAAAACCQABLAAAAAICAAAAAkdfCQABpAAAAAEFAAAAC2dhbWVDb3VudGVyAgAAAAZfU1RBVEUBAAAAD2dhbWVTdW1TaGFMYWJlbAAAAAEAAAALZ2FtZUNvdW50ZXIJAAEsAAAAAgkAASwAAAACAgAAAAJHXwkAAaQAAAABBQAAAAtnYW1lQ291bnRlcgIAAAAHX1NVTVNIQQEAAAAUZ2FtZVN0YXJ0SGVpZ2h0TGFiZWwAAAABAAAAC2dhbWVDb3VudGVyCQABLAAAAAIJAAEsAAAAAgIAAAACR18JAAGkAAAAAQUAAAALZ2FtZUNvdW50ZXICAAAADF9TVEFSVEhFSUdIVAEAAAAMZ2V0R2FtZVN0YXRlAAAAAQAAAAtnYW1lQ291bnRlcgkABBoAAAACBQAAAAR0aGlzCQEAAAAOZ2FtZVN0YXRlTGFiZWwAAAABBQAAAAtnYW1lQ291bnRlcgEAAAANZ2V0R2FtZVN1bVNoYQAAAAEAAAALZ2FtZUNvdW50ZXIJAAQdAAAAAgUAAAAEdGhpcwkBAAAAD2dhbWVTdW1TaGFMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAQAAAA5nZXRTdGFydEhlaWdodAAAAAEAAAALZ2FtZUNvdW50ZXIJAAQaAAAAAgUAAAAEdGhpcwkBAAAAFGdhbWVTdGFydEhlaWdodExhYmVsAAAAAQUAAAALZ2FtZUNvdW50ZXIBAAAAEmdldENyYXBHYW1lQ291bnRlcgAAAAAJAAQaAAAAAgUAAAAEdGhpcwUAAAAQZ2FtZUNvdW50ZXJMYWJlbAEAAAARZ2V0Rmlyc3RQb2ludERpY2UAAAABAAAAC2dhbWVDb3VudGVyCQAEGgAAAAIFAAAABHRoaXMJAQAAABdnYW1lRmlyc3RQb2ludERpY2VMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAQAAABNnZXRDdXJyZW50UG9pbnREaWNlAAAAAQAAAAtnYW1lQ291bnRlcgkABBoAAAACBQAAAAR0aGlzCQEAAAAZZ2FtZUN1cnJlbnRQb2ludERpY2VMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAAAAAwAAAAFpAQAAAAhpbml0R2FtZQAAAAADCQEAAAATYXV0aG9yaXplUGVybWlzc2lvbgAAAAEIBQAAAAFpAAAAD2NhbGxlclB1YmxpY0tleQkAAAIAAAABAgAAABJpbml0R2FtZV9GT1JCSURERU4EAAAAByRtYXRjaDAJAQAAABJnZXRDcmFwR2FtZUNvdW50ZXIAAAAAAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAB2NvdW50ZXIFAAAAByRtYXRjaDAJAAACAAAAAQIAAAARSU5JVF9BTFJFQURZX0RPTkUJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEGdhbWVDb3VudGVyTGFiZWwAAAAAAAAAAAAJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEmdhbWVUb3RhbEJldHNMYWJlbAAAAAAAAAAAAAUAAAADbmlsAAAAAWkBAAAACXN0YXJ0R2FtZQAAAAEAAAAKcmFuZG9tSGFzaAMJAQAAABNhdXRob3JpemVQZXJtaXNzaW9uAAAAAQgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5CQAAAgAAAAECAAAAE3N0YXJ0R2FtZV9GT1JCSURERU4EAAAAByRtYXRjaDAJAQAAABJnZXRDcmFwR2FtZUNvdW50ZXIA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", "chainId": 84, "height": 1524013, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 3J6F5Ue8JXMsvpGVwCKqqnvC3L4UJBWuz7GSiUFYWoEJ Next: 62dmi64SYEo4nekmA8CKFrXuHtmuvKLaWbFsMy9ze9hm Diff:
OldNewDifferences
111111 then {
112112 let M = L
113113 let B = sha256((take(J, 4) + take(M.generationSignature, 4)))
114- throw(("fsdfsd " + toBase64String(B)))
114+ if (!(K))
115+ then throw("INVALID_RSA_SIGN")
116+ else {
117+ let N = (toInt(B) % 37)
118+ throw(("fsdfsd " + toBase64String(B)))
119+ }
115120 }
116121 else throw("Last block doesn't exist.")
117122 }
122127 }
123128
124129
125-@Verifier(N)
126-func O () = {
127- let z = N
128- sigVerify(N.bodyBytes, N.proofs[0], N.senderPublicKey)
130+@Verifier(O)
131+func P () = {
132+ let z = O
133+ sigVerify(O.bodyBytes, O.proofs[0], O.senderPublicKey)
129134 }
130135
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 4 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = base58'ALG9JVGNn9aCL68dbg1AmW6yDQv1b8EDLq99pQS8L1k6'
55
66 let b = [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
77
88 let c = base58'Co7gTLr7ZJvVKwToLpuZJqmkVecy5uwupYH6qCkKuhc8'
99
1010 let d = fromBase64String("base64:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjnt2PdN1Pdjd:
1111 7rsXzbapgucn9e1XffUx1o7grAlw8C6NFuv1PPj7KnQ6RtN9xhniLF4xKlc7//TYXd1uHWmx9vu9hjciYX9UMRJnhlZO2q34mxPdcgLDKhJHDN726KI0wHpFQ5dHMyzoMLdWsahFc1Wx/XxroK2Kc1y2JBWN2akRlkxSDcluqbbUcWMyrwG6iWuVlhej5xfcuerg/psK35WGn7SLF29tWuR2x+24nM+BJUsuRG7yBZUhGrYzJk2gvpucRLea6AFRvow7RdyMYAwKFrr6mgQ0VcUw2T750e1oGanY0UdU3NPsKIgvU4Ft4uibMlMMBJvcrsEbDQHfDlwIDAQAB")
1212
1313 let e = 0
1414
1515 let f = 1
1616
1717 let g = 2
1818
1919 let h = "G_GAMECOUNTER"
2020
2121 let i = "G_TOTALCRAPSBETS"
2222
2323 let j = 0
2424
2525 func k (l) = (l != a)
2626
2727
2828 func m (n) = (("G_" + toString(n)) + "_FIRSTPOINT")
2929
3030
3131 func o (n) = (("G_" + toString(n)) + "_CURRENTPOINT")
3232
3333
3434 func p (n) = (("G_" + toString(n)) + "_STATE")
3535
3636
3737 func q (n) = (("G_" + toString(n)) + "_SUMSHA")
3838
3939
4040 func r (n) = (("G_" + toString(n)) + "_STARTHEIGHT")
4141
4242
4343 func s (n) = getInteger(this, p(n))
4444
4545
4646 func t (n) = getString(this, q(n))
4747
4848
4949 func u (n) = getInteger(this, r(n))
5050
5151
5252 func v () = getInteger(this, h)
5353
5454
5555 func w (n) = getInteger(this, o(n))
5656
5757
5858 func x (n) = getInteger(this, m(n))
5959
6060
6161 @Callable(y)
6262 func initGame () = if (k(y.callerPublicKey))
6363 then throw("initGame_FORBIDDEN")
6464 else {
6565 let z = v()
6666 if ($isInstanceOf(z, "Int"))
6767 then {
6868 let A = z
6969 throw("INIT_ALREADY_DONE")
7070 }
7171 else [IntegerEntry(h, 0), IntegerEntry(i, 0)]
7272 }
7373
7474
7575
7676 @Callable(y)
7777 func startGame (B) = if (k(y.callerPublicKey))
7878 then throw("startGame_FORBIDDEN")
7979 else {
8080 let z = v()
8181 if ($isInstanceOf(z, "Int"))
8282 then {
8383 let C = z
8484 let D = (C + 1)
8585 [IntegerEntry(h, D), IntegerEntry(p(D), 0), IntegerEntry(r(D), lastBlock.height), StringEntry(q(D), toBase58String(sha256(fromBase64String(B))))]
8686 }
8787 else throw("INIT_NEED")
8888 }
8989
9090
9191
9292 @Callable(y)
9393 func throwDices (E,F) = if (k(y.callerPublicKey))
9494 then throw("throwDices_FORBIDDEN")
9595 else {
9696 let z = s(F)
9797 if ($isInstanceOf(z, "Int"))
9898 then {
9999 let G = z
100100 if ((G == g))
101101 then throw("Game is finished")
102102 else {
103103 let H = t(F)
104104 if ($isInstanceOf(H, "String"))
105105 then {
106106 let I = H
107107 let J = fromBase64String(E)
108108 let K = rsaVerify(SHA256, fromBase58String(I), J, d)
109109 let L = blockInfoByHeight((lastBlock.height - 1))
110110 if ($isInstanceOf(L, "BlockInfo"))
111111 then {
112112 let M = L
113113 let B = sha256((take(J, 4) + take(M.generationSignature, 4)))
114- throw(("fsdfsd " + toBase64String(B)))
114+ if (!(K))
115+ then throw("INVALID_RSA_SIGN")
116+ else {
117+ let N = (toInt(B) % 37)
118+ throw(("fsdfsd " + toBase64String(B)))
119+ }
115120 }
116121 else throw("Last block doesn't exist.")
117122 }
118123 else throw("SHA doesn't exist")
119124 }
120125 }
121126 else throw("Game does not exist or has already ended.")
122127 }
123128
124129
125-@Verifier(N)
126-func O () = {
127- let z = N
128- sigVerify(N.bodyBytes, N.proofs[0], N.senderPublicKey)
130+@Verifier(O)
131+func P () = {
132+ let z = O
133+ sigVerify(O.bodyBytes, O.proofs[0], O.senderPublicKey)
129134 }
130135

github/deemru/w8io/169f3d6 
35.71 ms