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:
OldNewDifferences
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