tx · GpQJHPfxJeAn48zLv3UXjZYKrRWXaJn6rJ2jj3EJKKEw 3My9Kd9gApw3GCoz2KWSZPiTRNzDsNE2eeh: -0.01400000 Waves 2021.02.15 13:43 [1399171] smart account 3My9Kd9gApw3GCoz2KWSZPiTRNzDsNE2eeh > SELF 0.00000000 Waves
{ "type": 13, "id": "GpQJHPfxJeAn48zLv3UXjZYKrRWXaJn6rJ2jj3EJKKEw", "fee": 1400000, "feeAssetId": null, "timestamp": 1613385793605, "version": 2, "chainId": 84, "sender": "3My9Kd9gApw3GCoz2KWSZPiTRNzDsNE2eeh", "senderPublicKey": "BjjwtwUgZ4s8p9HJuFwyRMR3egd3zMAHGDV2HoZ1J7ho", "proofs": [ "426U3rAHjSq7QDpcWADZPSGnkMar4gQFMiz44xQk4h51JXqHjNhM9XiJg6J85BDVpdGK12KmosjNmWpH8xvVcYCG" ], "script": "base64:AAIDAAAAAAAAAAYIARIAEgAAAAAgAAAAAA1nYW1lUHVibGljS2V5CQACWQAAAAECAAAALEJqand0d1VnWjRzOHA5SEp1Rnd5Uk1SM2VnZDN6TUFIR0RWMkhvWjFKN2hvAAAAAA9zZXJ2ZXJQdWJsaWNLZXkJAAJZAAAAAQIAAAAsNTJEalROeG95ZXNBZExrS3A5VUo3ck4xWDJOUDVubk52a0h3S0wyOXdibloAAAAAFmRpdmlkZW5kUHJvZ3JhbUFkZHJlc3MJAQAAABRhZGRyZXNzRnJvbVB1YmxpY0tleQAAAAEFAAAAD3NlcnZlclB1YmxpY0tleQAAAAANcnNhUHVibGljS2V5MQkAAlsAAAABAgAAAIBNRnd3RFFZSktvWklodmNOQVFFQkJRQURTd0F3U0FKQkFPa2l1ei9CVjRFam94R2hUbU5DYnQyVGdrYlNQSC93NjliM0YxckttRDYxSmlQWHZ2RjhMMnBJOXhPWWNXNEZtb0VaVkhsUlF0QWxhSnlrbDMrcnNyRUNBd0VBQVE9PQAAAAANcnNhUHVibGljS2V5MgkAAlsAAAABAgAAAIBNRnd3RFFZSktvWklodmNOQVFFQkJRQURTd0F3U0FKQkFKblh6Yk0vVjJzRFYxVUxiUFNPbEhrbGRPVFdSckhpNWZ4SWtCbXVldnJDbE1QVkg3cnFjY3dpckROY01kSWR3WEhJOUFkaGo5Rldqd0dJd2ZVL0s2TUNBd0VBQVE9PQAAAAANcnNhUHVibGljS2V5MwkAAlsAAAABAgAAAIBNRnd3RFFZSktvWklodmNOQVFFQkJRQURTd0F3U0FKQkFPUkRldnkwcjRrekxxT3lTbG9CNjNIdXYyZTR6ZUhLSGpDc3k1dnRGS21XWmJYSmE4Z1pZdDQrRWtsRklvMUs5b3F1NUJBUFZmSjNGT3pzMlUxQStnMENBd0VBQVE9PQAAAAAFZHJ1bTEJAARMAAAAAgIAAAABMgkABEwAAAACAgAAAAExCQAETAAAAAICAAAAATMJAARMAAAAAgIAAAABNQkABEwAAAACAgAAAAE3CQAETAAAAAICAAAAATMJAARMAAAAAgIAAAABMwkABEwAAAACAgAAAAExCQAETAAAAAICAAAAATQJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAEzCQAETAAAAAICAAAAATUJAARMAAAAAgIAAAABMgkABEwAAAACAgAAAAE0CQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABNgkABEwAAAACAgAAAAE1CQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAE0BQAAAANuaWwAAAAABWRydW0yCQAETAAAAAICAAAAATQJAARMAAAAAgIAAAABMgkABEwAAAACAgAAAAEzCQAETAAAAAICAAAAATEJAARMAAAAAgIAAAABNgkABEwAAAACAgAAAAE0CQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAE0CQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAE2CQAETAAAAAICAAAAATMJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAEyCQAETAAAAAICAAAAATUJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAE1CQAETAAAAAICAAAAATMJAARMAAAAAgIAAAABNwUAAAADbmlsAAAAAAVkcnVtMwkABEwAAAACAgAAAAEzCQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABNwkABEwAAAACAgAAAAE0CQAETAAAAAICAAAAATEJAARMAAAAAgIAAAABNgkABEwAAAACAgAAAAE0CQAETAAAAAICAAAAATIJAARMAAAAAgIAAAABMwkABEwAAAACAgAAAAExCQAETAAAAAICAAAAATQJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAE1CQAETAAAAAICAAAAATUJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAEzCQAETAAAAAICAAAAATcJAARMAAAAAgIAAAABMQkABEwAAAACAgAAAAEyCQAETAAAAAICAAAAATYFAAAAA25pbAAAAAAIc3RhdGVBY2MCAAAACEFjY2VwdGVkAAAAAAhzdGF0ZVdpbgIAAAADV2luAAAAAAlzdGF0ZUxvc2UCAAAABExvc2UAAAAADHN0YXRlVGltZW91dAIAAAAMV2luQnlUaW1lb3V0AAAAAAd3YXZlc0lkBQAAAAR1bml0AAAAAAt3YXZlc01pbkFtdAAAAAAAATEtAAAAAAALd2F2ZXNNYXhBbXQJAABoAAAAAgUAAAALd2F2ZXNNaW5BbXQAAAAAAAAAAAoAAAAACmNvbW1pc3Npb24AAAAAAAAHoSAAAAAADWdhbWVUaW1lRnJhbWUAAAAAAAAAC0ABAAAAC3BtdEFtdENoZWNrAAAAAgAAAApwbXRBc3NldElkAAAACWJldEFtb3VudAMJAAAAAAAAAgUAAAAKcG10QXNzZXRJZAIAAAAFV0FWRVMDAwkAAGcAAAACBQAAAAliZXRBbW91bnQFAAAAC3dhdmVzTWluQW10CQAAZwAAAAIFAAAAC3dhdmVzTWF4QW10BQAAAAliZXRBbW91bnQHBgkAAAIAAAABAgAAABpCZXQgYW1vdW50IGlzIG5vdCBpbiByYW5nZQkAAAIAAAABAgAAAB1QYXltZW50IEFzc2V0IElEIGlzIG5vdCB2YWxpZAEAAAALZ2V0RGF0YUxpc3QAAAABAAAABmdhbWVJZAQAAAANZ2V0RGF0YVN0cmluZwkABB0AAAACBQAAAAR0aGlzCQABLAAAAAIFAAAABmdhbWVJZAIAAAAHX0dhbWVJZAQAAAABYQQAAAAHJG1hdGNoMAUAAAANZ2V0RGF0YVN0cmluZwMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAAGU3RyaW5nBAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhCQAAAgAAAAECAAAAFEdhbWVJZCB3YXMgbm90IGZvdW5kCQAEtQAAAAIFAAAAAWECAAAAAV8BAAAACHJzYVRvSW50AAAAAwAAAAZnYW1lSWQAAAAHcnNhU2lnbgAAAAxyc2FQdWJsaWNLZXkEAAAACHJzYUNoZWNrCQAB+AAAAAQFAAAABlNIQTI1NgkAAZsAAAABBQAAAAZnYW1lSWQFAAAAB3JzYVNpZ24FAAAADHJzYVB1YmxpY0tleQMFAAAACHJzYUNoZWNrCQAAagAAAAIJAASxAAAAAQkAAfcAAAABBQAAAAdyc2FTaWduAAAAAAAAAAATCQAAAgAAAAECAAAAFUludmFsaWQgUlNBIFNpZ25hdHVyZQEAAAAXaW5jcmVhc2VSZXNlcnZlZEJhbGFuY2UAAAACAAAABnBtdEFtdAAAAAlhc3NldElkNTgEAAAAFmN1cnJlbnRSZXNlcnZlZEJhbGFuY2UEAAAAFHZhbHVlUmVzZXJ2ZWRCYWxhbmNlCQAEGgAAAAIFAAAABHRoaXMCAAAADldBVkVTX1Jlc2VydmVkBAAAAAckbWF0Y2gwBQAAABR2YWx1ZVJlc2VydmVkQmFsYW5jZQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAABAAAABJuZXdSZXNlcnZlZEJhbGFuY2UJAABkAAAAAgUAAAAWY3VycmVudFJlc2VydmVkQmFsYW5jZQkAAGgAAAACBQAAAAZwbXRBbXQAAAAAAAAAAQQDCQAAZwAAAAIJAAPrAAAAAgUAAAAEdGhpcwUAAAAJYXNzZXRJZDU4BQAAABJuZXdSZXNlcnZlZEJhbGFuY2UFAAAAEm5ld1Jlc2VydmVkQmFsYW5jZQkAAAIAAAABAgAAADVCZXQgd2FzIHJlamVjdGVkLiBJbnN1ZmZpY2llbnQgZnVuZHMgb24gZ2FtZSBhY2NvdW50LgEAAAAXZGVjcmVhc2VSZXNlcnZlZEJhbGFuY2UAAAACAAAABmJldEFtdAAAAAdhc3NldElkBAAAABR2YWx1ZVJlc2VydmVkQmFsYW5jZQkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIFAAAAB2Fzc2V0SWQCAAAACV9SZXNlcnZlZAQAAAAWZXh0cmFjdFJlc2VydmVkQmFsYW5jZQQAAAAHJG1hdGNoMAUAAAAUdmFsdWVSZXNlcnZlZEJhbGFuY2UDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAABYQUAAAAHJG1hdGNoMAUAAAABYQAAAAAAAAAAAAQAAAAXZGVjcmVhc2VSZXNlcnZlZEJhbGFuY2UJAABlAAAAAgUAAAAWZXh0cmFjdFJlc2VydmVkQmFsYW5jZQkAAGgAAAACBQAAAAZiZXRBbXQAAAAAAAAAAQQDCQAAZwAAAAIFAAAAF2RlY3JlYXNlUmVzZXJ2ZWRCYWxhbmNlAAAAAAAAAAAABQAAABdkZWNyZWFzZVJlc2VydmVkQmFsYW5jZQkAAAIAAAABAgAAAChSZXNlcnZlZCBiYWxhbmNlIGNvdWxkbid0IGJlIGxlc3MgdGhhbiAwAQAAAA9kcnVtSW50VG9TdHJpbmcAAAABAAAAB2RydW1JbnQDCQAAZgAAAAIAAAAAAAAAAAoFAAAAB2RydW1JbnQJAAEsAAAAAgIAAAABMAkAAaQAAAABBQAAAAdkcnVtSW50CQABpAAAAAEFAAAAB2RydW1JbnQBAAAAEGRlZmluZU11bHRpcGxpZXIAAAACAAAAC3RocmVlSW5BUm93AAAACXR3b0luQVJvdwMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzc3NwAAAAAAAAAKKAMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzY2NgAAAAAAAAAFFAMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzU1NQAAAAAAAAABwgMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzQ0NAAAAAAAAAAAyAMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzMzMwAAAAAAAAAAlgMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzIyMgAAAAAAAAAAbgMJAAAAAAAAAgUAAAALdGhyZWVJbkFSb3cCAAAAAzExMQAAAAAAAAAAMgMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAI3NwAAAAAAAAABDgMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAI2NgAAAAAAAAAAggMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAI1NQAAAAAAAAAALQMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAI0NAAAAAAAAAAAHgMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAIzMwAAAAAAAAAAFAMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAIyMgAAAAAAAAAAEQMJAAAAAAAAAgUAAAAJdHdvSW5BUm93AgAAAAIxMQAAAAAAAAAADQAAAAAAAAAAAAEAAAARYXNzZXROYW1lVG9CYXNlNTgAAAABAAAACWFzc2V0TmFtZQMJAAAAAAAAAgUAAAAJYXNzZXROYW1lAgAAAAVXQVZFUwUAAAAHd2F2ZXNJZAkAAAIAAAABAgAAABdBc3NldCBuYW1lIGlzIGluY29ycmVjdAEAAAARYXNzZXRCYXNlNThUb05hbWUAAAABAAAAB2Fzc2V0SWQDCQEAAAABIQAAAAEJAQAAAAlpc0RlZmluZWQAAAABBQAAAAdhc3NldElkAgAAAAVXQVZFUwkAAAIAAAABAgAAABRBc3NldElkIGlzIGluY29ycmVjdAEAAAAUc2V0TmV3R2FtZXNQbGF5ZWROdW0AAAABAAAAB2FkZHJlc3MEAAAAE3ZhbHVlR2FtZXNQbGF5ZWROdW0JAAQaAAAAAgUAAAAEdGhpcwkAASwAAAACBQAAAAdhZGRyZXNzAgAAAAxfR2FtZXNQbGF5ZWQEAAAAFWN1cnJlbnRHYW1lc1BsYXllZE51bQQAAAAHJG1hdGNoMAUAAAATdmFsdWVHYW1lc1BsYXllZE51bQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAACQAAZAAAAAIFAAAAFWN1cnJlbnRHYW1lc1BsYXllZE51bQAAAAAAAAAAAQEAAAAPY2hlY2tQZXJtaXNzaW9uAAAAAQAAAA9jYWxsZXJQdWJsaWNLZXkJAQAAAAIhPQAAAAIFAAAAD2NhbGxlclB1YmxpY0tleQUAAAAPc2VydmVyUHVibGljS2V5AQAAABBnZXRDdXJyZW50SW5jb21lAAAAAQAAAAlhc3NldE5hbWUEAAAAA3ZhbAkABBoAAAACBQAAAAR0aGlzCQABLAAAAAIFAAAACWFzc2V0TmFtZQIAAAAHX0luY29tZQQAAAAHJG1hdGNoMAUAAAADdmFsAwkAAAEAAAACBQAAAAckbWF0Y2gwAgAAAANJbnQEAAAAAWEFAAAAByRtYXRjaDAFAAAAAWEAAAAAAAAAAAABAAAAFGNhbGxlcklzRGVwb3NpdE93bmVyAAAAAgAAAAlhc3NldE5hbWUAAAAPY2FsbGVyUHVibGljS2V5BAAAAAxkZXBvc2l0T3duZXIJAAQdAAAAAgUAAAAWZGl2aWRlbmRQcm9ncmFtQWRkcmVzcwkAASwAAAACBQAAAAlhc3NldE5hbWUCAAAADV9EZXBvc2l0T3duZXIDCQAAAAAAAAIFAAAAD2NhbGxlclB1YmxpY0tleQUAAAAMZGVwb3NpdE93bmVyBQAAAA9jYWxsZXJQdWJsaWNLZXkJAAACAAAAAQIAAAApT25seSBkZXBvc2l0IG93bmVyIGNhbiB3aXRoZHJhd2FsIGRlcG9zaXQBAAAADmdldERlcG9zaXREYXRhAAAAAgAAAAlhc3NldE5hbWUAAAAJa2V5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", "height": 1399171, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 3mG3VAiCy8G4PSDEeY9BENCMwDs4an2cMfP1QdA59f5R Next: B35FRY9KNJiD7xt2zYtkNkpoZJ4SNs3Run4Tkq15R2dW Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let gamePublicKey = fromBase58String("BjjwtwUgZ4s8p9HJuFwyRMR3egd3zMAHGDV2HoZ1J7ho") | |
5 | 5 | ||
6 | - | let dividendProgramAddress = addressFromPublicKey(fromBase58String("85WRynF4cwHurmJhYS4baWuSCu1D2Msv8i37g8s8DPFN")) | |
6 | + | let serverPublicKey = fromBase58String("52DjTNxoyesAdLkKp9UJ7rN1X2NP5nnNvkHwKL29wbnZ") | |
7 | + | ||
8 | + | let dividendProgramAddress = addressFromPublicKey(serverPublicKey) | |
7 | 9 | ||
8 | 10 | let rsaPublicKey1 = fromBase64String("MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOkiuz/BV4EjoxGhTmNCbt2TgkbSPH/w69b3F1rKmD61JiPXvvF8L2pI9xOYcW4FmoEZVHlRQtAlaJykl3+rsrECAwEAAQ==") | |
9 | 11 | ||
27 | 29 | ||
28 | 30 | let wavesId = unit | |
29 | 31 | ||
30 | - | let wavesMinAmt = | |
32 | + | let wavesMinAmt = 20000000 | |
31 | 33 | ||
32 | 34 | let wavesMaxAmt = (wavesMinAmt * 10) | |
33 | 35 | ||
64 | 66 | } | |
65 | 67 | ||
66 | 68 | ||
67 | - | func increaseReservedBalance (pmtAmt, | |
69 | + | func increaseReservedBalance (pmtAmt,assetId58) = { | |
68 | 70 | let currentReservedBalance = { | |
69 | - | let valueReservedBalance = getInteger(this, | |
71 | + | let valueReservedBalance = getInteger(this, "WAVES_Reserved") | |
70 | 72 | match valueReservedBalance { | |
71 | 73 | case a: Int => | |
72 | 74 | a | |
154 | 156 | } | |
155 | 157 | ||
156 | 158 | ||
159 | + | func checkPermission (callerPublicKey) = (callerPublicKey != serverPublicKey) | |
160 | + | ||
161 | + | ||
157 | 162 | func getCurrentIncome (assetName) = { | |
158 | 163 | let val = getInteger(this, (assetName + "_Income")) | |
159 | 164 | match val { | |
186 | 191 | ||
187 | 192 | ||
188 | 193 | @Callable(i) | |
194 | + | func initGame () = if (checkPermission(i.callerPublicKey)) | |
195 | + | then throw("initGame_FORBBIDEN") | |
196 | + | else match getInteger(this, "X_GAMESCOUNTER") { | |
197 | + | case GAMESCOUNTER: Int => | |
198 | + | throw("INIT_ALREADY_DONE") | |
199 | + | case _ => | |
200 | + | WriteSet([DataEntry("X_GAMESCOUNTER", 1), DataEntry("WAVES_Reserved", wavesMinAmt)]) | |
201 | + | } | |
202 | + | ||
203 | + | ||
204 | + | ||
205 | + | @Callable(i) | |
189 | 206 | func makeBet () = { | |
190 | 207 | let pmt = extract(i.payment) | |
191 | 208 | let betAmount = (pmt.amount - commission) | |
192 | 209 | let assetId = pmt.assetId | |
193 | 210 | let gameId = toBase58String(i.transactionId) | |
194 | 211 | let playerAddress = extract(i.caller) | |
195 | - | let pmtAssetName = assetBase58ToName(assetId) | |
196 | - | let setReservedBalance = increaseReservedBalance(betAmount, pmtAssetName, pmt.assetId) | |
197 | - | let pmtAmtCorrect = pmtAmtCheck(pmtAssetName, betAmount) | |
212 | + | let setReservedBalance = increaseReservedBalance(betAmount, pmt.assetId) | |
213 | + | let pmtAmtCorrect = pmtAmtCheck("WAVES", betAmount) | |
198 | 214 | if (pmtAmtCorrect) | |
199 | 215 | then { | |
200 | - | let dataString = | |
201 | - | WriteSet([DataEntry((gameId + "_GameId"), dataString), DataEntry( | |
216 | + | let dataString = ((((((stateAcc + "_") + toString(playerAddress)) + "_") + toString(betAmount)) + "_WAVES_") + toString(height)) | |
217 | + | WriteSet([DataEntry((gameId + "_GameId"), dataString), DataEntry("WAVES_Reserved", setReservedBalance)]) | |
202 | 218 | } | |
203 | 219 | else throw("AssetId is incorrect") | |
204 | - | } | |
205 | - | ||
206 | - | ||
207 | - | ||
208 | - | @Callable(i) | |
209 | - | func playGame (gameId,rsaSign1,rsaSign2,rsaSign3) = { | |
210 | - | let dataList = getDataList(gameId) | |
211 | - | let gameState = dataList[0] | |
212 | - | let playerAddress = dataList[1] | |
213 | - | let betAmt = parseIntValue(dataList[2]) | |
214 | - | let assetName = dataList[3] | |
215 | - | let gameStart = parseIntValue(dataList[4]) | |
216 | - | let assetId58 = assetNameToBase58(assetName) | |
217 | - | let setReservedBalance = decreaseReservedBalance(betAmt, assetName) | |
218 | - | let drum1Int = rsaToInt(gameId, rsaSign1, rsaPublicKey1) | |
219 | - | let drum2Int = rsaToInt(gameId, rsaSign2, rsaPublicKey2) | |
220 | - | let drum3Int = rsaToInt(gameId, rsaSign3, rsaPublicKey3) | |
221 | - | let twoInARow = (drum1[drum1Int] + drum2[drum2Int]) | |
222 | - | let threeInARow = (twoInARow + drum3[drum3Int]) | |
223 | - | let droppedElementsString = ((drumIntToString(drum1Int) + drumIntToString(drum2Int)) + drumIntToString(drum3Int)) | |
224 | - | let winAmt = ((betAmt * defineMultiplier(threeInARow, twoInARow)) / 10) | |
225 | - | if ((gameState == stateAcc)) | |
226 | - | then if ((gameTimeFrame > (height - gameStart))) | |
227 | - | then if ((winAmt == 0)) | |
228 | - | then { | |
229 | - | let availableDividends = { | |
230 | - | let dividends = (getCurrentIncome(assetName) + betAmt) | |
231 | - | if ((dividends > 0)) | |
232 | - | then dividends | |
233 | - | else 0 | |
234 | - | } | |
235 | - | let income = { | |
236 | - | let dividends = (getCurrentIncome(assetName) + betAmt) | |
237 | - | if ((dividends > 0)) | |
238 | - | then 0 | |
239 | - | else dividends | |
240 | - | } | |
241 | - | ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateLose + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString(winAmt)) + "_") + threeInARow) + "_") + droppedElementsString)), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), income)]), TransferSet([ScriptTransfer(dividendProgramAddress, availableDividends, assetId58)])) | |
242 | - | } | |
243 | - | else ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateWin + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString(winAmt)) + "_") + threeInARow) + "_") + droppedElementsString)), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), (getCurrentIncome(assetName) - winAmt))]), TransferSet([ScriptTransfer(addressFromStringValue(playerAddress), winAmt, assetId58)])) | |
244 | - | else ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateTimeout + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString((betAmt * 2))) + "_") + "000") + "_") + "000000")), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), (getCurrentIncome(assetName) - (betAmt * 2)))]), TransferSet([ScriptTransfer(addressFromStringValue(playerAddress), (betAmt * 2), assetId58)])) | |
245 | - | else throw("Game state is incorrect") | |
246 | - | } | |
247 | - | ||
248 | - | ||
249 | - | ||
250 | - | @Callable(i) | |
251 | - | func withdrawDeposit (assetName) = { | |
252 | - | let assetId58 = assetNameToBase58(assetName) | |
253 | - | let callerPub = callerIsDepositOwner(assetName, toBase58String(i.callerPublicKey)) | |
254 | - | let dividendStartHeight = getDepositData(assetName, "_DepositStartBlock") | |
255 | - | let depositDuration = getDepositData(assetName, "_DepositDurationBlock") | |
256 | - | let depositAmount = getDepositData(assetName, "_DepositAmount") | |
257 | - | if (((height - dividendStartHeight) >= depositDuration)) | |
258 | - | then ScriptResult(WriteSet([DataEntry((assetName + "_DepositWithdrawTransactionId"), i.transactionId)]), TransferSet([ScriptTransfer(addressFromPublicKey(fromBase58String(callerPub)), depositAmount, assetId58)])) | |
259 | - | else throw((("Deposit time is not over. " + toString((height - (dividendStartHeight + depositDuration)))) + " blocks left.")) | |
260 | 220 | } | |
261 | 221 | ||
262 | 222 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let gamePublicKey = fromBase58String("BjjwtwUgZ4s8p9HJuFwyRMR3egd3zMAHGDV2HoZ1J7ho") | |
5 | 5 | ||
6 | - | let dividendProgramAddress = addressFromPublicKey(fromBase58String("85WRynF4cwHurmJhYS4baWuSCu1D2Msv8i37g8s8DPFN")) | |
6 | + | let serverPublicKey = fromBase58String("52DjTNxoyesAdLkKp9UJ7rN1X2NP5nnNvkHwKL29wbnZ") | |
7 | + | ||
8 | + | let dividendProgramAddress = addressFromPublicKey(serverPublicKey) | |
7 | 9 | ||
8 | 10 | let rsaPublicKey1 = fromBase64String("MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOkiuz/BV4EjoxGhTmNCbt2TgkbSPH/w69b3F1rKmD61JiPXvvF8L2pI9xOYcW4FmoEZVHlRQtAlaJykl3+rsrECAwEAAQ==") | |
9 | 11 | ||
10 | 12 | let rsaPublicKey2 = fromBase64String("MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAJnXzbM/V2sDV1ULbPSOlHkldOTWRrHi5fxIkBmuevrClMPVH7rqccwirDNcMdIdwXHI9Adhj9FWjwGIwfU/K6MCAwEAAQ==") | |
11 | 13 | ||
12 | 14 | let rsaPublicKey3 = fromBase64String("MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAORDevy0r4kzLqOySloB63Huv2e4zeHKHjCsy5vtFKmWZbXJa8gZYt4+EklFIo1K9oqu5BAPVfJ3FOzs2U1A+g0CAwEAAQ==") | |
13 | 15 | ||
14 | 16 | let drum1 = ["2", "1", "3", "5", "7", "3", "3", "1", "4", "1", "3", "5", "2", "4", "2", "6", "5", "2", "1", "4"] | |
15 | 17 | ||
16 | 18 | let drum2 = ["4", "2", "3", "1", "6", "4", "2", "1", "4", "2", "1", "6", "3", "1", "2", "5", "1", "5", "3", "7"] | |
17 | 19 | ||
18 | 20 | let drum3 = ["3", "2", "7", "4", "1", "6", "4", "2", "3", "1", "4", "1", "5", "5", "1", "3", "7", "1", "2", "6"] | |
19 | 21 | ||
20 | 22 | let stateAcc = "Accepted" | |
21 | 23 | ||
22 | 24 | let stateWin = "Win" | |
23 | 25 | ||
24 | 26 | let stateLose = "Lose" | |
25 | 27 | ||
26 | 28 | let stateTimeout = "WinByTimeout" | |
27 | 29 | ||
28 | 30 | let wavesId = unit | |
29 | 31 | ||
30 | - | let wavesMinAmt = | |
32 | + | let wavesMinAmt = 20000000 | |
31 | 33 | ||
32 | 34 | let wavesMaxAmt = (wavesMinAmt * 10) | |
33 | 35 | ||
34 | 36 | let commission = 500000 | |
35 | 37 | ||
36 | 38 | let gameTimeFrame = 2880 | |
37 | 39 | ||
38 | 40 | func pmtAmtCheck (pmtAssetId,betAmount) = if ((pmtAssetId == "WAVES")) | |
39 | 41 | then if (if ((betAmount >= wavesMinAmt)) | |
40 | 42 | then (wavesMaxAmt >= betAmount) | |
41 | 43 | else false) | |
42 | 44 | then true | |
43 | 45 | else throw("Bet amount is not in range") | |
44 | 46 | else throw("Payment Asset ID is not valid") | |
45 | 47 | ||
46 | 48 | ||
47 | 49 | func getDataList (gameId) = { | |
48 | 50 | let getDataString = getString(this, (gameId + "_GameId")) | |
49 | 51 | let a = match getDataString { | |
50 | 52 | case a: String => | |
51 | 53 | a | |
52 | 54 | case _ => | |
53 | 55 | throw("GameId was not found") | |
54 | 56 | } | |
55 | 57 | split(a, "_") | |
56 | 58 | } | |
57 | 59 | ||
58 | 60 | ||
59 | 61 | func rsaToInt (gameId,rsaSign,rsaPublicKey) = { | |
60 | 62 | let rsaCheck = rsaVerify(SHA256, toBytes(gameId), rsaSign, rsaPublicKey) | |
61 | 63 | if (rsaCheck) | |
62 | 64 | then (toInt(sha256(rsaSign)) % 19) | |
63 | 65 | else throw("Invalid RSA Signature") | |
64 | 66 | } | |
65 | 67 | ||
66 | 68 | ||
67 | - | func increaseReservedBalance (pmtAmt, | |
69 | + | func increaseReservedBalance (pmtAmt,assetId58) = { | |
68 | 70 | let currentReservedBalance = { | |
69 | - | let valueReservedBalance = getInteger(this, | |
71 | + | let valueReservedBalance = getInteger(this, "WAVES_Reserved") | |
70 | 72 | match valueReservedBalance { | |
71 | 73 | case a: Int => | |
72 | 74 | a | |
73 | 75 | case _ => | |
74 | 76 | 0 | |
75 | 77 | } | |
76 | 78 | } | |
77 | 79 | let newReservedBalance = (currentReservedBalance + (pmtAmt * 260)) | |
78 | 80 | if ((assetBalance(this, assetId58) >= newReservedBalance)) | |
79 | 81 | then newReservedBalance | |
80 | 82 | else throw("Bet was rejected. Insufficient funds on game account.") | |
81 | 83 | } | |
82 | 84 | ||
83 | 85 | ||
84 | 86 | func decreaseReservedBalance (betAmt,assetId) = { | |
85 | 87 | let valueReservedBalance = getInteger(this, (assetId + "_Reserved")) | |
86 | 88 | let extractReservedBalance = match valueReservedBalance { | |
87 | 89 | case a: Int => | |
88 | 90 | a | |
89 | 91 | case _ => | |
90 | 92 | 0 | |
91 | 93 | } | |
92 | 94 | let decreaseReservedBalance = (extractReservedBalance - (betAmt * 260)) | |
93 | 95 | if ((decreaseReservedBalance >= 0)) | |
94 | 96 | then decreaseReservedBalance | |
95 | 97 | else throw("Reserved balance couldn't be less than 0") | |
96 | 98 | } | |
97 | 99 | ||
98 | 100 | ||
99 | 101 | func drumIntToString (drumInt) = if ((10 > drumInt)) | |
100 | 102 | then ("0" + toString(drumInt)) | |
101 | 103 | else toString(drumInt) | |
102 | 104 | ||
103 | 105 | ||
104 | 106 | func defineMultiplier (threeInARow,twoInARow) = if ((threeInARow == "777")) | |
105 | 107 | then 2600 | |
106 | 108 | else if ((threeInARow == "666")) | |
107 | 109 | then 1300 | |
108 | 110 | else if ((threeInARow == "555")) | |
109 | 111 | then 450 | |
110 | 112 | else if ((threeInARow == "444")) | |
111 | 113 | then 200 | |
112 | 114 | else if ((threeInARow == "333")) | |
113 | 115 | then 150 | |
114 | 116 | else if ((threeInARow == "222")) | |
115 | 117 | then 110 | |
116 | 118 | else if ((threeInARow == "111")) | |
117 | 119 | then 50 | |
118 | 120 | else if ((twoInARow == "77")) | |
119 | 121 | then 270 | |
120 | 122 | else if ((twoInARow == "66")) | |
121 | 123 | then 130 | |
122 | 124 | else if ((twoInARow == "55")) | |
123 | 125 | then 45 | |
124 | 126 | else if ((twoInARow == "44")) | |
125 | 127 | then 30 | |
126 | 128 | else if ((twoInARow == "33")) | |
127 | 129 | then 20 | |
128 | 130 | else if ((twoInARow == "22")) | |
129 | 131 | then 17 | |
130 | 132 | else if ((twoInARow == "11")) | |
131 | 133 | then 13 | |
132 | 134 | else 0 | |
133 | 135 | ||
134 | 136 | ||
135 | 137 | func assetNameToBase58 (assetName) = if ((assetName == "WAVES")) | |
136 | 138 | then wavesId | |
137 | 139 | else throw("Asset name is incorrect") | |
138 | 140 | ||
139 | 141 | ||
140 | 142 | func assetBase58ToName (assetId) = if (!(isDefined(assetId))) | |
141 | 143 | then "WAVES" | |
142 | 144 | else throw("AssetId is incorrect") | |
143 | 145 | ||
144 | 146 | ||
145 | 147 | func setNewGamesPlayedNum (address) = { | |
146 | 148 | let valueGamesPlayedNum = getInteger(this, (address + "_GamesPlayed")) | |
147 | 149 | let currentGamesPlayedNum = match valueGamesPlayedNum { | |
148 | 150 | case a: Int => | |
149 | 151 | a | |
150 | 152 | case _ => | |
151 | 153 | 0 | |
152 | 154 | } | |
153 | 155 | (currentGamesPlayedNum + 1) | |
154 | 156 | } | |
155 | 157 | ||
156 | 158 | ||
159 | + | func checkPermission (callerPublicKey) = (callerPublicKey != serverPublicKey) | |
160 | + | ||
161 | + | ||
157 | 162 | func getCurrentIncome (assetName) = { | |
158 | 163 | let val = getInteger(this, (assetName + "_Income")) | |
159 | 164 | match val { | |
160 | 165 | case a: Int => | |
161 | 166 | a | |
162 | 167 | case _ => | |
163 | 168 | 0 | |
164 | 169 | } | |
165 | 170 | } | |
166 | 171 | ||
167 | 172 | ||
168 | 173 | func callerIsDepositOwner (assetName,callerPublicKey) = { | |
169 | 174 | let depositOwner = getString(dividendProgramAddress, (assetName + "_DepositOwner")) | |
170 | 175 | if ((callerPublicKey == depositOwner)) | |
171 | 176 | then callerPublicKey | |
172 | 177 | else throw("Only deposit owner can withdrawal deposit") | |
173 | 178 | } | |
174 | 179 | ||
175 | 180 | ||
176 | 181 | func getDepositData (assetName,keySuffix) = { | |
177 | 182 | let key = (assetName + keySuffix) | |
178 | 183 | let val = getInteger(dividendProgramAddress, key) | |
179 | 184 | match val { | |
180 | 185 | case a: Int => | |
181 | 186 | a | |
182 | 187 | case _ => | |
183 | 188 | throw("Couldn't find dividend program start height") | |
184 | 189 | } | |
185 | 190 | } | |
186 | 191 | ||
187 | 192 | ||
188 | 193 | @Callable(i) | |
194 | + | func initGame () = if (checkPermission(i.callerPublicKey)) | |
195 | + | then throw("initGame_FORBBIDEN") | |
196 | + | else match getInteger(this, "X_GAMESCOUNTER") { | |
197 | + | case GAMESCOUNTER: Int => | |
198 | + | throw("INIT_ALREADY_DONE") | |
199 | + | case _ => | |
200 | + | WriteSet([DataEntry("X_GAMESCOUNTER", 1), DataEntry("WAVES_Reserved", wavesMinAmt)]) | |
201 | + | } | |
202 | + | ||
203 | + | ||
204 | + | ||
205 | + | @Callable(i) | |
189 | 206 | func makeBet () = { | |
190 | 207 | let pmt = extract(i.payment) | |
191 | 208 | let betAmount = (pmt.amount - commission) | |
192 | 209 | let assetId = pmt.assetId | |
193 | 210 | let gameId = toBase58String(i.transactionId) | |
194 | 211 | let playerAddress = extract(i.caller) | |
195 | - | let pmtAssetName = assetBase58ToName(assetId) | |
196 | - | let setReservedBalance = increaseReservedBalance(betAmount, pmtAssetName, pmt.assetId) | |
197 | - | let pmtAmtCorrect = pmtAmtCheck(pmtAssetName, betAmount) | |
212 | + | let setReservedBalance = increaseReservedBalance(betAmount, pmt.assetId) | |
213 | + | let pmtAmtCorrect = pmtAmtCheck("WAVES", betAmount) | |
198 | 214 | if (pmtAmtCorrect) | |
199 | 215 | then { | |
200 | - | let dataString = | |
201 | - | WriteSet([DataEntry((gameId + "_GameId"), dataString), DataEntry( | |
216 | + | let dataString = ((((((stateAcc + "_") + toString(playerAddress)) + "_") + toString(betAmount)) + "_WAVES_") + toString(height)) | |
217 | + | WriteSet([DataEntry((gameId + "_GameId"), dataString), DataEntry("WAVES_Reserved", setReservedBalance)]) | |
202 | 218 | } | |
203 | 219 | else throw("AssetId is incorrect") | |
204 | - | } | |
205 | - | ||
206 | - | ||
207 | - | ||
208 | - | @Callable(i) | |
209 | - | func playGame (gameId,rsaSign1,rsaSign2,rsaSign3) = { | |
210 | - | let dataList = getDataList(gameId) | |
211 | - | let gameState = dataList[0] | |
212 | - | let playerAddress = dataList[1] | |
213 | - | let betAmt = parseIntValue(dataList[2]) | |
214 | - | let assetName = dataList[3] | |
215 | - | let gameStart = parseIntValue(dataList[4]) | |
216 | - | let assetId58 = assetNameToBase58(assetName) | |
217 | - | let setReservedBalance = decreaseReservedBalance(betAmt, assetName) | |
218 | - | let drum1Int = rsaToInt(gameId, rsaSign1, rsaPublicKey1) | |
219 | - | let drum2Int = rsaToInt(gameId, rsaSign2, rsaPublicKey2) | |
220 | - | let drum3Int = rsaToInt(gameId, rsaSign3, rsaPublicKey3) | |
221 | - | let twoInARow = (drum1[drum1Int] + drum2[drum2Int]) | |
222 | - | let threeInARow = (twoInARow + drum3[drum3Int]) | |
223 | - | let droppedElementsString = ((drumIntToString(drum1Int) + drumIntToString(drum2Int)) + drumIntToString(drum3Int)) | |
224 | - | let winAmt = ((betAmt * defineMultiplier(threeInARow, twoInARow)) / 10) | |
225 | - | if ((gameState == stateAcc)) | |
226 | - | then if ((gameTimeFrame > (height - gameStart))) | |
227 | - | then if ((winAmt == 0)) | |
228 | - | then { | |
229 | - | let availableDividends = { | |
230 | - | let dividends = (getCurrentIncome(assetName) + betAmt) | |
231 | - | if ((dividends > 0)) | |
232 | - | then dividends | |
233 | - | else 0 | |
234 | - | } | |
235 | - | let income = { | |
236 | - | let dividends = (getCurrentIncome(assetName) + betAmt) | |
237 | - | if ((dividends > 0)) | |
238 | - | then 0 | |
239 | - | else dividends | |
240 | - | } | |
241 | - | ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateLose + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString(winAmt)) + "_") + threeInARow) + "_") + droppedElementsString)), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), income)]), TransferSet([ScriptTransfer(dividendProgramAddress, availableDividends, assetId58)])) | |
242 | - | } | |
243 | - | else ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateWin + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString(winAmt)) + "_") + threeInARow) + "_") + droppedElementsString)), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), (getCurrentIncome(assetName) - winAmt))]), TransferSet([ScriptTransfer(addressFromStringValue(playerAddress), winAmt, assetId58)])) | |
244 | - | else ScriptResult(WriteSet([DataEntry((gameId + "_GameId"), ((((((((((((((stateTimeout + "_") + dataList[1]) + "_") + dataList[2]) + "_") + dataList[3]) + "_") + toString(height)) + "_") + toString((betAmt * 2))) + "_") + "000") + "_") + "000000")), DataEntry((assetName + "_Reserved"), setReservedBalance), DataEntry((assetName + "_Income"), (getCurrentIncome(assetName) - (betAmt * 2)))]), TransferSet([ScriptTransfer(addressFromStringValue(playerAddress), (betAmt * 2), assetId58)])) | |
245 | - | else throw("Game state is incorrect") | |
246 | - | } | |
247 | - | ||
248 | - | ||
249 | - | ||
250 | - | @Callable(i) | |
251 | - | func withdrawDeposit (assetName) = { | |
252 | - | let assetId58 = assetNameToBase58(assetName) | |
253 | - | let callerPub = callerIsDepositOwner(assetName, toBase58String(i.callerPublicKey)) | |
254 | - | let dividendStartHeight = getDepositData(assetName, "_DepositStartBlock") | |
255 | - | let depositDuration = getDepositData(assetName, "_DepositDurationBlock") | |
256 | - | let depositAmount = getDepositData(assetName, "_DepositAmount") | |
257 | - | if (((height - dividendStartHeight) >= depositDuration)) | |
258 | - | then ScriptResult(WriteSet([DataEntry((assetName + "_DepositWithdrawTransactionId"), i.transactionId)]), TransferSet([ScriptTransfer(addressFromPublicKey(fromBase58String(callerPub)), depositAmount, assetId58)])) | |
259 | - | else throw((("Deposit time is not over. " + toString((height - (dividendStartHeight + depositDuration)))) + " blocks left.")) | |
260 | 220 | } | |
261 | 221 | ||
262 | 222 | ||
263 | 223 | @Verifier(tx) | |
264 | 224 | func verify () = if (sigVerify(tx.bodyBytes, tx.proofs[0], gamePublicKey)) | |
265 | 225 | then match tx { | |
266 | 226 | case tx: SetScriptTransaction => | |
267 | 227 | true | |
268 | 228 | case _ => | |
269 | 229 | false | |
270 | 230 | } | |
271 | 231 | else false | |
272 | 232 |
github/deemru/w8io/169f3d6 34.97 ms ◑![]()