tx · 4BWx5YweBxsTU7F51Yi5QLsLJ1MzfotiJhRUojKX3yzY 3N2Z6EjzrzaCpD8ypDYLWDKe2PPVU8y9dJs: -0.01400000 Waves 2019.09.02 17:32 [658453] smart account 3N2Z6EjzrzaCpD8ypDYLWDKe2PPVU8y9dJs > SELF 0.00000000 Waves
{ "type": 13, "id": "4BWx5YweBxsTU7F51Yi5QLsLJ1MzfotiJhRUojKX3yzY", "fee": 1400000, "feeAssetId": null, "timestamp": 1567434671784, "version": 1, "sender": "3N2Z6EjzrzaCpD8ypDYLWDKe2PPVU8y9dJs", "senderPublicKey": "HSTmdhPrJF81ozDBaqVn8QVtV76oD7gzDfcHPQRdxdwW", "proofs": [ "2Rz9ym5JoNDUhYW1EHDzoHxCGiy9wTN2JwF5ke6RfTX3qyuaHAWvSVB9rcgijGTN8virqdarJf4o6aB3Hvzirhdp" ], "script": "base64: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", "chainId": 84, "height": 658453, "spentComplexity": 0 } View: original | compacted Prev: ACyzfJ9LZXRCTs4SxppprFe2xKuLFqthP2moUCJanFik Next: DHUxNBPJ575cWen318CiHp5hibxXjjgzd8WmqpKV9QM1 Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let ServerPublicKey = fromBase58String(" | |
4 | + | let ServerPublicKey = fromBase58String("7im9caiCmE4SL6jTm4KTicHH4bGPf5v59rnfUA3cCRDj") | |
5 | 5 | ||
6 | 6 | let WAVELET = ((100 * 1000) * 1000) | |
7 | 7 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let ServerPublicKey = fromBase58String(" | |
4 | + | let ServerPublicKey = fromBase58String("7im9caiCmE4SL6jTm4KTicHH4bGPf5v59rnfUA3cCRDj") | |
5 | 5 | ||
6 | 6 | let WAVELET = ((100 * 1000) * 1000) | |
7 | 7 | ||
8 | 8 | let COMMISSION = ((5 * WAVELET) / 1000) | |
9 | 9 | ||
10 | 10 | let TicketsRate = 100 | |
11 | 11 | ||
12 | 12 | func GenerateRandInt (gameId,rsaSign,lastTicket) = { | |
13 | 13 | let rsaSigValid = sigVerify(toBytes(gameId), rsaSign, ServerPublicKey) | |
14 | 14 | if (rsaSigValid) | |
15 | 15 | then { | |
16 | 16 | let rand = (toInt(sha256(rsaSign)) % lastTicket) | |
17 | 17 | if ((0 > rand)) | |
18 | 18 | then ((-1 * rand) + 1) | |
19 | 19 | else (rand + 1) | |
20 | 20 | } | |
21 | 21 | else throw("Invalid RSA signature") | |
22 | 22 | } | |
23 | 23 | ||
24 | 24 | ||
25 | 25 | func getPlayers (gameId) = { | |
26 | 26 | let rawDataStr = match getString(this, gameId) { | |
27 | 27 | case str: String => | |
28 | 28 | str | |
29 | 29 | case _ => | |
30 | 30 | throw(("Couldn't find game by " + gameId)) | |
31 | 31 | } | |
32 | 32 | split(rawDataStr, "_") | |
33 | 33 | } | |
34 | 34 | ||
35 | 35 | ||
36 | 36 | func getPlayersTickets (gameId,Player) = { | |
37 | 37 | let playerTicketsStr = match getString(this, ((gameId + "_") + Player)) { | |
38 | 38 | case str: String => | |
39 | 39 | str | |
40 | 40 | case _ => | |
41 | 41 | throw(("Couldn't find game by " + gameId)) | |
42 | 42 | } | |
43 | 43 | split(playerTicketsStr, " ") | |
44 | 44 | } | |
45 | 45 | ||
46 | 46 | ||
47 | 47 | @Callable(i) | |
48 | 48 | func bet () = { | |
49 | 49 | let gameId = toBase58String(i.transactionId) | |
50 | 50 | let pmt = extract(i.payment) | |
51 | 51 | let betNotInWaves = isDefined(pmt.assetId) | |
52 | 52 | let feeNotInWaves = isDefined(pmt.assetId) | |
53 | 53 | let playerPubKey58 = toBase58String(i.callerPublicKey) | |
54 | 54 | let playerAddress = addressFromPublicKey(fromBase58String(playerPubKey58)) | |
55 | 55 | if (betNotInWaves) | |
56 | 56 | then throw("Bet amount must be in Waves") | |
57 | 57 | else if (feeNotInWaves) | |
58 | 58 | then throw("Transaction's fee must be in Waves") | |
59 | 59 | else { | |
60 | 60 | let gameDataStr = toString(playerAddress) | |
61 | 61 | let betData = [DataEntry(gameId, gameDataStr)] | |
62 | 62 | WriteSet(betData) | |
63 | 63 | } | |
64 | 64 | } | |
65 | 65 | ||
66 | 66 | ||
67 | 67 | ||
68 | 68 | @Callable(i) | |
69 | 69 | func generateResult (gameId,rsaSignCrypted,lastTicket,winAmt) = { | |
70 | 70 | let rsaSign = fromBase58String(rsaSignCrypted) | |
71 | 71 | let randTicket = GenerateRandInt(gameId, rsaSign, lastTicket) | |
72 | 72 | let playersList = getPlayers(gameId) | |
73 | 73 | let player1Tickets = getPlayersTickets(gameId, playersList[0]) | |
74 | 74 | let player1TicketFirst = parseIntValue(player1Tickets[0]) | |
75 | 75 | let player1TicketLast = parseIntValue(player1Tickets[1]) | |
76 | 76 | if (if ((randTicket >= player1TicketFirst)) | |
77 | 77 | then (player1TicketLast >= randTicket) | |
78 | 78 | else false) | |
79 | 79 | then TransferSet([ScriptTransfer(addressFromStringValue(playersList[0]), winAmt, unit)]) | |
80 | 80 | else throw("Player1 not the Winner") | |
81 | 81 | } | |
82 | 82 | ||
83 | 83 | ||
84 | 84 | @Verifier(tx) | |
85 | 85 | func verify () = if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
86 | 86 | then match tx { | |
87 | 87 | case ttx: TransferTransaction => | |
88 | 88 | true | |
89 | 89 | case stx: SetScriptTransaction => | |
90 | 90 | true | |
91 | 91 | case _ => | |
92 | 92 | false | |
93 | 93 | } | |
94 | 94 | else false | |
95 | 95 |
github/deemru/w8io/169f3d6 38.00 ms ◑