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