tx · ERdzHedKxxQf8sn2S1TzC8ocgicoK9hWVYDQ9h87B5ad 3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ: -0.01400000 Waves 2021.05.14 04:34 [1524696] smart account 3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ > SELF 0.00000000 Waves
{ "type": 13, "id": "ERdzHedKxxQf8sn2S1TzC8ocgicoK9hWVYDQ9h87B5ad", "fee": 1400000, "feeAssetId": null, "timestamp": 1620956069713, "version": 1, "sender": "3MpdJJV3WyZufiGHRtb7xbY2Vsc2pBFcJYZ", "senderPublicKey": "ALG9JVGNn9aCL68dbg1AmW6yDQv1b8EDLq99pQS8L1k6", "proofs": [ "TRpGEkGxaRsAjvLqZAHbKeVYN4yNKooLGUEHsPtE5kzyBwQQ6DNHmEN4aU7uNSTR82jj92ZQaCH3k31LTwkWqyU" ], "script": "base64:AAIEAAAAAAAAAA8IAhIAEgMKAQgSBAoCCAEAAAAWAAAAABNnYW1lTWFzdGVyUHVibGljS2V5AQAAACCKqFcQ1VSNQa7ZONz4ZD59H7wLfuowVwcQ1qI/fK6ACwAAAAAKZGljZU51bWJlcgkABEwAAAACAAAAAAAAAAACCQAETAAAAAIAAAAAAAAAAAMJAARMAAAAAgAAAAAAAAAABAkABEwAAAACAAAAAAAAAAAFCQAETAAAAAIAAAAAAAAAAAYJAARMAAAAAgAAAAAAAAAABwkABEwAAAACAAAAAAAAAAAICQAETAAAAAIAAAAAAAAAAAkJAARMAAAAAgAAAAAAAAAACgkABEwAAAACAAAAAAAAAAALCQAETAAAAAIAAAAAAAAAAAwFAAAAA25pbAAAAAAJZ2FtZVRva2VuAQAAACCvQNOoGbkt3wVk9kpr+yD9dOUY7LBdGNCbLK5MVkSodQAAAAAJUlNBUFVCTElDCQACWwAAAAECAAABkmJhc2U2NDpNSUlCSWpBTkJna3Foa2lHOXcwQkFRRUZBQU9DQVE4QU1JSUJDZ0tDQVFFQWpudDJQZE4xUGRqZDoKN3JzWHpiYXBndWNuOWUxWGZmVXgxbzdnckFsdzhDNk5GdXYxUFBqN0tuUTZSdE45eGhuaUxGNHhLbGM3Ly9UWVhkMXVIV214OXZ1OWhqY2lZWDlVTVJKbmhsWk8ycTM0bXhQZGNnTERLaEpIRE43MjZLSTB3SHBGUTVkSE15em9NTGRXc2FoRmMxV3gvWHhyb0syS2MxeTJKQldOMmFrUmxreFNEY2x1cWJiVWNXTXlyd0c2aVd1VmxoZWo1eGZjdWVyZy9wc0szNVdHbjdTTEYyOXRXdVIyeCsyNG5NK0JKVXN1Ukc3eUJaVWhHcll6SmsyZ3ZwdWNSTGVhNkFGUnZvdzdSZHlNWUF3S0ZycjZtZ1EwVmNVdzJUNzUwZTFvR2FuWTBVZFUzTlBzS0lndlU0RnQ0dWliTWxNTUJKdmNyc0ViRFFIZkRsd0lEQVFBQgAAAAAJR0FNRVNUQVJUAAAAAAAAAAAAAAAAAA5HQU1FSU5QUk9HUkVTUwAAAAAAAAAAAQAAAAAMR0FNRUZJTklTSEVEAAAAAAAAAAACAAAAABBnYW1lQ291bnRlckxhYmVsAgAAAA1HX0dBTUVDT1VOVEVSAAAAABJnYW1lVG90YWxCZXRzTGFiZWwCAAAAEEdfVE9UQUxDUkFQU0JFVFMAAAAAEGxhc3RSb2xsZWROdW1iZXIAAAAAAAAAAAABAAAAE2F1dGhvcml6ZVBlcm1pc3Npb24AAAABAAAAD2NhbGxlclB1YmxpY0tleQkBAAAAAiE9AAAAAgUAAAAPY2FsbGVyUHVibGljS2V5BQAAABNnYW1lTWFzdGVyUHVibGljS2V5AQAAABlnYW1lQ3VycmVudFBvaW50RGljZUxhYmVsAAAAAQAAAAtnYW1lQ291bnRlcgkAASwAAAACCQABLAAAAAICAAAAAkdfCQABpAAAAAEFAAAAC2dhbWVDb3VudGVyAgAAAAtfRklSU1RQT0lOVAEAAAAXZ2FtZUZpcnN0UG9pbnREaWNlTGFiZWwAAAABAAAAC2dhbWVDb3VudGVyCQABLAAAAAIJAAEsAAAAAgIAAAACR18JAAGkAAAAAQUAAAALZ2FtZUNvdW50ZXICAAAADV9DVVJSRU5UUE9JTlQBAAAADmdhbWVTdGF0ZUxhYmVsAAAAAQAAAAtnYW1lQ291bnRlcgkAASwAAAACCQABLAAAAAICAAAAAkdfCQABpAAAAAEFAAAAC2dhbWVDb3VudGVyAgAAAAZfU1RBVEUBAAAAD2dhbWVTdW1TaGFMYWJlbAAAAAEAAAALZ2FtZUNvdW50ZXIJAAEsAAAAAgkAASwAAAACAgAAAAJHXwkAAaQAAAABBQAAAAtnYW1lQ291bnRlcgIAAAAHX1NVTVNIQQEAAAAUZ2FtZVN0YXJ0SGVpZ2h0TGFiZWwAAAABAAAAC2dhbWVDb3VudGVyCQABLAAAAAIJAAEsAAAAAgIAAAACR18JAAGkAAAAAQUAAAALZ2FtZUNvdW50ZXICAAAADF9TVEFSVEhFSUdIVAEAAAAMZ2V0R2FtZVN0YXRlAAAAAQAAAAtnYW1lQ291bnRlcgkABBoAAAACBQAAAAR0aGlzCQEAAAAOZ2FtZVN0YXRlTGFiZWwAAAABBQAAAAtnYW1lQ291bnRlcgEAAAANZ2V0R2FtZVN1bVNoYQAAAAEAAAALZ2FtZUNvdW50ZXIJAAQdAAAAAgUAAAAEdGhpcwkBAAAAD2dhbWVTdW1TaGFMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAQAAAA5nZXRTdGFydEhlaWdodAAAAAEAAAALZ2FtZUNvdW50ZXIJAAQaAAAAAgUAAAAEdGhpcwkBAAAAFGdhbWVTdGFydEhlaWdodExhYmVsAAAAAQUAAAALZ2FtZUNvdW50ZXIBAAAAEmdldENyYXBHYW1lQ291bnRlcgAAAAAJAAQaAAAAAgUAAAAEdGhpcwUAAAAQZ2FtZUNvdW50ZXJMYWJlbAEAAAARZ2V0Rmlyc3RQb2ludERpY2UAAAABAAAAC2dhbWVDb3VudGVyCQAEGgAAAAIFAAAABHRoaXMJAQAAABdnYW1lRmlyc3RQb2ludERpY2VMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAQAAABNnZXRDdXJyZW50UG9pbnREaWNlAAAAAQAAAAtnYW1lQ291bnRlcgkABBoAAAACBQAAAAR0aGlzCQEAAAAZZ2FtZUN1cnJlbnRQb2ludERpY2VMYWJlbAAAAAEFAAAAC2dhbWVDb3VudGVyAAAAAwAAAAFpAQAAAAhpbml0R2FtZQAAAAADCQEAAAATYXV0aG9yaXplUGVybWlzc2lvbgAAAAEIBQAAAAFpAAAAD2NhbGxlclB1YmxpY0tleQkAAAIAAAABAgAAABJpbml0R2FtZV9GT1JCSURERU4EAAAAByRtYXRjaDAJAQAAABJnZXRDcmFwR2FtZUNvdW50ZXIAAAAAAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAB2NvdW50ZXIFAAAAByRtYXRjaDAJAAACAAAAAQIAAAARSU5JVF9BTFJFQURZX0RPTkUJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEGdhbWVDb3VudGVyTGFiZWwAAAAAAAAAAAAJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIFAAAAEmdhbWVUb3RhbEJldHNMYWJlbAAAAAAAAAAAAAUAAAADbmlsAAAAAWkBAAAACXN0YXJ0R2FtZQAAAAEAAAAKcmFuZG9tSGFzaAMJAQAAABNhdXRob3JpemVQZXJtaXNzaW9uAAAAAQgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5CQAAAgAAAAECAAAAE3N0YXJ0R2FtZV9GT1JCSURERU4EAAAAByRtYXRjaDAJAQAAABJnZXRDcmFwR2FtZUNvdW50ZXIA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", "chainId": 84, "height": 1524696, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HpAAjMFKFaW1a6vrcB1gW5HgVmW1KiKJMR9EHyQUV5Dr Next: BD3d8Am9VRJnRDn68YHc2NTsfpnDVAzZZCahC9HngHHf Full:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 4 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let gameMasterPublicKey = base58'ALG9JVGNn9aCL68dbg1AmW6yDQv1b8EDLq99pQS8L1k6' | |
5 | 5 | ||
6 | 6 | let diceNumber = [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12] | |
7 | 7 | ||
8 | 8 | let gameToken = base58'Co7gTLr7ZJvVKwToLpuZJqmkVecy5uwupYH6qCkKuhc8' | |
9 | 9 | ||
10 | 10 | let RSAPUBLIC = fromBase64String("base64:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjnt2PdN1Pdjd: | |
11 | 11 | 7rsXzbapgucn9e1XffUx1o7grAlw8C6NFuv1PPj7KnQ6RtN9xhniLF4xKlc7//TYXd1uHWmx9vu9hjciYX9UMRJnhlZO2q34mxPdcgLDKhJHDN726KI0wHpFQ5dHMyzoMLdWsahFc1Wx/XxroK2Kc1y2JBWN2akRlkxSDcluqbbUcWMyrwG6iWuVlhej5xfcuerg/psK35WGn7SLF29tWuR2x+24nM+BJUsuRG7yBZUhGrYzJk2gvpucRLea6AFRvow7RdyMYAwKFrr6mgQ0VcUw2T750e1oGanY0UdU3NPsKIgvU4Ft4uibMlMMBJvcrsEbDQHfDlwIDAQAB") | |
12 | 12 | ||
13 | 13 | let GAMESTART = 0 | |
14 | 14 | ||
15 | 15 | let GAMEINPROGRESS = 1 | |
16 | 16 | ||
17 | 17 | let GAMEFINISHED = 2 | |
18 | 18 | ||
19 | 19 | let gameCounterLabel = "G_GAMECOUNTER" | |
20 | 20 | ||
21 | 21 | let gameTotalBetsLabel = "G_TOTALCRAPSBETS" | |
22 | 22 | ||
23 | 23 | let lastRolledNumber = 0 | |
24 | 24 | ||
25 | 25 | func authorizePermission (callerPublicKey) = (callerPublicKey != gameMasterPublicKey) | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func gameCurrentPointDiceLabel (gameCounter) = (("G_" + toString(gameCounter)) + "_FIRSTPOINT") | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | func gameFirstPointDiceLabel (gameCounter) = (("G_" + toString(gameCounter)) + "_CURRENTPOINT") | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | func gameStateLabel (gameCounter) = (("G_" + toString(gameCounter)) + "_STATE") | |
35 | 35 | ||
36 | 36 | ||
37 | 37 | func gameSumShaLabel (gameCounter) = (("G_" + toString(gameCounter)) + "_SUMSHA") | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func gameStartHeightLabel (gameCounter) = (("G_" + toString(gameCounter)) + "_STARTHEIGHT") | |
41 | 41 | ||
42 | 42 | ||
43 | 43 | func getGameState (gameCounter) = getInteger(this, gameStateLabel(gameCounter)) | |
44 | 44 | ||
45 | 45 | ||
46 | 46 | func getGameSumSha (gameCounter) = getString(this, gameSumShaLabel(gameCounter)) | |
47 | 47 | ||
48 | 48 | ||
49 | 49 | func getStartHeight (gameCounter) = getInteger(this, gameStartHeightLabel(gameCounter)) | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | func getCrapGameCounter () = getInteger(this, gameCounterLabel) | |
53 | 53 | ||
54 | 54 | ||
55 | 55 | func getFirstPointDice (gameCounter) = getInteger(this, gameFirstPointDiceLabel(gameCounter)) | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | func getCurrentPointDice (gameCounter) = getInteger(this, gameCurrentPointDiceLabel(gameCounter)) | |
59 | 59 | ||
60 | 60 | ||
61 | 61 | @Callable(i) | |
62 | 62 | func initGame () = if (authorizePermission(i.callerPublicKey)) | |
63 | 63 | then throw("initGame_FORBIDDEN") | |
64 | 64 | else match getCrapGameCounter() { | |
65 | 65 | case counter: Int => | |
66 | 66 | throw("INIT_ALREADY_DONE") | |
67 | 67 | case _ => | |
68 | 68 | [IntegerEntry(gameCounterLabel, 0), IntegerEntry(gameTotalBetsLabel, 0)] | |
69 | 69 | } | |
70 | 70 | ||
71 | 71 | ||
72 | 72 | ||
73 | 73 | @Callable(i) | |
74 | 74 | func startGame (randomHash) = if (authorizePermission(i.callerPublicKey)) | |
75 | 75 | then throw("startGame_FORBIDDEN") | |
76 | 76 | else match getCrapGameCounter() { | |
77 | 77 | case number: Int => | |
78 | 78 | let newNumber = (number + 1) | |
79 | 79 | [IntegerEntry(gameCounterLabel, newNumber), IntegerEntry(gameStateLabel(newNumber), 0), IntegerEntry(gameStartHeightLabel(newNumber), lastBlock.height), StringEntry(gameSumShaLabel(newNumber), toBase58String(sha256(fromBase64String(randomHash))))] | |
80 | 80 | case _ => | |
81 | 81 | throw("INIT_NEED") | |
82 | 82 | } | |
83 | 83 | ||
84 | 84 | ||
85 | 85 | ||
86 | 86 | @Callable(i) | |
87 | 87 | func throwDices (rsaSign,gameNumber) = if (authorizePermission(i.callerPublicKey)) | |
88 | 88 | then throw("throwDices_FORBIDDEN") | |
89 | 89 | else match getGameState(gameNumber) { | |
90 | 90 | case state: Int => | |
91 | 91 | if ((state == GAMEFINISHED)) | |
92 | 92 | then throw("Game is finished") | |
93 | 93 | else match getGameSumSha(gameNumber) { | |
94 | 94 | case sumSha: String => | |
95 | 95 | let sig = fromBase64String(rsaSign) | |
96 | 96 | let rsaSigValid = rsaVerify(SHA256, fromBase58String(sumSha), sig, RSAPUBLIC) | |
97 | 97 | match blockInfoByHeight((lastBlock.height - 1)) { | |
98 | 98 | case previousBlock: BlockInfo => | |
99 | 99 | let randomHash = sha256((take(sig, 4) + take(previousBlock.generationSignature, 4))) | |
100 | 100 | if (!(rsaSigValid)) | |
101 | 101 | then throw("INVALID_RSA_SIGN") | |
102 | 102 | else { | |
103 | 103 | let randNumber = (toInt(randomHash) % 37) | |
104 | 104 | throw(("fsdfsd " + toBase64String(randomHash))) | |
105 | 105 | } | |
106 | 106 | case _ => | |
107 | 107 | throw("Last block doesn't exist.") | |
108 | 108 | } | |
109 | 109 | case _ => | |
110 | 110 | throw("SHA doesn't exist") | |
111 | 111 | } | |
112 | 112 | case _ => | |
113 | 113 | throw("Game does not exist or has already ended.") | |
114 | 114 | } | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | @Verifier(tx) | |
118 | 118 | func verify () = match tx { | |
119 | 119 | case _ => | |
120 | 120 | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
121 | 121 | } | |
122 | 122 |
github/deemru/w8io/169f3d6 30.95 ms ◑