2019.03.04 03:46 [1421717] smart account 3PAdDG32kqsPQZgVonrNcLGEHQGg8ED47wS > SELF 0.00000000 Waves

{ "type": 13, "id": "9eHjysCrwLmoWKDX3JfhGNEBVhx5fesvt75x4nEcW14v", "fee": 1000000, "feeAssetId": null, "timestamp": 1551660472559, "version": 1, "sender": "3PAdDG32kqsPQZgVonrNcLGEHQGg8ED47wS", "senderPublicKey": "D55YNpPgDARtLsTtkaY6F8qv55GbZJtk1L2UFyr18FyR", "proofs": [ "2SCsFbqJ1jjaXxPEEGxHD4wV68T32t1Jj2ZmALafvCsspa4mRbBrXuTkdvhDbcDcVCpT6HbVQhbzCtfFmyRcG45t" ], "script": "base64:AQQAAAACbWUIBQAAAAJ0eAAAAAZzZW5kZXIEAAAABXR4RmVlAAAAAAAACSfABAAAAAd0aW1lb3V0AAAAAAAAAAAKBAAAAAhsaWZlc3BhbgAAAAAAAAAAHgQAAAADZXJyCQAAAgAAAAECAAAAAAQAAAAVc2VydmVyQ2hvaWNlSGFzaEJ5dGVzCQACWQAAAAECAAAALER3TXNXdkV3aDFHejluWldtUjJ4aFpRbXk4aENkU3J2TUQ0TlJxZ1QzVk02BAAAAA9zZXJ2ZXJQdWJsaWNLZXkJAAJZAAAAAQIAAAAsNmZLY25wV0w0djNLcTUxaTNqNnpvY3E4blpoNjhSMjQ1Q1Rha2tlSkxjcUYEAAAABnNlcnZlcgkBAAAAEWFkZHJlc3NGcm9tU3RyaW5nAAAAAQIAAAAjM1BNVDl3dW43QkI3SkFCU3VoVEpwRmdKb2VnUmZZdzJlNmQEAAAABnBsYXllcgkBAAAAEWFkZHJlc3NGcm9tU3RyaW5nAAAAAQIAAAAjM1AzTWtrMWZwNVQybVZEanR5c1VqRzlxTWY5Y2RGZXRBdmMEAAAAEHRvdGFsU2VydmVyRnVuZHMAAAAAAEsjOsAEAAAADnN0YXJ0aW5nSGVpZ2h0AAAAAAAAFbGVBAAAAAlkaWNlQ291bnQAAAAAAAAAAAMEAAAAA2JldAAAAAAAU3JOAAMJAABnAAAAAgUAAAAGaGVpZ2h0BQAAAA5zdGFydGluZ0hlaWdodAQAAAAHJG1hdGNoMAUAAAACdHgDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAE1RyYW5zZmVyVHJhbnNhY3Rpb24EAAAABnBheW91dAUAAAAHJG1hdGNoMAMDAwkBAAAAASEAAAABCQEAAAAJaXNEZWZpbmVkAAAAAQgFAAAABnBheW91dAAAAAdhc3NldElkCQEAAAABIQAAAAEJAQAAAAlpc0RlZmluZWQAAAABCAUAAAAGcGF5b3V0AAAACmZlZUFzc2V0SWQHCQAAZwAAAAIIBQAAAAZwYXlvdXQAAAADZmVlBQAAAAV0eEZlZQcDCQAAZgAAAAIJAABlAAAAAgUAAAAGaGVpZ2h0BQAAAA5zdGFydGluZ0hlaWdodAUAAAAIbGlmZXNwYW4EAAAADnNpZ25lZEJ5U2VydmVyCQAB9AAAAAMIBQAAAAZwYXlvdXQA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", "chainId": 87, "height": 1421717, "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 1 #-}
2+{-# CONTENT_TYPE EXPRESSION #-}
3+let me = tx.sender
4+let txFee = 600000
5+let timeout = 10
6+let lifespan = 30
7+let err = throw("")
8+let serverChoiceHashBytes = fromBase58String("DwMsWvEwh1Gz9nZWmR2xhZQmy8hCdSrvMD4NRqgT3VM6")
9+let serverPublicKey = fromBase58String("6fKcnpWL4v3Kq51i3j6zocq8nZh68R245CTakkeJLcqF")
10+let server = addressFromString("3PMT9wun7BB7JABSuhTJpFgJoegRfYw2e6d")
11+let player = addressFromString("3P3Mkk1fp5T2mVDjtysUjG9qMf9cdFetAvc")
12+let totalServerFunds = 1260600000
13+let startingHeight = 1421717
14+let diceCount = 3
15+let bet = 1400000000
16+if ((height >= startingHeight))
17+ then match tx {
18+ case payout: TransferTransaction =>
19+ if (if (if (!(isDefined(payout.assetId)))
20+ then !(isDefined(payout.feeAssetId))
21+ else false)
22+ then (payout.fee >= txFee)
23+ else false)
24+ then if (((height - startingHeight) > lifespan))
25+ then {
26+ let signedByServer = sigVerify(payout.bodyBytes, payout.proofs[0], serverPublicKey)
27+ if (signedByServer)
28+ then if ((payout.recipient == server))
29+ then true
30+ else (payout.recipient == player)
31+ else false
32+ }
33+ else {
34+ let paymentId = payout.proofs[0]
35+ match transactionById(paymentId) {
36+ case payment: TransferTransaction =>
37+ let paymentHeight = extract(transactionHeightById(paymentId))
38+ if (if (if (if ((payment.amount == bet))
39+ then (payment.recipient == me)
40+ else false)
41+ then (payment.sender == player)
42+ else false)
43+ then !(isDefined(payment.assetId))
44+ else false)
45+ then if (((paymentHeight - startingHeight) > timeout))
46+ then (payout.recipient == server)
47+ else if (if (((totalServerFunds + bet) > wavesBalance(me)))
48+ then true
49+ else ((height - paymentHeight) > timeout))
50+ then (payout.recipient == player)
51+ else {
52+ let serverChoiceWithSalt = payout.attachment
53+ let playerChoice = payment.attachment
54+ let s = size(playerChoice)
55+ let serverChoice = take(serverChoiceWithSalt, 1)
56+ let serverChoiceValid = if (if (if (if (if ((serverChoice == toBytes("1")))
57+ then true
58+ else (serverChoice == toBytes("2")))
59+ then true
60+ else (serverChoice == toBytes("3")))
61+ then true
62+ else (serverChoice == toBytes("4")))
63+ then true
64+ else (serverChoice == toBytes("5")))
65+ then true
66+ else (serverChoice == toBytes("6"))
67+ let playerWins = if (!(serverChoiceValid))
68+ then true
69+ else if ((s == diceCount))
70+ then if (if (if (if (if (if ((s >= 1))
71+ then (take(drop(playerChoice, 0), 1) == serverChoice)
72+ else false)
73+ then true
74+ else if ((s >= 2))
75+ then (take(drop(playerChoice, 1), 1) == serverChoice)
76+ else false)
77+ then true
78+ else if ((s >= 3))
79+ then (take(drop(playerChoice, 2), 1) == serverChoice)
80+ else false)
81+ then true
82+ else if ((s >= 4))
83+ then (take(drop(playerChoice, 3), 1) == serverChoice)
84+ else false)
85+ then true
86+ else if ((s >= 5))
87+ then (take(drop(playerChoice, 4), 1) == serverChoice)
88+ else false)
89+ then true
90+ else if ((s >= 6))
91+ then (take(drop(playerChoice, 5), 1) == serverChoice)
92+ else false
93+ else false
94+ let recipientValid = (payout.recipient == (if (playerWins)
95+ then player
96+ else server))
97+ let signedByServer = sigVerify(payout.bodyBytes, payout.proofs[1], serverPublicKey)
98+ let hashValid = (keccak256(serverChoiceWithSalt) == serverChoiceHashBytes)
99+ let serverChoiceAndSaltValid = (size(serverChoiceWithSalt) == 38)
100+ if (if (if (recipientValid)
101+ then signedByServer
102+ else false)
103+ then hashValid
104+ else false)
105+ then serverChoiceAndSaltValid
106+ else false
107+ }
108+ else false
109+ case _ =>
110+ err
111+ }
112+ }
113+ else false
114+ case _ =>
115+ err
116+ }
117+ else false

github/deemru/w8io/786bc32 
55.08 ms