tx · 3M5TP3Qg52qK68TFsaeDTNtoWGGEDLanGEZUMDSw4Bzm 3N2BrWKSDmaxT3QjEZQzdYTkuPSSyqBkkBC: -0.01000000 Waves 2019.12.25 17:40 [824659] smart account 3N2BrWKSDmaxT3QjEZQzdYTkuPSSyqBkkBC > SELF 0.00000000 Waves
{ "type": 13, "id": "3M5TP3Qg52qK68TFsaeDTNtoWGGEDLanGEZUMDSw4Bzm", "fee": 1000000, "feeAssetId": null, "timestamp": 1577284818042, "version": 1, "sender": "3N2BrWKSDmaxT3QjEZQzdYTkuPSSyqBkkBC", "senderPublicKey": "2oQXihmidYab6A9qGjZvJd6gYHb6Y4dPodFMToSEpR3t", "proofs": [ "4j9uTmdsxPt7TRsk4WtxjBUfN43yNwHCjtPCnANAitbV7oVygAGAZgFey2gbZgqA73CAwiMXGvth2jdpwEYEWyYd" ], "script": "base64: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AAAAAgkAASwAAAACCQABLAAAAAIFAAAAD25ld1dpbkhlaWdodFN0cgIAAAABXwUAAAAVbmV3VG90YWxHYW1lc0NvdW50U3RyAgAAAAFfBQAAABJuZXdMYXN0UGxheWVyc0FkZHIFAAAAA25pbAMJAAAAAAAAAgUAAAAEdHlwZQIAAAAIV0lUSERSQVcJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgUAAAAJcm91bmREYXRhBQAAAANuaWwJAAACAAAAAQkAASwAAAACAgAAADBVbnN1cHBvcnRlZCB0eXBlIGluIHdyaXRlU2V0T2ZSb3VuZERhdGEgbWV0aG9kOiAFAAAABHR5cGUAAAAABm9mZnNldAkAAGUAAAACBQAAAAZoZWlnaHQFAAAAEWJsb2Nrc09uR2FtZVN0YXJ0AAAAAAxjdXJyUm91bmROdW0DCQAAZwAAAAIFAAAABm9mZnNldAAAAAAAAAAAAAkAAGkAAAACBQAAAAZvZmZzZXQFAAAADmJsb2Nrc1BlclJvdW5kCQAAAgAAAAEJAAEsAAAAAgIAAAAtUGxlYXNlIGRvIG5vdCBodXJyeS4gTVJUIHBhcnR5IHdpbGwgc3RhcnQgb24gCQABpAAAAAEFAAAAEWJsb2Nrc09uR2FtZVN0YXJ0AAAAAA9jdXJyUm91bmRIZWlnaHQJAABqAAAAAgUAAAAGb2Zmc2V0BQAAAA5ibG9ja3NQZXJSb3VuZAAAAAAUY3VyclJvdW5kSGVpZ2h0U3RhcnQJAABkAAAAAgkAAGgAAAACBQAAAAxjdXJyUm91bmROdW0FAAAADmJsb2Nrc1BlclJvdW5kBQAAABFibG9ja3NPbkdhbWVTdGFydAAAAAAXY3VyclJvdW5kQ29tcGV0aXRpb25FbmQJAABkAAAAAgUAAAAUY3VyclJvdW5kSGVpZ2h0U3RhcnQFAAAAFGJsb2Nrc1BlckNvbXBldGl0aW9uAAAAABFjdXJyUm91bmREYXRhTGlzdAkBAAAAF3JlYWRSb3VuZERhdGFMaXN0T3JGYWlsAAAAAQUAAAAMY3VyclJvdW5kTnVtAAAAAA1jdXJyV2luSGVpZ2h0CQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAARY3VyclJvdW5kRGF0YUxpc3QFAAAADElkeFdpbkhlaWdodAAAAAANY3Vyck1pblBtdEFtdAUAAAAHcG10U3RlcAEAAAANaXNXaW5CeUhlaWdodAAAAAEAAAABaAkAAGcAAAACBQAAAAZoZWlnaHQFAAAAAWgAAAAAHGF0TGVhc3RPbmVNb3ZlSW5Sb3VuZFByZXNlbnQJAABmAAAAAgUAAAANY3VycldpbkhlaWdodAUAAAAUY3VyclJvdW5kSGVpZ2h0U3RhcnQAAAAAFmZpcnN0Q291bnRkb3duRmluaXNoZWQDCQAAAAAAAAIFAAAADWN1cnJXaW5IZWlnaHQAAAAAAAAAAAAJAQAAAA1pc1dpbkJ5SGVpZ2h0AAAAAQkAAGQAAAACBQAAABRjdXJyUm91bmRIZWlnaHRTdGFydAUAAAAKaGVpZ2h0U3RlcAcAAAAADGlzUGF1c2VCeVdpbgMJAQAAAA1pc1dpbkJ5SGVpZ2h0AAAAAQUAAAANY3VycldpbkhlaWdodAUAAAAcYXRMZWFzdE9uZU1vdmVJblJvdW5kUHJlc2VudAcAAAAADWlzUGF1c2VCeVRpbWUDCQAAZgAAAAIFAAAAD2N1cnJSb3VuZEhlaWdodAUAAAAUYmxvY2tzUGVyQ29tcGV0aXRpb24GBQAAABZmaXJzdENvdW50ZG93bkZpbmlzaGVkAAAAAAdpc1BhdXNlAwUAAAAMaXNQYXVzZUJ5V2luBgUAAAANaXNQYXVzZUJ5VGltZQAAAAANaXNDb21wZXRpdGlvbgkBAAAAASEAAAABBQAAAAdpc1BhdXNlAAAAAgAAAANpbnYBAAAABG1vdmUAAAAABAAAABZvdmVyZmxvd2VkTmV3V2luSGVpZ2h0CQAAZAAAAAIFAAAABmhlaWdodAUAAAAKaGVpZ2h0U3RlcAQAAAAMbmV3V2luSGVpZ2h0AwkAAGcAAAACBQAAABZvdmVyZmxvd2VkTmV3V2luSGVpZ2h0BQAAABdjdXJyUm91bmRDb21wZXRpdGlvbkVuZAUAAAAXY3VyclJvdW5kQ29tcGV0aXRpb25FbmQFAAAAFm92ZXJmbG93ZWROZXdXaW5IZWlnaHQEAAAAB3BheW1lbnQDCQEAAAAJaXNEZWZpbmVkAAAAAQgFAAAAA2ludgAAAAdwYXltZW50CQEAAAAHZXh0cmFjdAAAAAEIBQAAAANpbnYAAAAHcGF5bWVudAkAAAIAAAABAgAAADpQbGVhc2UgYXR0YWNoIHBheW1lbnQgd2l0aCBNUlQgdG8gcGFydGljaXBhdGUgaW4gTVJUIHBhcnR5AwkAAGcAAAACBQAAAAxjdXJyUm91bmROdW0FAAAACW1heFJvdW5kcwkAAAIAAAABAgAAABFNUlQgcGFydHkgaXMgb3ZlcgMFAAAAB2lzUGF1c2UJAAACAAAAAQkAASwAAAACCQABLAAAAAICAAAAEVNvcnJ5IGJ1dCByb3VuZCAjCQABpAAAAAEFAAAADGN1cnJSb3VuZE51bQIAAAANIGlzIGZpbmlzaGVkLgMJAQAAAAIhPQAAAAIIBQAAAAdwYXltZW50AAAAB2Fzc2V0SWQFAAAAA01SVAkAAAIAAAABAgAAAD1QbGVhc2UgdXNlIE1SVCBhcyBhIHBheW1lbnQgYXNzZXQgdG8gcGFydGljaXBhdGUgaW4gTVJUIHBhcnR5AwkAAGYAAAACBQAAAA1jdXJyTWluUG10QW10CAUAAAAHcGF5bWVudAAAAAZhbW91bnQJAAACAAAAAQkAASwAAAACAgAAAEZTb3JyeSBteSBmcmllbmQgYnV0IHlvdXIgcGF5bWVudCBpcyB0b28gc21hbGwuIEN1cnJlbnQgbWluIHBheW1lbnQgaXMgCQABpAAAAAEFAAAADWN1cnJNaW5QbXRBbXQJAQAAABN3cml0ZVNldE9mUm91bmREYXRhAAAABgIAAAAETU9WRQUAAAAMY3VyclJvdW5kTnVtBQAAAAxuZXdXaW5IZWlnaHQJAAQlAAAAAQkBAAAAFGFkZHJlc3NGcm9tUHVibGljS2V5AAAAAQgFAAAAA2ludgAAAA9jYWxsZXJQdWJsaWNLZXkJAAJYAAAAAQgFAAAAA2ludgAAAA9jYWxsZXJQdWJsaWNLZXkCAAAAAT8AAAADaW52AQAAAAh3aXRoZHJhdwAAAAEAAAAFcm91bmQEAAAADXJvdW5kRGF0YUxpc3QJAQAAABdyZWFkUm91bmREYXRhTGlzdE9yRmFpbAAAAAEFAAAABXJvdW5kBAAAAAx3aW5uZXJQdWJLZXkJAAJZAAAAAQkAAZEAAAACBQAAAA1yb3VuZERhdGFMaXN0BQAAAAxJZHhXaW5QdWJLZXkEAAAADHdpdGhkcmF3SWQ1OAkAAZEAAAACBQAAAA1yb3VuZERhdGFMaXN0BQAAAA1JZHhXaXRoZHJhd0lkAwkAAGYAAAACBQAAAAVyb3VuZAUAAAAMY3VyclJvdW5kTnVtCQAAAgAAAAECAAAANUltcG9zc2libGUgdG8gd2l0aGRyYXcgd2luIGFtb3VudCBmb3Igcm91bmQgaW4gZnV0dXJlAwMJAAAAAAAAAgUAAAAFcm91bmQFAAAADGN1cnJSb3VuZE51bQUAAAANaXNDb21wZXRpdGlvbgcJAAACAAAAAQIAAABGSW1wb3NzaWJsZSB0byB3aXRoZHJhdyB3aW4gYW1vdW50IC0gd2lubmVyIGhhcyBub3QgYmVlbiBkZXRlcm1pbmVkIHlldAMJAQAAAAIhPQAAAAIFAAAADHdpdGhkcmF3SWQ1OAIAAAABPwkAAAIAAAABCQABLAAAAAIJAAEsAAAAAgIAAAARV2lubmVyIG9mIHJvdW5kICMJAAGkAAAAAQUAAAAFcm91bmQCAAAAHCBoYXMgYWxyZWFkeSB0YWtlbiB0aGUgcHJpemUEAAAAE3dpdGhkcmF3UGVyaW9kRW5kZWQJAABmAAAAAgUAAAAGaGVpZ2h0CQAAZAAAAAIJAABkAAAAAgUAAAARYmxvY2tzT25HYW1lU3RhcnQJAABoAAAAAgUAAAAJbWF4Um91bmRzBQAAAA5ibG9ja3NQZXJSb3VuZAUAAAAOd2l0aGRyYXdQZXJpb2QEAAAAD3dpbkFtdFJlY2lwaWVudAMFAAAAE3dpdGhkcmF3UGVyaW9kRW5kZWQFAAAAEXBhcnR5T3duZXJBZGRyZXNzCQEAAAAUYWRkcmVzc0Zyb21QdWJsaWNLZXkAAAABBQAAAAx3aW5uZXJQdWJLZXkEAAAADnJvdW5kV2luSGVpZ2h0CQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAANcm91bmREYXRhTGlzdAUAAAAMSWR4V2luSGVpZ2h0CQEAAAAMU2NyaXB0UmVzdWx0AAAAAgkBAAAAE3dyaXRlU2V0T2ZSb3VuZERhdGEAAAAGAgAAAAhXSVRIRFJBVwUAAAAFcm91bmQFAAAADnJvdW5kV2luSGVpZ2h0CQABkQAAAAIFAAAADXJvdW5kRGF0YUxpc3QFAAAADUlkeFdpbkFkZHJlc3MJAAGRAAAAAgUAAAANcm91bmREYXRhTGlzdAUAAAAMSWR4V2luUHViS2V5CQACWAAAAAEIBQAAAANpbnYAAAANdHJhbnNhY3Rpb25JZAkBAAAAC1RyYW5zZmVyU2V0AAAAAQkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADBQAAAA93aW5BbXRSZWNpcGllbnQFAAAABndpbkFtdAUAAAAEdW5pdAUAAAADbmlsAAAAAQAAAAJ0eAEAAAAGdmVyaWZ5AAAAAAQAAAATd2l0aGRyYXdQZXJpb2RFbmRlZAkAAGYAAAACBQAAAAZoZWlnaHQJAABkAAAAAgkAAGQAAAACBQAAABFibG9ja3NPbkdhbWVTdGFydAkAAGgAAAACBQAAAAltYXhSb3VuZHMFAAAADmJsb2Nrc1BlclJvdW5kBQAAAA53aXRoZHJhd1BlcmlvZAQAAAAHJG1hdGNoMAUAAAACdHgDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAE1RyYW5zZmVyVHJhbnNhY3Rpb24EAAAAA3R0eAUAAAAHJG1hdGNoMAMJAQAAAAEhAAAAAQUAAAATd2l0aGRyYXdQZXJpb2RFbmRlZAkAAAIAAAABAgAAADhNUlQgcGFydHkgaGFzIG5vdCBmaW5pc2hlZCB5ZXQuIFRyYW5zZmVyIGlzIG5vdCBhbGxvd2VkLgMJAQAAAAEhAAAAAQkAAfQAAAADCAUAAAADdHR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAADdHR4AAAABnByb29mcwAAAAAAAAAAAAUAAAAQcGFydHlPd25lclB1YktleQkAAAIAAAABAgAAAClUcmFuc2ZlciBpcyBhbGxvd2VkIGZvciBQYXJ0eSBPd25lciBvbmx5LgMJAQAAAAIhPQAAAAIIBQAAAAN0dHgAAAADZmVlBQAAAAZNaW5GRUUJAAACAAAAAQkAASwAAAACAgAAADVJbXBvc3NpYmxlIHRvIHRyYW5zZmVyIHdpdGggZmVlIGxlc3Mgb3IgZ3JlYXRlciB0aGFuIAkAAaQAAAABBQAAAAZNaW5GRUUGAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAA9CdXJuVHJhbnNhY3Rpb24EAAAAA2J0eAUAAAAHJG1hdGNoMAMJAQAAAAEhAAAAAQUAAAATd2l0aGRyYXdQZXJpb2RFbmRlZAkAAAIAAAABAgAAADRNUlQgcGFydHkgaGFzIG5vdCBmaW5pc2hlZCB5ZXQuIEJ1cm4gaXMgbm90IGFsbG93ZWQuAwkBAAAAASEAAAABCQAB9AAAAAMIBQAAAANidHgAAAAJYm9keUJ5dGVzCQABkQAAAAIIBQAAAANidHgAAAAGcHJvb2ZzAAAAAAAAAAAABQAAABBwYXJ0eU93bmVyUHViS2V5CQAAAgAAAAECAAAAJUJ1cm4gaXMgYWxsb3dlZCBmb3IgUGFydHkgT3duZXIgb25seS4DCQEAAAACIT0AAAACCAUAAAADYnR4AAAAA2ZlZQUAAAAGTWluRkVFCQAAAgAAAAEJAAEsAAAAAgIAAAAxSW1wb3NzaWJsZSB0byBidXJuIHdpdGggZmVlIGxlc3Mgb3IgZ3JlYXRlciB0aGFuIAkAAaQAAAABBQAAAAZNaW5GRUUGB4oZdow=", "chainId": 84, "height": 824659, "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 3 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let WAVELET = ((100 * 1000) * 1000) | |
5 | + | ||
6 | + | let MRTEC = 100 | |
7 | + | ||
8 | + | let maxRounds = 100000000 | |
9 | + | ||
10 | + | let pmtStep = (10 * MRTEC) | |
11 | + | ||
12 | + | let partyOwnerPubKey = fromBase58String("EUmmzmJhsXbfk6mFvuWqPQ1S2mZzSUtvY1KExtu3K8R6") | |
13 | + | ||
14 | + | let partyOwnerAddress = addressFromPublicKey(partyOwnerPubKey) | |
15 | + | ||
16 | + | let withdrawPeriod = 10 | |
17 | + | ||
18 | + | let winAmt = (1 * WAVELET) | |
19 | + | ||
20 | + | let heightStep = 2 | |
21 | + | ||
22 | + | let blocksOnGameStart = 824658 | |
23 | + | ||
24 | + | let blocksPerRound = 12 | |
25 | + | ||
26 | + | let blocksPerCompetition = 8 | |
27 | + | ||
28 | + | let MRT = fromBase58String("qZcXsV8Qv1PfvZNowckmbg7ZfmJewDRiPfeBR5PKJjJ") | |
29 | + | ||
30 | + | let MinFEE = ((5 * WAVELET) / 1000) | |
31 | + | ||
32 | + | let IdxWinHeight = 0 | |
33 | + | ||
34 | + | let IdxWinAddress = 1 | |
35 | + | ||
36 | + | let IdxWinPubKey = 2 | |
37 | + | ||
38 | + | let IdxWithdrawId = 3 | |
39 | + | ||
40 | + | func getRoundDataKeyOrFail (round) = if ((0 > round)) | |
41 | + | then throw("Invalid round number") | |
42 | + | else ("round" + toString(round)) | |
43 | + | ||
44 | + | ||
45 | + | func readRoundDataListOrFail (round) = { | |
46 | + | let roundDataOpt = getString(this, getRoundDataKeyOrFail(round)) | |
47 | + | let roundDataStr = if (isDefined(roundDataOpt)) | |
48 | + | then extract(roundDataOpt) | |
49 | + | else "" | |
50 | + | if ((roundDataStr != "")) | |
51 | + | then split(roundDataStr, "_") | |
52 | + | else ["0", toString(pmtStep), "?", "?", "?", "0"] | |
53 | + | } | |
54 | + | ||
55 | + | ||
56 | + | func readSharedState () = { | |
57 | + | let sharedStateOpt = getString(this, "RoundsSharedState") | |
58 | + | let sharedStateStr = if (isDefined(sharedStateOpt)) | |
59 | + | then extract(sharedStateOpt) | |
60 | + | else "" | |
61 | + | if ((sharedStateStr != "")) | |
62 | + | then split(sharedStateStr, "_") | |
63 | + | else ["?", "0", "?"] | |
64 | + | } | |
65 | + | ||
66 | + | ||
67 | + | func writeSetOfRoundData (type,round,newWinHeight,newWinAddressStr,newWinPubKeyStr,withdrawId58) = { | |
68 | + | let newWinHeightStr = toString(newWinHeight) | |
69 | + | let roundData = DataEntry(getRoundDataKeyOrFail(round), ((((((newWinHeightStr + "_") + newWinAddressStr) + "_") + newWinPubKeyStr) + "_") + withdrawId58)) | |
70 | + | if ((type == "MOVE")) | |
71 | + | then { | |
72 | + | let addressLength = size(newWinAddressStr) | |
73 | + | let sharedState = readSharedState() | |
74 | + | let newTotalGamesCountStr = toString((parseIntValue(sharedState[1]) + 1)) | |
75 | + | let currLastPlayersAddr = if ((sharedState[2] == "?")) | |
76 | + | then "" | |
77 | + | else sharedState[2] | |
78 | + | let newLastPlayersAddr = if (if ((currLastPlayersAddr != "")) | |
79 | + | then (size(currLastPlayersAddr) > ((addressLength + 1) * 10)) | |
80 | + | else false) | |
81 | + | then (("-" + newWinAddressStr) + dropRight(currLastPlayersAddr, (addressLength + 1))) | |
82 | + | else (("-" + newWinAddressStr) + currLastPlayersAddr) | |
83 | + | WriteSet([roundData, DataEntry("RoundsSharedState", ((((newWinHeightStr + "_") + newTotalGamesCountStr) + "_") + newLastPlayersAddr))]) | |
84 | + | } | |
85 | + | else if ((type == "WITHDRAW")) | |
86 | + | then WriteSet([roundData]) | |
87 | + | else throw(("Unsupported type in writeSetOfRoundData method: " + type)) | |
88 | + | } | |
89 | + | ||
90 | + | ||
91 | + | let offset = (height - blocksOnGameStart) | |
92 | + | ||
93 | + | let currRoundNum = if ((offset >= 0)) | |
94 | + | then (offset / blocksPerRound) | |
95 | + | else throw(("Please do not hurry. MRT party will start on " + toString(blocksOnGameStart))) | |
96 | + | ||
97 | + | let currRoundHeight = (offset % blocksPerRound) | |
98 | + | ||
99 | + | let currRoundHeightStart = ((currRoundNum * blocksPerRound) + blocksOnGameStart) | |
100 | + | ||
101 | + | let currRoundCompetitionEnd = (currRoundHeightStart + blocksPerCompetition) | |
102 | + | ||
103 | + | let currRoundDataList = readRoundDataListOrFail(currRoundNum) | |
104 | + | ||
105 | + | let currWinHeight = parseIntValue(currRoundDataList[IdxWinHeight]) | |
106 | + | ||
107 | + | let currMinPmtAmt = pmtStep | |
108 | + | ||
109 | + | func isWinByHeight (h) = (height >= h) | |
110 | + | ||
111 | + | ||
112 | + | let atLeastOneMoveInRoundPresent = (currWinHeight > currRoundHeightStart) | |
113 | + | ||
114 | + | let firstCountdownFinished = if ((currWinHeight == 0)) | |
115 | + | then isWinByHeight((currRoundHeightStart + heightStep)) | |
116 | + | else false | |
117 | + | ||
118 | + | let isPauseByWin = if (isWinByHeight(currWinHeight)) | |
119 | + | then atLeastOneMoveInRoundPresent | |
120 | + | else false | |
121 | + | ||
122 | + | let isPauseByTime = if ((currRoundHeight > blocksPerCompetition)) | |
123 | + | then true | |
124 | + | else firstCountdownFinished | |
125 | + | ||
126 | + | let isPause = if (isPauseByWin) | |
127 | + | then true | |
128 | + | else isPauseByTime | |
129 | + | ||
130 | + | let isCompetition = !(isPause) | |
131 | + | ||
132 | + | @Callable(inv) | |
133 | + | func move () = { | |
134 | + | let overflowedNewWinHeight = (height + heightStep) | |
135 | + | let newWinHeight = if ((overflowedNewWinHeight >= currRoundCompetitionEnd)) | |
136 | + | then currRoundCompetitionEnd | |
137 | + | else overflowedNewWinHeight | |
138 | + | let payment = if (isDefined(inv.payment)) | |
139 | + | then extract(inv.payment) | |
140 | + | else throw("Please attach payment with MRT to participate in MRT party") | |
141 | + | if ((currRoundNum >= maxRounds)) | |
142 | + | then throw("MRT party is over") | |
143 | + | else if (isPause) | |
144 | + | then throw((("Sorry but round #" + toString(currRoundNum)) + " is finished.")) | |
145 | + | else if ((payment.assetId != MRT)) | |
146 | + | then throw("Please use MRT as a payment asset to participate in MRT party") | |
147 | + | else if ((currMinPmtAmt > payment.amount)) | |
148 | + | then throw(("Sorry my friend but your payment is too small. Current min payment is " + toString(currMinPmtAmt))) | |
149 | + | else writeSetOfRoundData("MOVE", currRoundNum, newWinHeight, toString(addressFromPublicKey(inv.callerPublicKey)), toBase58String(inv.callerPublicKey), "?") | |
150 | + | } | |
151 | + | ||
152 | + | ||
153 | + | ||
154 | + | @Callable(inv) | |
155 | + | func withdraw (round) = { | |
156 | + | let roundDataList = readRoundDataListOrFail(round) | |
157 | + | let winnerPubKey = fromBase58String(roundDataList[IdxWinPubKey]) | |
158 | + | let withdrawId58 = roundDataList[IdxWithdrawId] | |
159 | + | if ((round > currRoundNum)) | |
160 | + | then throw("Impossible to withdraw win amount for round in future") | |
161 | + | else if (if ((round == currRoundNum)) | |
162 | + | then isCompetition | |
163 | + | else false) | |
164 | + | then throw("Impossible to withdraw win amount - winner has not been determined yet") | |
165 | + | else if ((withdrawId58 != "?")) | |
166 | + | then throw((("Winner of round #" + toString(round)) + " has already taken the prize")) | |
167 | + | else { | |
168 | + | let withdrawPeriodEnded = (height > ((blocksOnGameStart + (maxRounds * blocksPerRound)) + withdrawPeriod)) | |
169 | + | let winAmtRecipient = if (withdrawPeriodEnded) | |
170 | + | then partyOwnerAddress | |
171 | + | else addressFromPublicKey(winnerPubKey) | |
172 | + | let roundWinHeight = parseIntValue(roundDataList[IdxWinHeight]) | |
173 | + | ScriptResult(writeSetOfRoundData("WITHDRAW", round, roundWinHeight, roundDataList[IdxWinAddress], roundDataList[IdxWinPubKey], toBase58String(inv.transactionId)), TransferSet([ScriptTransfer(winAmtRecipient, winAmt, unit)])) | |
174 | + | } | |
175 | + | } | |
176 | + | ||
177 | + | ||
178 | + | @Verifier(tx) | |
179 | + | func verify () = { | |
180 | + | let withdrawPeriodEnded = (height > ((blocksOnGameStart + (maxRounds * blocksPerRound)) + withdrawPeriod)) | |
181 | + | match tx { | |
182 | + | case ttx: TransferTransaction => | |
183 | + | if (!(withdrawPeriodEnded)) | |
184 | + | then throw("MRT party has not finished yet. Transfer is not allowed.") | |
185 | + | else if (!(sigVerify(ttx.bodyBytes, ttx.proofs[0], partyOwnerPubKey))) | |
186 | + | then throw("Transfer is allowed for Party Owner only.") | |
187 | + | else if ((ttx.fee != MinFEE)) | |
188 | + | then throw(("Impossible to transfer with fee less or greater than " + toString(MinFEE))) | |
189 | + | else true | |
190 | + | case btx: BurnTransaction => | |
191 | + | if (!(withdrawPeriodEnded)) | |
192 | + | then throw("MRT party has not finished yet. Burn is not allowed.") | |
193 | + | else if (!(sigVerify(btx.bodyBytes, btx.proofs[0], partyOwnerPubKey))) | |
194 | + | then throw("Burn is allowed for Party Owner only.") | |
195 | + | else if ((btx.fee != MinFEE)) | |
196 | + | then throw(("Impossible to burn with fee less or greater than " + toString(MinFEE))) | |
197 | + | else true | |
198 | + | case _ => | |
199 | + | false | |
200 | + | } | |
201 | + | } | |
202 | + |
github/deemru/w8io/169f3d6 28.78 ms ◑