tx · LM6memssYxsuKRM4vY3jRxWkXJuKuwhfmMUhCi8df2E 3N7oes1Mab9zmCWuTdXSnKvkN6Y2pJc1dDe: -0.05000000 Waves 2021.04.21 19:52 [1492489] smart account 3N7oes1Mab9zmCWuTdXSnKvkN6Y2pJc1dDe > SELF 0.00000000 Waves
{ "type": 13, "id": "LM6memssYxsuKRM4vY3jRxWkXJuKuwhfmMUhCi8df2E", "fee": 5000000, "feeAssetId": null, "timestamp": 1619024040303, "version": 2, "chainId": 84, "sender": "3N7oes1Mab9zmCWuTdXSnKvkN6Y2pJc1dDe", "senderPublicKey": "4MMreyp5fK9PfGwiJTaZTXuPjY9Tj3qHt6pHiGJ8uyXJ", "proofs": [ "2hdarebGkTpuU1SwfxDboj1Kb643ntHDPGXm1Ce6Ua4p2QYBG5BD9qEeVQPxwawdVbM9az9UWet6sXp8w76mhSwc" ], "script": "base64:AAIDAAAAAAAAAAgIARIECgIICAAAAAcAAAAACVJTQVBVQkxJQwkAAlsAAAABAgAAAY9iYXNlNjQ6TUlJQklqQU5CZ2txaGtpRzl3MEJBUUVGQUFPQ0FROEFNSUlCQ2dLQ0FRRUF4WEl1cW1meEROa1Y1Sm85YXhudUZwQWpLSDJjeUdxUWNrandCcEZ6MnRZSlhOL01zRHVSa2gvdFpCdG5uUVRHM0VLK1hid1dGY1lIczRCb0h6aGFLRm9nNHhLclQ0bnRVYmNURTJBcVBzaFhpT3NJZUp2ZUdkSVQ3aC9IMkpkQVVGTXVyM3RsUFZYQTFmUnBsVjFXNjUxT0lhRThGK0NudkI5WVdjQVRCcXFVSzNZWWh3N1ZhK0RvenR2Snd2TnF1Y29ZbWRubmk2ejV2MHJDbEptaWZPSEJYRnMwVVFvN1JxaldoM0w5K2ZHak9qcVFMc0NlbWJJUWJsL1NJcVJtWDFIWWVtQjFHUUJTbDN1NUxpTTlON2hHU091djdNRklmMmV6UXlhZ1NicSt2LzN3QUR2UC9XdytxU2x4aWtKTmJqeFhwTGFMTEpYelR5ZUpEK2t0NHdJREFRQUIAAAAAD0dBTUVTQ09VTlRFUktFWQIAAAAJJEdBTUVfTlVNAAAAAA5TVEFURVNVQk1JVFRFRAIAAAAJU1VCTUlUVEVEAAAAAAhTVEFURVdPTgIAAAADV09OAAAAAAlTVEFURUxPU1QCAAAABExPU1QBAAAAEEluY3JlbWVudEdhbWVOdW0AAAAABAAAAAdnYW1lTnVtBAAAAAckbWF0Y2gwCQAEGgAAAAIFAAAABHRoaXMFAAAAD0dBTUVTQ09VTlRFUktFWQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAANudW0FAAAAByRtYXRjaDAFAAAAA251bQAAAAAAAAAAAAkAAGQAAAACBQAAAAdnYW1lTnVtAAAAAAAAAAABAQAAAA9HZW5lcmF0ZVJhbmRJbnQAAAACAAAABmdhbWVJZAAAAAdyc2FTaWduBAAAAAtyc2FTaWdWYWxpZAkAAfgAAAAEBQAAAAZTSEEyNTYJAAGbAAAAAQUAAAAGZ2FtZUlkBQAAAAdyc2FTaWduBQAAAAlSU0FQVUJMSUMDBQAAAAtyc2FTaWdWYWxpZAQAAAAEcmFuZAkAAGoAAAACCQAEsQAAAAEJAAH3AAAAAQUAAAAHcnNhU2lnbgAAAAAAAAAAlgMJAABmAAAAAgAAAAAAAAAAAAUAAAAEcmFuZAkAAGQAAAACCQAAaAAAAAIA//////////8FAAAABHJhbmQAAAAAAAAAAAEJAABkAAAAAgUAAAAEcmFuZAAAAAAAAAAAAQkAAAIAAAABAgAAABVJbnZhbGlkIFJTQSBzaWduYXR1cmUAAAABAAAAAWkBAAAABHRlc3QAAAACAAAABmdhbWVJZAAAAAhyc2FTaWducgQAAAAHcnNhU2lnbgkAAlsAAAABBQAAAAhyc2FTaWducgQAAAAEcmFuZAkBAAAAD0dlbmVyYXRlUmFuZEludAAAAAIFAAAABmdhbWVJZAUAAAAHcnNhU2lnbgkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAGZ2FtZUlkCQABLAAAAAICAAAABXJhbmQ6CQABpAAAAAEFAAAABHJhbmQFAAAAA25pbAAAAAB/1kJh", "height": 1492489, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 3QWrXjE5NFXrfh7KJEVDw5TtaU9VpyakapPTPVJ6eW5c Next: none Diff:
Old | New | Differences | |
---|---|---|---|
36 | 36 | ||
37 | 37 | ||
38 | 38 | @Callable(i) | |
39 | - | func init () = { | |
40 | - | let callerAddress = toBase58String(i.caller.bytes) | |
41 | - | let gameId = toBase58String(i.transactionId) | |
42 | - | let newGameNum = IncrementGameNum() | |
43 | - | WriteSet([DataEntry(((callerAddress + "_") + toString(newGameNum)), gameId)]) | |
44 | - | } | |
45 | - | ||
46 | - | ||
47 | - | ||
48 | - | @Callable(i) | |
49 | - | func game (gameId,rsaSignr) = { | |
50 | - | let rsaSign = fromBase64String(rsaSignr) | |
51 | - | let callerAddress = toBase58String(i.caller.bytes) | |
52 | - | let rand = GenerateRandInt(gameId, rsaSign) | |
53 | - | let amount = 10000 | |
54 | - | let userid = "123456" | |
55 | - | let risk = 3 | |
56 | - | if ((risk == 2)) | |
57 | - | then if ((73 > rand)) | |
58 | - | then WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "won:") + toString((amount * 2))))]) | |
59 | - | else WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "lost:") + toString(amount)))]) | |
60 | - | else if ((48 > rand)) | |
61 | - | then WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "won:") + toString((amount * 3))))]) | |
62 | - | else WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "lost:") + toString(amount)))]) | |
63 | - | } | |
64 | - | ||
65 | - | ||
66 | - | ||
67 | - | @Callable(i) | |
68 | 39 | func test (gameId,rsaSignr) = { | |
69 | 40 | let rsaSign = fromBase64String(rsaSignr) | |
70 | 41 | let rand = GenerateRandInt(gameId, rsaSign) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let RSAPUBLIC = fromBase64String("base64:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxXIuqmfxDNkV5Jo9axnuFpAjKH2cyGqQckjwBpFz2tYJXN/MsDuRkh/tZBtnnQTG3EK+XbwWFcYHs4BoHzhaKFog4xKrT4ntUbcTE2AqPshXiOsIeJveGdIT7h/H2JdAUFMur3tlPVXA1fRplV1W651OIaE8F+CnvB9YWcATBqqUK3YYhw7Va+DoztvJwvNqucoYmdnni6z5v0rClJmifOHBXFs0UQo7RqjWh3L9+fGjOjqQLsCembIQbl/SIqRmX1HYemB1GQBSl3u5LiM9N7hGSOuv7MFIf2ezQyagSbq+v/3wADvP/Ww+qSlxikJNbjxXpLaLLJXzTyeJD+kt4wIDAQAB") | |
5 | 5 | ||
6 | 6 | let GAMESCOUNTERKEY = "$GAME_NUM" | |
7 | 7 | ||
8 | 8 | let STATESUBMITTED = "SUBMITTED" | |
9 | 9 | ||
10 | 10 | let STATEWON = "WON" | |
11 | 11 | ||
12 | 12 | let STATELOST = "LOST" | |
13 | 13 | ||
14 | 14 | func IncrementGameNum () = { | |
15 | 15 | let gameNum = match getInteger(this, GAMESCOUNTERKEY) { | |
16 | 16 | case num: Int => | |
17 | 17 | num | |
18 | 18 | case _ => | |
19 | 19 | 0 | |
20 | 20 | } | |
21 | 21 | (gameNum + 1) | |
22 | 22 | } | |
23 | 23 | ||
24 | 24 | ||
25 | 25 | func GenerateRandInt (gameId,rsaSign) = { | |
26 | 26 | let rsaSigValid = rsaVerify(SHA256, toBytes(gameId), rsaSign, RSAPUBLIC) | |
27 | 27 | if (rsaSigValid) | |
28 | 28 | then { | |
29 | 29 | let rand = (toInt(sha256(rsaSign)) % 150) | |
30 | 30 | if ((0 > rand)) | |
31 | 31 | then ((-1 * rand) + 1) | |
32 | 32 | else (rand + 1) | |
33 | 33 | } | |
34 | 34 | else throw("Invalid RSA signature") | |
35 | 35 | } | |
36 | 36 | ||
37 | 37 | ||
38 | 38 | @Callable(i) | |
39 | - | func init () = { | |
40 | - | let callerAddress = toBase58String(i.caller.bytes) | |
41 | - | let gameId = toBase58String(i.transactionId) | |
42 | - | let newGameNum = IncrementGameNum() | |
43 | - | WriteSet([DataEntry(((callerAddress + "_") + toString(newGameNum)), gameId)]) | |
44 | - | } | |
45 | - | ||
46 | - | ||
47 | - | ||
48 | - | @Callable(i) | |
49 | - | func game (gameId,rsaSignr) = { | |
50 | - | let rsaSign = fromBase64String(rsaSignr) | |
51 | - | let callerAddress = toBase58String(i.caller.bytes) | |
52 | - | let rand = GenerateRandInt(gameId, rsaSign) | |
53 | - | let amount = 10000 | |
54 | - | let userid = "123456" | |
55 | - | let risk = 3 | |
56 | - | if ((risk == 2)) | |
57 | - | then if ((73 > rand)) | |
58 | - | then WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "won:") + toString((amount * 2))))]) | |
59 | - | else WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "lost:") + toString(amount)))]) | |
60 | - | else if ((48 > rand)) | |
61 | - | then WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "won:") + toString((amount * 3))))]) | |
62 | - | else WriteSet([DataEntry(((callerAddress + "userid:") + userid), ((((("rand:" + toString(rand)) + "risk:") + toString(risk)) + "lost:") + toString(amount)))]) | |
63 | - | } | |
64 | - | ||
65 | - | ||
66 | - | ||
67 | - | @Callable(i) | |
68 | 39 | func test (gameId,rsaSignr) = { | |
69 | 40 | let rsaSign = fromBase64String(rsaSignr) | |
70 | 41 | let rand = GenerateRandInt(gameId, rsaSign) | |
71 | 42 | WriteSet([DataEntry(gameId, ("rand:" + toString(rand)))]) | |
72 | 43 | } | |
73 | 44 | ||
74 | 45 |
github/deemru/w8io/169f3d6 35.59 ms ◑