tx · FbLfUuHxhBHJyyH9spkhGqtfp8TGDHhAHhYcFCX9LanU 3N5uzQBRwhLHDpXkQXKAKXLgsbfa9Sf2Hjf: -0.01400000 Waves 2019.07.03 08:33 [568821] smart account 3N5uzQBRwhLHDpXkQXKAKXLgsbfa9Sf2Hjf > SELF 0.00000000 Waves
{ "type": 13, "id": "FbLfUuHxhBHJyyH9spkhGqtfp8TGDHhAHhYcFCX9LanU", "fee": 1400000, "feeAssetId": null, "timestamp": 1562132066006, "version": 1, "sender": "3N5uzQBRwhLHDpXkQXKAKXLgsbfa9Sf2Hjf", "senderPublicKey": "35Xxuggtoeee4EV6BV6Y1s3pVar8eTJby7uFDU7i9tz6", "proofs": [ "3n3wuQTorf4mKX5j7WJ13LRmyarU2bmssPPMGNzp1JQqf82r6BNzMPCMQLcs45AGucaS3JF3U6BFLsdVFATaGEQQ" ], "script": "base64:AAIDAAAAAAAAAAAAAAAFAAAAAA9TZXJ2ZXJQdWJsaWNLZXkBAAAAIB7gtUehm6JC0/WALGrP9fklFpOaZB03pVThYrhCe2prAAAAABBSb3VsZXR0ZVNlY3Rpb25zAAAAAAAAAAAVAAAAAA1EYXRhR2FtZUlkS2V5AgAAAAtBUFBfR0FNRV9JRAAAAAAWRXJyb3JPbmx5V2F2ZXNBY2NlcHRlZAIAAAAZZXJyb3Jfb25seV93YXZlc19hY2NlcHRlZAEAAAAJTmV3R2FtZUlkAAAAAAQAAAAHZ2FtZU51bQQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAA1EYXRhR2FtZUlkS2V5AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAA251bQUAAAAHJG1hdGNoMAUAAAADbnVtAAAAAAAAAAAACQAAZAAAAAIFAAAAB2dhbWVOdW0AAAAAAAAAAAEAAAADAAAAAWkBAAAAD0dlbmVyYXRlUmFuZEludAAAAAIAAAAGZ2FtZUlkAAAAB3JzYVNpZ24EAAAAC3JzYVNpZ1ZhbGlkCQAB9AAAAAMJAAJZAAAAAQUAAAAGZ2FtZUlkCQACWQAAAAEFAAAAB3JzYVNpZ24FAAAAD1NlcnZlclB1YmxpY0tleQMFAAAAC3JzYVNpZ1ZhbGlkBAAAAARyYW5kCQAAagAAAAIJAASxAAAAAQkAAfcAAAABCQABmwAAAAEFAAAAB3JzYVNpZ24FAAAAEFJvdWxldHRlU2VjdGlvbnMJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAICAAAABG9yaWcJAASxAAAAAQkAAfcAAAABCQABmwAAAAEFAAAAB3JzYVNpZ24JAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAICAAAABHJhbmQFAAAABHJhbmQFAAAAA25pbAkAAAIAAAABAgAAABVJbnZhbGlkIFJTQSBzaWduYXR1cmUAAAABaQEAAAADYmV0AAAAAQAAAA5leHBlY3RlZFJlc3VsdAQAAAAKZ2FtZU51bWJlcgkBAAAACU5ld0dhbWVJZAAAAAAEAAAABmdhbWVJZAkAAlgAAAABCAUAAAABaQAAAA10cmFuc2FjdGlvbklkBAAAAANwbXQJAQAAAAdleHRyYWN0AAAAAQgFAAAAAWkAAAAHcGF5bWVudAkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgIAAAAEb3JpZwIAAAAACQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACAgAAAARyYW5kAgAAAAAFAAAAA25pbAAAAAFpAQAAAAZiZXQxMTEAAAABAAAADmV4cGVjdGVkUmVzdWx0BAAAABBsYXN0QXVjdGlvbklkS2V5AgAAAA9sYXN0X2F1Y3Rpb25faWQEAAAADWxhc3RBdWN0aW9uSWQEAAAAByRtYXRjaDAJAAQaAAAAAgUAAAAEdGhpcwUAAAAQbGFzdEF1Y3Rpb25JZEtleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAABAAAAAJpZAkAAGQAAAACBQAAAA1sYXN0QXVjdGlvbklkAAAAAAAAAAABBAAAAAxuZXdBdWN0aW9uSWQJAAGkAAAAAQUAAAACaWQEAAAAC293bmVyV2FsbGV0CQACWAAAAAEICAUAAAABaQAAAAZjYWxsZXIAAAAFYnl0ZXMEAAAAA3BtdAkBAAAABXZhbHVlAAAAAQgFAAAAAWkAAAAHcGF5bWVudAMJAQAAAAlpc0RlZmluZWQAAAABCAUAAAADcG10AAAAB2Fzc2V0SWQJAAACAAAAAQUAAAAWRXJyb3JPbmx5V2F2ZXNBY2NlcHRlZAQAAAAHYXNzZXRJZAkAAlgAAAABCQEAAAAFdmFsdWUAAAABCAUAAAADcG10AAAAB2Fzc2V0SWQEAAAAEmF1Y3Rpb25EdXJhdGlvbktleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAACV9kdXJhdGlvbgQAAAAQYXVjdGlvbk1pbkJpZEtleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAACF9taW5fYmlkBAAAABFhdWN0aW9uTGFzdEJpZEtleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAACV9sYXN0X2JpZAQAAAAWYXVjdGlvbkxhc3RCaWRPd25lcktleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAAD19sYXN0X2JpZF9vd25lcgQAAAAPYXVjdGlvbk93bmVyS2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAGX293bmVyBAAAABBhdWN0aW9uQW1vdW50S2V5CQABLAAAAAIJAAEsAAAAAgIAAAAIYXVjdGlvbl8FAAAADG5ld0F1Y3Rpb25JZAIAAAAHX2Ftb3VudAQAAAARYXVjdGlvbkFzc2V0SWRLZXkJAAEsAAAAAgkAASwAAAACAgAAAAhhdWN0aW9uXwUAAAAMbmV3QXVjdGlvbklkAgAAAAlfYXNzZXRfaWQEAAAAEmF1Y3Rpb25Jc0FjdGl2ZUtleQkAASwAAAACCQABLAAAAAICAAAACGF1Y3Rpb25fBQAAAAxuZXdBdWN0aW9uSWQCAAAACl9pc19hY3RpdmUEAAAADnVzZXJCYWxhbmNlS2V5CQABLAAAAAIJAAEsAAAAAgkAASwAAAACAgAAAAhiYWxhbmNlXwUAAAALb3duZXJXYWxsZXQCAAAAAV8FAAAAB2Fzc2V0SWQEAAAADWN1cnJlbnRBbW91bnQEAAAAByRtYXRjaDAJAAQaAAAAAgUAAAAEdGhpcwUAAAAOdXNlckJhbGFuY2VLZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAABYQUAAAAHJG1hdGNoMAUAAAABYQAAAAAAAAAAAAQAAAAJbmV3QW1vdW50CQAAZAAAAAIFAAAADWN1cnJlbnRBbW91bnQIBQAAAANwbXQAAAAGYW1vdW50CQEAAAAIV3JpdGVTZXQAAAABCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAABFhdWN0aW9uTGFzdEJpZEtleQAAAAAAAAAAAAkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAPYXVjdGlvbk93bmVyS2V5BQAAAAtvd25lcldhbGxldAkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgUAAAAQYXVjdGlvbkFtb3VudEtleQgFAAAAA3BtdAAAAAZhbW91bnQJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAEWF1Y3Rpb25Bc3NldElkS2V5BQAAAAdhc3NldElkCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAAA51c2VyQmFsYW5jZUtleQUAAAAJbmV3QW1vdW50CQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAABJhdWN0aW9uSXNBY3RpdmVLZXkGCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAABZhdWN0aW9uTGFzdEJpZE93bmVyS2V5AgAAAAAJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAAEGxhc3RBdWN0aW9uSWRLZXkFAAAAAmlkBQAAAANuaWwAAAABAAAAAnR4AQAAAAZ2ZXJpZnkAAAAAAwkAAfQAAAADCAUAAAACdHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAAJ0eAAAAAZwcm9vZnMAAAAAAAAAAAAIBQAAAAJ0eAAAAA9zZW5kZXJQdWJsaWNLZXkEAAAAByRtYXRjaDAFAAAAAnR4AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAABRTZXRTY3JpcHRUcmFuc2FjdGlvbgQAAAADc3R4BQAAAAckbWF0Y2gwBgcH+54uUQ==", "chainId": 84, "height": 568821, "spentComplexity": 0 } View: original | compacted Prev: 2mEKx4MyAMWiZ2yq99TmeHrdCc4PbXvpdwzjUC5D5UTd Next: 9oiWzGwKxUiZajjpzdfMUexkdrGqHz4BRVywRBP7kBvF Full:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let ServerPublicKey = base58'35Xxuggtoeee4EV6BV6Y1s3pVar8eTJby7uFDU7i9tz6' | |
5 | + | ||
6 | + | let RouletteSections = 21 | |
7 | + | ||
8 | + | let DataGameIdKey = "APP_GAME_ID" | |
9 | + | ||
10 | + | let ErrorOnlyWavesAccepted = "error_only_waves_accepted" | |
11 | + | ||
12 | + | func NewGameId () = { | |
13 | + | let gameNum = match getInteger(this, DataGameIdKey) { | |
14 | + | case num: Int => | |
15 | + | num | |
16 | + | case _ => | |
17 | + | 0 | |
18 | + | } | |
19 | + | (gameNum + 1) | |
20 | + | } | |
4 | 21 | ||
5 | 22 | ||
6 | 23 | @Callable(i) | |
7 | - | func deposit () = { | |
24 | + | func GenerateRandInt (gameId,rsaSign) = { | |
25 | + | let rsaSigValid = sigVerify(fromBase58String(gameId), fromBase58String(rsaSign), ServerPublicKey) | |
26 | + | if (rsaSigValid) | |
27 | + | then { | |
28 | + | let rand = (toInt(sha256(toBytes(rsaSign))) % RouletteSections) | |
29 | + | WriteSet([DataEntry("orig", toInt(sha256(toBytes(rsaSign)))), DataEntry("rand", rand)]) | |
30 | + | } | |
31 | + | else throw("Invalid RSA signature") | |
32 | + | } | |
33 | + | ||
34 | + | ||
35 | + | ||
36 | + | @Callable(i) | |
37 | + | func bet (expectedResult) = { | |
38 | + | let gameNumber = NewGameId() | |
39 | + | let gameId = toBase58String(i.transactionId) | |
8 | 40 | let pmt = extract(i.payment) | |
41 | + | WriteSet([DataEntry("orig", ""), DataEntry("rand", "")]) | |
42 | + | } | |
43 | + | ||
44 | + | ||
45 | + | ||
46 | + | @Callable(i) | |
47 | + | func bet111 (expectedResult) = { | |
48 | + | let lastAuctionIdKey = "last_auction_id" | |
49 | + | let lastAuctionId = match getInteger(this, lastAuctionIdKey) { | |
50 | + | case a: Int => | |
51 | + | a | |
52 | + | case _ => | |
53 | + | 0 | |
54 | + | } | |
55 | + | let id = (lastAuctionId + 1) | |
56 | + | let newAuctionId = toString(id) | |
57 | + | let ownerWallet = toBase58String(i.caller.bytes) | |
58 | + | let pmt = value(i.payment) | |
9 | 59 | if (isDefined(pmt.assetId)) | |
10 | - | then throw( | |
60 | + | then throw(ErrorOnlyWavesAccepted) | |
11 | 61 | else { | |
12 | - | let currentKey = toBase58String(i.caller.bytes) | |
13 | - | let currentAmount = match getInteger(this, currentKey) { | |
62 | + | let assetId = toBase58String(value(pmt.assetId)) | |
63 | + | let auctionDurationKey = (("auction_" + newAuctionId) + "_duration") | |
64 | + | let auctionMinBidKey = (("auction_" + newAuctionId) + "_min_bid") | |
65 | + | let auctionLastBidKey = (("auction_" + newAuctionId) + "_last_bid") | |
66 | + | let auctionLastBidOwnerKey = (("auction_" + newAuctionId) + "_last_bid_owner") | |
67 | + | let auctionOwnerKey = (("auction_" + newAuctionId) + "_owner") | |
68 | + | let auctionAmountKey = (("auction_" + newAuctionId) + "_amount") | |
69 | + | let auctionAssetIdKey = (("auction_" + newAuctionId) + "_asset_id") | |
70 | + | let auctionIsActiveKey = (("auction_" + newAuctionId) + "_is_active") | |
71 | + | let userBalanceKey = ((("balance_" + ownerWallet) + "_") + assetId) | |
72 | + | let currentAmount = match getInteger(this, userBalanceKey) { | |
14 | 73 | case a: Int => | |
15 | 74 | a | |
16 | 75 | case _ => | |
17 | 76 | 0 | |
18 | 77 | } | |
19 | 78 | let newAmount = (currentAmount + pmt.amount) | |
20 | - | WriteSet([DataEntry( | |
79 | + | WriteSet([DataEntry(auctionLastBidKey, 0), DataEntry(auctionOwnerKey, ownerWallet), DataEntry(auctionAmountKey, pmt.amount), DataEntry(auctionAssetIdKey, assetId), DataEntry(userBalanceKey, newAmount), DataEntry(auctionIsActiveKey, true), DataEntry(auctionLastBidOwnerKey, ""), DataEntry(lastAuctionIdKey, id)]) | |
21 | 80 | } | |
22 | 81 | } | |
23 | 82 | ||
24 | 83 | ||
25 | - | ||
26 | - | @Callable(i) | |
27 | - | func withdraw (amount) = { | |
28 | - | let currentKey = toBase58String(i.caller.bytes) | |
29 | - | let currentAmount = match getInteger(this, currentKey) { | |
30 | - | case a: Int => | |
31 | - | a | |
84 | + | @Verifier(tx) | |
85 | + | func verify () = if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
86 | + | then match tx { | |
87 | + | case stx: SetScriptTransaction => | |
88 | + | true | |
32 | 89 | case _ => | |
33 | - | | |
90 | + | false | |
34 | 91 | } | |
35 | - | let newAmount = (currentAmount - amount) | |
36 | - | if ((0 > amount)) | |
37 | - | then throw("Can't withdraw negative amount") | |
38 | - | else if ((0 > newAmount)) | |
39 | - | then throw("Not enough balance") | |
40 | - | else ScriptResult(WriteSet([DataEntry(currentKey, newAmount)]), TransferSet([ScriptTransfer(i.caller, amount, unit)])) | |
41 | - | } | |
42 | - | ||
43 | - | ||
44 | - | @Verifier(tx) | |
45 | - | func verify () = true | |
92 | + | else false | |
46 | 93 |
github/deemru/w8io/026f985 23.31 ms ◑