tx · yxSkDPE9JhZyg7FCQTYJzAZEb5ebKhFFoU6V3zQGzjr 3N2tusqAtDctK8iSTXS6F9rimmftmSuwLUX: -0.05000000 Waves 2019.10.29 15:58 [741465] smart account 3N2tusqAtDctK8iSTXS6F9rimmftmSuwLUX > SELF 0.00000000 Waves
{ "type": 13, "id": "yxSkDPE9JhZyg7FCQTYJzAZEb5ebKhFFoU6V3zQGzjr", "fee": 5000000, "feeAssetId": null, "timestamp": 1572353867429, "version": 1, "sender": "3N2tusqAtDctK8iSTXS6F9rimmftmSuwLUX", "senderPublicKey": "ACfUG5PwG2GssMuyEwVEhkYAbbbP1geSHR8XoNxLyu6V", "proofs": [ "3HonpoBdoz8ocRUnHLHuCtLPpR6KybtSyh9PaNdWnLxqZGMqAdEhfPzjjfe7Vr2iXBNZvSosRkgnp4Tn7pY3nou5" ], "script": "base64:AAIDAAAAAAAAABIIARIDCgEIEgQKAggCEgMKAQgAAAAiAAAAAAlSU0FQVUJMSUMJAAJbAAAAAQIAAAGPYmFzZTY0Ok1JSUJJakFOQmdrcWhraUc5dzBCQVFFRkFBT0NBUThBTUlJQkNnS0NBUUVBZzRkQVI2WGJCREFTOWhyL0VqM2RKdjZGZmM0NjZ4L21PR01XVTNsckFCczNxYThCSG11Skdua2ZicEVmMnZBd1lUT1dQdnZ6Zk0xME9CYmZsb1N5cTNjOU1LdnlUZTFsdUJMR3FXNHZaVVhJeXZTZ3oxbGl5VVZlZklReTNkeUY5amJlVFpiQzBiYmNULzdPM0RFTCswMXo2QStyRENhY1NaMGxHb2xTUTZBbmhMeHpJa1ZwT1FKYnJCbUMreCtadVpQQ01Xekp5bmQ1YWVPbjdqYWovbWtSVnl4ZTZnLzBPaFd6NE5paVpYZXVNUkIrOG1LeTBmV0QvVWxJbFpXSHNBUzJabXJrWEtxakxxMC8wd3I4SUxKa3pualNxZG5JNUliamczdVFyai80QU4raTlyMjhhUTczL1prUHRZNVNidzBBT2lBQkJ1N2dIbXE5YXlWeFpRSURBUUFCAAAAAA9HQU1FU0NPVU5URVJLRVkCAAAACSRHQU1FX05VTQAAAAAEV0JFVAEAAAAgD5uLrFpvaCc5H1Jt+IyA7GJAqs11k4f4jn5gjTii4MkAAAAAC0ZFRVdBVkVTQkVUAAAAAAAAAAAEAAAAAAlGRUVNQ0FGRUUAAAAAAAAAAAIAAAAAB1dBVkVMRVQAAAAAAAX14QAAAAAADlNUQVRFU1VCTUlUVEVEAgAAAAlTVUJNSVRURUQAAAAADVNUQVRFQUNDRVBURUQCAAAACEFDQ0VQVEVEAAAAAA1TVEFURUZJTklTSEVEAgAAAAhGSU5JU0hFRAAAAAANU1RBVEVDQU5DRUxFRAIAAAAIQ0FOQ0VMRUQAAAAAB0NPSU5SRUQCAAAAA1JFRAAAAAAIQ09JTkJMVUUCAAAABEJMVUUAAAAAC0JFVE1JTldBVkVTCQAAaQAAAAIJAABoAAAAAgAAAAAAAAAAAQUAAAAHV0FWRUxFVAAAAAAAAAAAAgAAAAAKQkVUTUlOV0JFVAkAAGgAAAACAAAAAAAAAABkBQAAAAdXQVZFTEVUAAAAAAxJZHhHYW1lU3RhdGUA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AAAAAAAAZAAAAAMAAAABaQEAAAAIcGxheUNvaW4AAAABAAAABnBhQ29pbgQAAAAGZ2FtZUlkCQACWAAAAAEIBQAAAAFpAAAADXRyYW5zYWN0aW9uSWQEAAAACmdhbWVJZFVzZWQJAQAAAAlpc0RlZmluZWQAAAABCQAEHQAAAAIFAAAABHRoaXMFAAAABmdhbWVJZAQAAAAHcGF5bWVudAkBAAAAB2V4dHJhY3QAAAABCAUAAAABaQAAAAdwYXltZW50BAAAAApmZWVBc3NldElkCQEAAAAJaXNEZWZpbmVkAAAAAQgFAAAAAWkAAAAKZmVlQXNzZXRJZAMDCQEAAAACIT0AAAACCAUAAAAHcGF5bWVudAAAAAdhc3NldElkCQAD7AAAAAEBAAAABBOr2TMJAQAAAAIhPQAAAAIIBQAAAAdwYXltZW50AAAAB2Fzc2V0SWQFAAAABFdCRVQHCQAAAgAAAAECAAAAMVBheW1lbnQgc2hvdWxkIGJlIGluIFdiZXQgb3IgV2F2ZXMuIEdhbWUgYWJvcnRlZC4DBQAAAApmZWVBc3NldElkCQAAAgAAAAECAAAAMVRyYW5zYWN0aW9uJ3MgZmVlIG11c3QgYmUgaW4gV2F2ZXMuIEdhbWUgYWJvcnRlZC4DBQAAAApnYW1lSWRVc2VkCQAAAgAAAAECAAAAMVBhc3NlZCBnYW1lSWQgaGFkIGJlZW4gdXNlZCBiZWZvcmUuIEdhbWUgYWJvcnRlZC4EAAAACm5ld0dhbWVOdW0JAQAAABBJbmNyZW1lbnRHYW1lTnVtAAAAAAQAAAAPcGxheWVyQVB1YktleTU4CQACWAAAAAEIBQAAAAFpAAAAD2NhbGxlclB1YmxpY0tleQQAAAAHcGF5VHlwZQkBAAAAC3BheW1lbnRUeXBlAAAAAQUAAAAHcGF5bWVudAQAAAAGd2luQW10CQEAAAAaVmFsaWRhdGVCZXRBbmREZWZpbmVXaW5BbXQAAAADCAUAAAAHcGF5bWVudAAAAAZhbW91bnQFAAAABnBhQ29pbgUAAAAHcGF5VHlwZQQAAAALZ2FtZURhdGFTdHIJAQAAABFGb3JtYXRHYW1lRGF0YVN0cgAAAAkFAAAADlNUQVRFU1VCTUlUVEVEBQAAAAZwYUNvaW4FAAAAD3BsYXllckFQdWJLZXk1OAUAAAAHcGF5VHlwZQgFAAAAB3BheW1lbnQAAAAGYW1vdW50BQAAAAZ3aW5BbXQCAAAAAAIAAAAAAgAAAAAJAQAAAAxTY3JpcHRSZXN1bHQAAAACCQEAAAAIV3JpdGVTZXQAAAABCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACBQAAAA9HQU1FU0NPVU5URVJLRVkFAAAACm5ld0dhbWVOdW0JAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAABmdhbWVJZAUAAAALZ2FtZURhdGFTdHIFAAAAA25pbAkBAAAAC1RyYW5zZmVyU2V0AAAAAQUAAAADbmlsAAAAAWkBAAAAE2FjY2VwdENvaW5DaGFsbGVuZ2UAAAACAAAABmdhbWVJZAAAAAZyc2FTaWcEAAAADGdhbWVEYXRhTGlzdAkBAAAAE0V4dHJhY3RHYW1lRGF0YUxpc3QAAAABBQAAAAZnYW1lSWQEAAAACWdhbWVTdGF0ZQkAAZEAAAACBQAAAAxnYW1lRGF0YUxpc3QFAAAADElkeEdhbWVTdGF0ZQQAAAAGcGFDb2luCQABkQAAAAIFAAAADGdhbWVEYXRhTGlzdAUAAAAOSWR4UGxheWVyQUNvaW4EAAAACnBhUHViS2V5NTgJAAGRAAAAAgUAAAAMZ2FtZURhdGFMaXN0BQAAABJJZHhQbGF5ZXJBUHViS2V5NTgEAAAAB3BheVR5cGUJAAGRAAAAAgUAAAAMZ2FtZURhdGFMaXN0BQAAAApJZHhQYXlUeXBlBAAAAAZwYXlBbXQJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAAxnYW1lRGF0YUxpc3QFAAAACUlkeFBheUFtdAQAAAAGd2luQW10CQEAAAANcGFyc2VJbnRWYWx1ZQAAAAEJAAGRAAAAAgUAAAAMZ2FtZURhdGFMaXN0BQAAAAlJZHhXaW5BbXQEAAAAB3BheW1lbnQJAQAAAAdleHRyYWN0AAAAAQgFAAAAAWkAAAAHcGF5bWVudAQAAAAKZmVlQXNzZXRJZAkBAAAACWlzRGVmaW5lZAAAAAEIBQAAAAFpAAAACmZlZUFzc2V0SWQEAAAACnBiUHViS2V5NTgJAAJYAAAAAQgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5BAAAAAhwYXlUeXBlQgkBAAAAC3BheW1lbnRUeXBlAAAAAQUAAAAHcGF5bWVudAMDCQEAAAACIT0AAAACCAUAAAAHcGF5bWVudAAAAAdhc3NldElkCQAD7AAAAAEBAAAABBOr2TMJAQAAAAIhPQAAAAIIBQAAAAdwYXltZW50AAAAB2Fzc2V0SWQFAAAABFdCRVQHCQAAAgAAAAECAAAAMVBheW1lbnQgc2hvdWxkIGJlIGluIFdiZXQgb3IgV2F2ZXMuIEdhbWUgYWJvcnRlZC4DBQAAAApmZWVBc3NldElkCQAAAgAAAAECAAAAMVRyYW5zYWN0aW9uJ3MgZmVlIG11c3QgYmUgaW4gV2F2ZXMuIEdhbWUgYWJvcnRlZC4DCQAAAAAAAAIFAAAACnBhUHViS2V5NTgFAAAACnBiUHViS2V5NTgJAAACAAAAAQIAAAA/WW91IGNhbid0IGFjY2VwdCBhIGNoYWxsZW5nZSBjcmVhdGVkIGJ5IHlvdXJzZWxmLiBHYW1lIGFib3J0ZWQuAwkBAAAAAiE9AAAAAgUAAAAHcGF5VHlwZQUAAAAIcGF5VHlwZUIJAAACAAAAAQIAAABjUGF5bWVudCBtdXN0IGJlIG1hZGUgaW4gdGhlIHNhbWUgY3VycmVuY3kgdG9rZW4gYXMgdGhlIGJldCwgV0JFVC9XQkVUIG9yIFdBVkVTL1dBVkVTLiBHYW1lIGFib3J0ZWQuAwkBAAAAAiE9AAAAAgUAAAAGcGF5QW10CAUAAAAHcGF5bWVudAAAAAZhbW91bnQJAAACAAAAAQIAAABAUGF5b3V0IG11c3QgYmUgZXF1YWwgdG8gdGhlIGNoYWxsZW5nZXIgYmV0IGFtb3VudC4gR2FtZSBhYm9ydGVkLgMJAQAAAAIhPQAAAAIFAAAACWdhbWVTdGF0ZQUAAAAOU1RBVEVTVUJNSVRURUQJAAACAAAAAQIAAAAzSW52YWxpZCBnYW1lIHN0YXRlIGZvciBwYXNzZWQgZ2FtZUlkLiBHYW1lIGFib3J0ZWQuBAAAAARyYW5kCQEAAAAOZ2VuZXJhdGVOdW1iZXIAAAADBQAAAAFpAAAAAAAAAABkAAAAAAAAAAAABAAAAAlsdWNreUNvaW4DCQAAZgAAAAIFAAAABHJhbmQAAAAAAAAAADIFAAAAB0NPSU5SRUQFAAAACENPSU5CTFVFBAAAAAZwYkNvaW4DCQAAAAAAAAIFAAAABnBhQ29pbgUAAAAHQ09JTlJFRAUAAAAIQ09JTkJMVUUFAAAAB0NPSU5SRUQEAAAADm5ld0dhbWVEYXRhU3RyCQEAAAARRm9ybWF0R2FtZURhdGFTdHIAAAAJBQAAAA1TVEFURUFDQ0VQVEVEBQAAAAZwYUNvaW4FAAAACnBhUHViS2V5NTgFAAAAB3BheVR5cGUFAAAABnBheUFtdAUAAAAGd2luQW10BQAAAAZwYkNvaW4FAAAACnBiUHViS2V5NTgFAAAACWx1Y2t5Q29pbgkBAAAADFNjcmlwdFJlc3VsdAAAAAIJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAABmdhbWVJZAUAAAAObmV3R2FtZURhdGFTdHIFAAAAA25pbAkBAAAAC1RyYW5zZmVyU2V0AAAAAQUAAAADbmlsAAAAAWkBAAAAE2NhbmNlbENvaW5DaGFsbGVuZ2UAAAABAAAABmdhbWVJZAQAAAAMZ2FtZURhdGFMaXN0CQEAAAATRXh0cmFjdEdhbWVEYXRhTGlzdAAAAAEFAAAABmdhbWVJZAQAAAAJZ2FtZVN0YXRlCQABkQAAAAIFAAAADGdhbWVEYXRhTGlzdAUAAAAMSWR4R2FtZVN0YXRlBAAAAAZwYUNvaW4JAAGRAAAAAgUAAAAMZ2FtZURhdGFMaXN0BQAAAA5JZHhQbGF5ZXJBQ29pbgQAAAAKcGFQdWJLZXk1OAkAAZEAAAACBQAAAAxnYW1lRGF0YUxpc3QFAAAAEklkeFBsYXllckFQdWJLZXk1OAQAAAAHcGF5VHlwZQkAAZEAAAACBQAAAAxnYW1lRGF0YUxpc3QFAAAACklkeFBheVR5cGUEAAAABnBheUFtdAkBAAAADXBhcnNlSW50VmFsdWUAAAABCQABkQAAAAIFAAAADGdhbWVEYXRhTGlzdAUAAAAJSWR4UGF5QW10BAAAAAZ3aW5BbXQJAQAAAA1wYXJzZUludFZhbHVlAAAAAQkAAZEAAAACBQAAAAxnYW1lRGF0YUxpc3QFAAAACUlkeFdpbkFtdAQAAAAIcHViS2V5NTgJAAJYAAAAAQgFAAAAAWkAAAAPY2FsbGVyUHVibGljS2V5BAAAAApmZWVBc3NldElkCQEAAAAJaXNEZWZpbmVkAAAAAQgFAAAAAWkAAAAKZmVlQXNzZXRJZAMFAAAACmZlZUFzc2V0SWQJAAACAAAAAQIAAAAxVHJhbnNhY3Rpb24ncyBmZWUgbXVzdCBiZSBpbiBXYXZlcy4gR2FtZSBhYm9ydGVkLgMJAQAAAAIhPQAAAAIFAAAACWdhbWVTdGF0ZQUAAAAOU1RBVEVTVUJNSVRURUQJAAACAAAAAQIAAAAzSW52YWxpZCBnYW1lIHN0YXRlIGZvciBwYXNzZWQgZ2FtZUlkLiBHYW1lIGFib3J0ZWQuAwkBAAAAAiE9AAAAAgUAAAAKcGFQdWJLZXk1OAUAAAAIcHViS2V5NTgJAAACAAAAAQIAAABBWW91IGNhbm5vdCBjYW5jZWwgYSBnYW1lIGNyZWF0ZWQgYnkgYW5vdGhlciBwbGF5ZXIuIEdhbWUgYWJvcnRlZC4EAAAADm5ld0dhbWVEYXRhU3RyCQEAAAARRm9ybWF0R2FtZURhdGFTdHIAAAAJBQAAAA1TVEFURUNBTkNFTEVEBQAAAAZwYUNvaW4FAAAACnBhUHViS2V5NTgFAAAAB3BheVR5cGUFAAAABnBheUFtdAUAAAAGd2luQW10AgAAAAACAAAAAAIAAAAABAAAAAlyZWZ1bmRBbXQJAABlAAAAAgUAAAAGcGF5QW10CQAAaQAAAAIJAABoAAAAAgUAAAAGcGF5QW10BQAAAAtGRUVXQVZFU0JFVAAAAAAAAAAAZAQAAAAMcmVmdW5kV2FsbGV0CQEAAAAUYWRkcmVzc0Zyb21QdWJsaWNLZXkAAAABCQABmwAAAAEFAAAACnBhUHViS2V5NTgEAAAAC3JlZnVuZFRva2VuCQEAAAAJdG9rZW5UeXBlAAAAAQUAAAAHcGF5VHlwZQkBAAAADFNjcmlwdFJlc3VsdAAAAAIJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIFAAAABmdhbWVJZAUAAAAObmV3R2FtZURhdGFTdHIFAAAAA25pbAkBAAAAC1RyYW5zZmVyU2V0AAAAAQkABEwAAAACCQEAAAAOU2NyaXB0VHJhbnNmZXIAAAADBQAAAAxyZWZ1bmRXYWxsZXQFAAAACXJlZnVuZEFtdAUAAAALcmVmdW5kVG9rZW4FAAAAA25pbAAAAACwx02w", "chainId": 84, "height": 741465, "spentComplexity": 0 } View: original | compacted Prev: 8Zy83qKBhnYGHLK7WxVwkmBgp7Bw8j1PdmbszNT2DDXi Next: 66MeUeLqE6LnuMZUWuvBYcZQLiZbsMHPtkezsUwaAH5c Diff:
Old | New | Differences | |
---|---|---|---|
189 | 189 | ||
190 | 190 | ||
191 | 191 | @Callable(i) | |
192 | + | func acceptCoinChallenge (gameId,rsaSig) = { | |
193 | + | let gameDataList = ExtractGameDataList(gameId) | |
194 | + | let gameState = gameDataList[IdxGameState] | |
195 | + | let paCoin = gameDataList[IdxPlayerACoin] | |
196 | + | let paPubKey58 = gameDataList[IdxPlayerAPubKey58] | |
197 | + | let payType = gameDataList[IdxPayType] | |
198 | + | let payAmt = parseIntValue(gameDataList[IdxPayAmt]) | |
199 | + | let winAmt = parseIntValue(gameDataList[IdxWinAmt]) | |
200 | + | let payment = extract(i.payment) | |
201 | + | let feeAssetId = isDefined(i.feeAssetId) | |
202 | + | let pbPubKey58 = toBase58String(i.callerPublicKey) | |
203 | + | let payTypeB = paymentType(payment) | |
204 | + | if (if ((payment.assetId != assetInfo(base58'WAVES'))) | |
205 | + | then (payment.assetId != WBET) | |
206 | + | else false) | |
207 | + | then throw("Payment should be in Wbet or Waves. Game aborted.") | |
208 | + | else if (feeAssetId) | |
209 | + | then throw("Transaction's fee must be in Waves. Game aborted.") | |
210 | + | else if ((paPubKey58 == pbPubKey58)) | |
211 | + | then throw("You can't accept a challenge created by yourself. Game aborted.") | |
212 | + | else if ((payType != payTypeB)) | |
213 | + | then throw("Payment must be made in the same currency token as the bet, WBET/WBET or WAVES/WAVES. Game aborted.") | |
214 | + | else if ((payAmt != payment.amount)) | |
215 | + | then throw("Payout must be equal to the challenger bet amount. Game aborted.") | |
216 | + | else if ((gameState != STATESUBMITTED)) | |
217 | + | then throw("Invalid game state for passed gameId. Game aborted.") | |
218 | + | else { | |
219 | + | let rand = generateNumber(i, 100, 0) | |
220 | + | let luckyCoin = if ((rand > 50)) | |
221 | + | then COINRED | |
222 | + | else COINBLUE | |
223 | + | let pbCoin = if ((paCoin == COINRED)) | |
224 | + | then COINBLUE | |
225 | + | else COINRED | |
226 | + | let newGameDataStr = FormatGameDataStr(STATEACCEPTED, paCoin, paPubKey58, payType, payAmt, winAmt, pbCoin, pbPubKey58, luckyCoin) | |
227 | + | ScriptResult(WriteSet([DataEntry(gameId, newGameDataStr)]), TransferSet(nil)) | |
228 | + | } | |
229 | + | } | |
230 | + | ||
231 | + | ||
232 | + | ||
233 | + | @Callable(i) | |
192 | 234 | func cancelCoinChallenge (gameId) = { | |
193 | 235 | let gameDataList = ExtractGameDataList(gameId) | |
194 | 236 | let gameState = gameDataList[IdxGameState] | |
195 | - | throw(gameState) | |
237 | + | let paCoin = gameDataList[IdxPlayerACoin] | |
238 | + | let paPubKey58 = gameDataList[IdxPlayerAPubKey58] | |
239 | + | let payType = gameDataList[IdxPayType] | |
240 | + | let payAmt = parseIntValue(gameDataList[IdxPayAmt]) | |
241 | + | let winAmt = parseIntValue(gameDataList[IdxWinAmt]) | |
242 | + | let pubKey58 = toBase58String(i.callerPublicKey) | |
243 | + | let feeAssetId = isDefined(i.feeAssetId) | |
244 | + | if (feeAssetId) | |
245 | + | then throw("Transaction's fee must be in Waves. Game aborted.") | |
246 | + | else if ((gameState != STATESUBMITTED)) | |
247 | + | then throw("Invalid game state for passed gameId. Game aborted.") | |
248 | + | else if ((paPubKey58 != pubKey58)) | |
249 | + | then throw("You cannot cancel a game created by another player. Game aborted.") | |
250 | + | else { | |
251 | + | let newGameDataStr = FormatGameDataStr(STATECANCELED, paCoin, paPubKey58, payType, payAmt, winAmt, "", "", "") | |
252 | + | let refundAmt = (payAmt - ((payAmt * FEEWAVESBET) / 100)) | |
253 | + | let refundWallet = addressFromPublicKey(toBytes(paPubKey58)) | |
254 | + | let refundToken = tokenType(payType) | |
255 | + | ScriptResult(WriteSet([DataEntry(gameId, newGameDataStr)]), TransferSet([ScriptTransfer(refundWallet, refundAmt, refundToken)])) | |
256 | + | } | |
196 | 257 | } | |
197 | 258 | ||
198 | 259 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let RSAPUBLIC = fromBase64String("base64:MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAg4dAR6XbBDAS9hr/Ej3dJv6Ffc466x/mOGMWU3lrABs3qa8BHmuJGnkfbpEf2vAwYTOWPvvzfM10OBbfloSyq3c9MKvyTe1luBLGqW4vZUXIyvSgz1liyUVefIQy3dyF9jbeTZbC0bbcT/7O3DEL+01z6A+rDCacSZ0lGolSQ6AnhLxzIkVpOQJbrBmC+x+ZuZPCMWzJynd5aeOn7jaj/mkRVyxe6g/0OhWz4NiiZXeuMRB+8mKy0fWD/UlIlZWHsAS2ZmrkXKqjLq0/0wr8ILJkznjSqdnI5Ibjg3uQrj/4AN+i9r28aQ73/ZkPtY5Sbw0AOiABBu7gHmq9ayVxZQIDAQAB") | |
5 | 5 | ||
6 | 6 | let GAMESCOUNTERKEY = "$GAME_NUM" | |
7 | 7 | ||
8 | 8 | let WBET = base58'23vgV9p9pD83A7CFbsDEc4zjanep7UeFo4ZRS6oGorhv' | |
9 | 9 | ||
10 | 10 | let FEEWAVESBET = 4 | |
11 | 11 | ||
12 | 12 | let FEEMCAFEE = 2 | |
13 | 13 | ||
14 | 14 | let WAVELET = 100000000 | |
15 | 15 | ||
16 | 16 | let STATESUBMITTED = "SUBMITTED" | |
17 | 17 | ||
18 | 18 | let STATEACCEPTED = "ACCEPTED" | |
19 | 19 | ||
20 | 20 | let STATEFINISHED = "FINISHED" | |
21 | 21 | ||
22 | 22 | let STATECANCELED = "CANCELED" | |
23 | 23 | ||
24 | 24 | let COINRED = "RED" | |
25 | 25 | ||
26 | 26 | let COINBLUE = "BLUE" | |
27 | 27 | ||
28 | 28 | let BETMINWAVES = ((1 * WAVELET) / 2) | |
29 | 29 | ||
30 | 30 | let BETMINWBET = (100 * WAVELET) | |
31 | 31 | ||
32 | 32 | let IdxGameState = 0 | |
33 | 33 | ||
34 | 34 | let IdxPlayerACoin = 1 | |
35 | 35 | ||
36 | 36 | let IdxPlayerAPubKey58 = 2 | |
37 | 37 | ||
38 | 38 | let IdxPayType = 3 | |
39 | 39 | ||
40 | 40 | let IdxPayAmt = 4 | |
41 | 41 | ||
42 | 42 | let IdxWinAmt = 5 | |
43 | 43 | ||
44 | 44 | let IdxPlayerBCoin = 6 | |
45 | 45 | ||
46 | 46 | let IdxPlayerBPubKey58 = 7 | |
47 | 47 | ||
48 | 48 | let IdxLuckyCoin = 8 | |
49 | 49 | ||
50 | 50 | func IncrementGameNum () = { | |
51 | 51 | let gameNum = match getInteger(this, GAMESCOUNTERKEY) { | |
52 | 52 | case num: Int => | |
53 | 53 | num | |
54 | 54 | case _ => | |
55 | 55 | 0 | |
56 | 56 | } | |
57 | 57 | (gameNum + 1) | |
58 | 58 | } | |
59 | 59 | ||
60 | 60 | ||
61 | 61 | func generateNumber (inv,max,min) = { | |
62 | 62 | let lastPlay = match getBinary(this, "lastPlay") { | |
63 | 63 | case s: ByteVector => | |
64 | 64 | s | |
65 | 65 | case a: Unit => | |
66 | 66 | base58'2ee4oFDYriWJ9EMeR' | |
67 | 67 | case _ => | |
68 | 68 | throw() | |
69 | 69 | } | |
70 | 70 | let rand = (((((lastPlay + inv.transactionId) + inv.callerPublicKey) + lastBlock.generationSignature) + toBytes(lastBlock.timestamp)) + toBytes(lastBlock.height)) | |
71 | 71 | (((toInt(sha256(rand)) % 1000) % ((max - min) + 1)) + 1) | |
72 | 72 | } | |
73 | 73 | ||
74 | 74 | ||
75 | 75 | func paymentType (payment) = if ((payment.assetId == WBET)) | |
76 | 76 | then "WBET" | |
77 | 77 | else "WAVES" | |
78 | 78 | ||
79 | 79 | ||
80 | 80 | func tokenType (token) = if ((token == "WBET")) | |
81 | 81 | then WBET | |
82 | 82 | else unit | |
83 | 83 | ||
84 | 84 | ||
85 | 85 | func FormatGameDataParam (p) = { | |
86 | 86 | let s = size(p) | |
87 | 87 | if ((s == 0)) | |
88 | 88 | then throw("Parameter size must be greater then 0") | |
89 | 89 | else if ((s > 99)) | |
90 | 90 | then throw("Parameter size must be less then 100") | |
91 | 91 | else if ((10 > s)) | |
92 | 92 | then (("0" + toString(s)) + p) | |
93 | 93 | else (toString(s) + p) | |
94 | 94 | } | |
95 | 95 | ||
96 | 96 | ||
97 | 97 | func FormatGameDataStr (gameState,playerACoin,playerAPubKey58,payType,payAmount,winAmt,playerBCoin,playerBPubKey58,luckyCoin) = { | |
98 | 98 | let fullStateStr = ((((((((((FormatGameDataParam(gameState) + "_") + FormatGameDataParam(playerACoin)) + "_") + FormatGameDataParam(playerAPubKey58)) + "_") + FormatGameDataParam(payType)) + "_") + FormatGameDataParam(toString(payAmount))) + "_") + FormatGameDataParam(toString(winAmt))) | |
99 | 99 | if (if (if ((playerBCoin == "")) | |
100 | 100 | then true | |
101 | 101 | else (playerBPubKey58 == "")) | |
102 | 102 | then true | |
103 | 103 | else (luckyCoin == "")) | |
104 | 104 | then fullStateStr | |
105 | 105 | else ((((((fullStateStr + "_") + FormatGameDataParam(playerBCoin)) + "_") + FormatGameDataParam(playerBPubKey58)) + "_") + FormatGameDataParam(luckyCoin)) | |
106 | 106 | } | |
107 | 107 | ||
108 | 108 | ||
109 | 109 | func RemoveUnderscoreIfPresent (remaining) = if ((size(remaining) > 0)) | |
110 | 110 | then drop(remaining, 1) | |
111 | 111 | else remaining | |
112 | 112 | ||
113 | 113 | ||
114 | 114 | func ParseNextAttribute (remaining) = { | |
115 | 115 | let s = size(remaining) | |
116 | 116 | if ((s > 0)) | |
117 | 117 | then { | |
118 | 118 | let nn = parseIntValue(take(remaining, 2)) | |
119 | 119 | let v = take(drop(remaining, 2), nn) | |
120 | 120 | let tmpRemaining = drop(remaining, (nn + 2)) | |
121 | 121 | let remainingState = RemoveUnderscoreIfPresent(tmpRemaining) | |
122 | 122 | [v, remainingState] | |
123 | 123 | } | |
124 | 124 | else throw("Empty string was passed into parseNextAttribute func") | |
125 | 125 | } | |
126 | 126 | ||
127 | 127 | ||
128 | 128 | func ParseGameRawDataStr (rawStateStr) = { | |
129 | 129 | let gameState = ParseNextAttribute(rawStateStr) | |
130 | 130 | let paCoin = ParseNextAttribute(gameState[1]) | |
131 | 131 | let paPubKey58 = ParseNextAttribute(paCoin[1]) | |
132 | 132 | let payType = ParseNextAttribute(paPubKey58[1]) | |
133 | 133 | let payAmt = ParseNextAttribute(payType[1]) | |
134 | 134 | let winAmt = ParseNextAttribute(payAmt[1]) | |
135 | 135 | [gameState[0], paCoin[0], paPubKey58[0], payType[0], payAmt[0], winAmt[0]] | |
136 | 136 | } | |
137 | 137 | ||
138 | 138 | ||
139 | 139 | func ExtractGameDataList (gameId) = { | |
140 | 140 | let rawDataStr = match getString(this, gameId) { | |
141 | 141 | case str: String => | |
142 | 142 | str | |
143 | 143 | case _ => | |
144 | 144 | throw(("Couldn't find game by " + gameId)) | |
145 | 145 | } | |
146 | 146 | ParseGameRawDataStr(rawDataStr) | |
147 | 147 | } | |
148 | 148 | ||
149 | 149 | ||
150 | 150 | func ValidateBetAndDefineWinAmt (amount,playerCoin,paymentType) = if (if ((playerCoin != COINRED)) | |
151 | 151 | then (playerCoin != COINBLUE) | |
152 | 152 | else false) | |
153 | 153 | then throw("Invalid play, change your bet to RED or BLUE coin. Game aborted.") | |
154 | 154 | else if (if ((paymentType == "WBET")) | |
155 | 155 | then (BETMINWBET > amount) | |
156 | 156 | else false) | |
157 | 157 | then throw(("The minimum bet on Wbet is " + toString((BETMINWBET / WAVELET)))) | |
158 | 158 | else if (if ((paymentType == "WAVES")) | |
159 | 159 | then (BETMINWAVES > amount) | |
160 | 160 | else false) | |
161 | 161 | then throw(("The minimum bet on Waves is " + toString((BETMINWAVES / WAVELET)))) | |
162 | 162 | else (((amount * 2) * (100 - (FEEWAVESBET + FEEMCAFEE))) / 100) | |
163 | 163 | ||
164 | 164 | ||
165 | 165 | @Callable(i) | |
166 | 166 | func playCoin (paCoin) = { | |
167 | 167 | let gameId = toBase58String(i.transactionId) | |
168 | 168 | let gameIdUsed = isDefined(getString(this, gameId)) | |
169 | 169 | let payment = extract(i.payment) | |
170 | 170 | let feeAssetId = isDefined(i.feeAssetId) | |
171 | 171 | if (if ((payment.assetId != assetInfo(base58'WAVES'))) | |
172 | 172 | then (payment.assetId != WBET) | |
173 | 173 | else false) | |
174 | 174 | then throw("Payment should be in Wbet or Waves. Game aborted.") | |
175 | 175 | else if (feeAssetId) | |
176 | 176 | then throw("Transaction's fee must be in Waves. Game aborted.") | |
177 | 177 | else if (gameIdUsed) | |
178 | 178 | then throw("Passed gameId had been used before. Game aborted.") | |
179 | 179 | else { | |
180 | 180 | let newGameNum = IncrementGameNum() | |
181 | 181 | let playerAPubKey58 = toBase58String(i.callerPublicKey) | |
182 | 182 | let payType = paymentType(payment) | |
183 | 183 | let winAmt = ValidateBetAndDefineWinAmt(payment.amount, paCoin, payType) | |
184 | 184 | let gameDataStr = FormatGameDataStr(STATESUBMITTED, paCoin, playerAPubKey58, payType, payment.amount, winAmt, "", "", "") | |
185 | 185 | ScriptResult(WriteSet([DataEntry(GAMESCOUNTERKEY, newGameNum), DataEntry(gameId, gameDataStr)]), TransferSet(nil)) | |
186 | 186 | } | |
187 | 187 | } | |
188 | 188 | ||
189 | 189 | ||
190 | 190 | ||
191 | 191 | @Callable(i) | |
192 | + | func acceptCoinChallenge (gameId,rsaSig) = { | |
193 | + | let gameDataList = ExtractGameDataList(gameId) | |
194 | + | let gameState = gameDataList[IdxGameState] | |
195 | + | let paCoin = gameDataList[IdxPlayerACoin] | |
196 | + | let paPubKey58 = gameDataList[IdxPlayerAPubKey58] | |
197 | + | let payType = gameDataList[IdxPayType] | |
198 | + | let payAmt = parseIntValue(gameDataList[IdxPayAmt]) | |
199 | + | let winAmt = parseIntValue(gameDataList[IdxWinAmt]) | |
200 | + | let payment = extract(i.payment) | |
201 | + | let feeAssetId = isDefined(i.feeAssetId) | |
202 | + | let pbPubKey58 = toBase58String(i.callerPublicKey) | |
203 | + | let payTypeB = paymentType(payment) | |
204 | + | if (if ((payment.assetId != assetInfo(base58'WAVES'))) | |
205 | + | then (payment.assetId != WBET) | |
206 | + | else false) | |
207 | + | then throw("Payment should be in Wbet or Waves. Game aborted.") | |
208 | + | else if (feeAssetId) | |
209 | + | then throw("Transaction's fee must be in Waves. Game aborted.") | |
210 | + | else if ((paPubKey58 == pbPubKey58)) | |
211 | + | then throw("You can't accept a challenge created by yourself. Game aborted.") | |
212 | + | else if ((payType != payTypeB)) | |
213 | + | then throw("Payment must be made in the same currency token as the bet, WBET/WBET or WAVES/WAVES. Game aborted.") | |
214 | + | else if ((payAmt != payment.amount)) | |
215 | + | then throw("Payout must be equal to the challenger bet amount. Game aborted.") | |
216 | + | else if ((gameState != STATESUBMITTED)) | |
217 | + | then throw("Invalid game state for passed gameId. Game aborted.") | |
218 | + | else { | |
219 | + | let rand = generateNumber(i, 100, 0) | |
220 | + | let luckyCoin = if ((rand > 50)) | |
221 | + | then COINRED | |
222 | + | else COINBLUE | |
223 | + | let pbCoin = if ((paCoin == COINRED)) | |
224 | + | then COINBLUE | |
225 | + | else COINRED | |
226 | + | let newGameDataStr = FormatGameDataStr(STATEACCEPTED, paCoin, paPubKey58, payType, payAmt, winAmt, pbCoin, pbPubKey58, luckyCoin) | |
227 | + | ScriptResult(WriteSet([DataEntry(gameId, newGameDataStr)]), TransferSet(nil)) | |
228 | + | } | |
229 | + | } | |
230 | + | ||
231 | + | ||
232 | + | ||
233 | + | @Callable(i) | |
192 | 234 | func cancelCoinChallenge (gameId) = { | |
193 | 235 | let gameDataList = ExtractGameDataList(gameId) | |
194 | 236 | let gameState = gameDataList[IdxGameState] | |
195 | - | throw(gameState) | |
237 | + | let paCoin = gameDataList[IdxPlayerACoin] | |
238 | + | let paPubKey58 = gameDataList[IdxPlayerAPubKey58] | |
239 | + | let payType = gameDataList[IdxPayType] | |
240 | + | let payAmt = parseIntValue(gameDataList[IdxPayAmt]) | |
241 | + | let winAmt = parseIntValue(gameDataList[IdxWinAmt]) | |
242 | + | let pubKey58 = toBase58String(i.callerPublicKey) | |
243 | + | let feeAssetId = isDefined(i.feeAssetId) | |
244 | + | if (feeAssetId) | |
245 | + | then throw("Transaction's fee must be in Waves. Game aborted.") | |
246 | + | else if ((gameState != STATESUBMITTED)) | |
247 | + | then throw("Invalid game state for passed gameId. Game aborted.") | |
248 | + | else if ((paPubKey58 != pubKey58)) | |
249 | + | then throw("You cannot cancel a game created by another player. Game aborted.") | |
250 | + | else { | |
251 | + | let newGameDataStr = FormatGameDataStr(STATECANCELED, paCoin, paPubKey58, payType, payAmt, winAmt, "", "", "") | |
252 | + | let refundAmt = (payAmt - ((payAmt * FEEWAVESBET) / 100)) | |
253 | + | let refundWallet = addressFromPublicKey(toBytes(paPubKey58)) | |
254 | + | let refundToken = tokenType(payType) | |
255 | + | ScriptResult(WriteSet([DataEntry(gameId, newGameDataStr)]), TransferSet([ScriptTransfer(refundWallet, refundAmt, refundToken)])) | |
256 | + | } | |
196 | 257 | } | |
197 | 258 | ||
198 | 259 |
github/deemru/w8io/169f3d6 41.14 ms ◑