tx · 3At9CmPFub6bK7pDm9CEiiuyr6xuPaxxfnsKvmDUKuHY 3Mu9qAjmg8fVTxxpwPZnBAH948ujt4m6Xvk: -0.01000000 Waves 2021.10.20 12:15 [1754412] smart account 3Mu9qAjmg8fVTxxpwPZnBAH948ujt4m6Xvk > SELF 0.00000000 Waves
{ "type": 13, "id": "3At9CmPFub6bK7pDm9CEiiuyr6xuPaxxfnsKvmDUKuHY", "fee": 1000000, "feeAssetId": null, "timestamp": 1634721373842, "version": 2, "chainId": 84, "sender": "3Mu9qAjmg8fVTxxpwPZnBAH948ujt4m6Xvk", "senderPublicKey": "8v9pmcXqHz9DTc5k1Z8duTYyDwykFxN3EzdZ9WAn3KXJ", "proofs": [ "57EZHSE3pdfx53AG7m6HDu1CE9hKAyTrkv4SHd1WWkHoWi9FyS42qXgCp8ViHVb8up8xFQCjYzSZXAZm7QvfDVZs" ], "script": "base64:AAIFAAAAAAAAAAkIAhIAEgMKAQEAAAAMAAAAAA1nYW1lTnVtYmVyS2V5AgAAAAwkR0FNRV9OVU1CRVIAAAAAB3Rlc3RLZXkCAAAABSRURVNUAAAAAAxkZWxheUZvckdhbWUAAAAAAAAAAAIAAAAAC0dhbWVTdGFydGVkAAAAAAAAAAABAAAAAAxHYW1lRmluaXNoZWQAAAAAAAAAAAIBAAAAEGdldEdhbWVTdGF0dXNLZXkAAAACAAAAB2FkZHJlc3MAAAAGZ2FtZUlkAgAAAAFhAQAAAA5nZXRHYW1lVHhJZEtleQAAAAIAAAAHYWRkcmVzcwAAAAZnYW1lSWQJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAAB2FkZHJlc3MCAAAAAV8JAAGkAAAAAQUAAAAGZ2FtZUlkAgAAAAVfdHhpZAEAAAAZZ2V0R2FtZWluZ0ZpbmlzaEhlaWdodEtleQAAAAIAAAAHYWRkcmVzcwAAAAZnYW1lSWQJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAAB2FkZHJlc3MCAAAAAV8JAAGkAAAAAQUAAAAGZ2FtZUlkAgAAAANfZmgBAAAADWdldEFzc2V0SWRLZXkAAAACAAAAB2FkZHJlc3MAAAAGZ2FtZUlkCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAAdhZGRyZXNzAgAAAAFfCQABpAAAAAEFAAAABmdhbWVJZAIAAAADX2RpAQAAAA10cnlHZXRJbnRlZ2VyAAAAAQAAAANrZXkEAAAAA3ZhbAQAAAAHJG1hdGNoMAkABBoAAAACBQAAAAR0aGlzBQAAAANrZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAAA0ludAQAAAABYgUAAAAHJG1hdGNoMAUAAAABYgAAAAAAAAAAAAUAAAADdmFsAQAAAA9nZXRSYW5kb21OdW1iZXIAAAAEAAAACHZhcmlhbnRzAAAABHR4SWQAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAAAAAZvZmZzZXQEAAAAD3JhbmRvbVNlZWRCbG9jawkBAAAABXZhbHVlAAAAAQkAA+0AAAABCQAAZQAAAAIFAAAAE2dhbWVpbmdGaW5pc2hIZWlnaHQAAAAAAAAAAAEEAAAACnJhbmRvbUhhc2gJAAH3AAAAAQkAAMsAAAACBQAAAAR0eElkCQEAAAAFdmFsdWUAAAABCAUAAAAPcmFuZG9tU2VlZEJsb2NrAAAAA3ZyZgkAAGoAAAACCQAEsgAAAAIFAAAACnJhbmRvbUhhc2gJAABoAAAAAgUAAAAGb2Zmc2V0AAAAAAAAAAAIBQAAAAh2YXJpYW50cwEAAAANZ2V0UmFuZG9tTmFtZQAAAAIAAAAEdHhJZAAAABNnYW1laW5nRmluaXNoSGVpZ2h0BAAAAARyYW5kCQEAAAAPZ2V0UmFuZG9tTnVtYmVyAAAABAAAAAAAAAAAAgUAAAAEdHhJZAUAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAAAAAAAAAAAAAMJAAAAAAAAAgUAAAAEcmFuZAAAAAAAAAAAAAIAAAAFdHlwZTECAAAABXR5cGUyAAAAAgAAAAFpAQAAABBzdGFydEFzc2V0R2FtaW5nAAAAAAQAAAAMZmlyc3RQYXltZW50CQEAAAAFdmFsdWUAAAABCQABkQAAAAIIBQAAAAFpAAAACHBheW1lbnRzAAAAAAAAAAAABAAAAAZnYW1lSWQJAQAAAA10cnlHZXRJbnRlZ2VyAAAAAQUAAAANZ2FtZU51bWJlcktleQkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgkBAAAAEGdldEdhbWVTdGF0dXNLZXkAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAGZ2FtZUlkBQAAAAtHYW1lU3RhcnRlZAkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQEAAAAOZ2V0R2FtZVR4SWRLZXkAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAGZ2FtZUlkCQACWAAAAAEIBQAAAAFpAAAADXRyYW5zYWN0aW9uSWQJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAIJAQAAABlnZXRHYW1laW5nRmluaXNoSGVpZ2h0S2V5AAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAABmdhbWVJZAkAAGQAAAACBQAAAAZoZWlnaHQFAAAADGRlbGF5Rm9yR2FtZQkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgUAAAANZ2FtZU51bWJlcktleQkAAGQAAAACBQAAAAZnYW1lSWQAAAAAAAAAAAEFAAAAA25pbAAAAAFpAQAAABFmaW5pc2hBc3NldEdhbWluZwAAAAEAAAAGZ2FtZUlkBAAAABBnYW1laW5nU3RhdHVzS2V5CQEAAAAQZ2V0R2FtZVN0YXR1c0tleQAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAAAZnYW1lSWQEAAAAD2ZpbmlzaEhlaWdodEtleQkBAAAAGWdldEdhbWVpbmdGaW5pc2hIZWlnaHRLZXkAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAGZ2FtZUlkBAAAAAphc3NldElkS2V5CQEAAAANZ2V0QXNzZXRJZEtleQAAAAIJAAQlAAAAAQgFAAAAAWkAAAAGY2FsbGVyBQAAAAZnYW1lSWQEAAAAC2dhbWVUeElkS2V5CQEAAAAOZ2V0R2FtZVR4SWRLZXkAAAACCQAEJQAAAAEIBQAAAAFpAAAABmNhbGxlcgUAAAAGZ2FtZUlkBAAAAA9nYW1laW5nVHhTdGF0dXMJAQAAAA10cnlHZXRJbnRlZ2VyAAAAAQUAAAAQZ2FtZWluZ1N0YXR1c0tleQQAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAkBAAAAEUBleHRyTmF0aXZlKDEwNTApAAAAAgUAAAAEdGhpcwUAAAAPZmluaXNoSGVpZ2h0S2V5BAAAAAhnYW1lVHhJZAkAAlkAAAABCQEAAAARQGV4dHJOYXRpdmUoMTA1MykAAAACBQAAAAR0aGlzBQAAAAtnYW1lVHhJZEtleQMJAAAAAAAAAgUAAAAPZ2FtZWluZ1R4U3RhdHVzBQAAAAxHYW1lRmluaXNoZWQEAAAAB2Fzc2V0SWQJAQAAABFAZXh0ck5hdGl2ZSgxMDUzKQAAAAIFAAAABHRoaXMJAQAAAA1nZXRBc3NldElkS2V5AAAAAgkABCUAAAABCAUAAAABaQAAAAZjYWxsZXIFAAAABmdhbWVJZAkAAAIAAAABCQABLAAAAAICAAAAP1RoZSBhc3NldCB3YXMgZ2FtZWQgYW5kIGNsYWltZWQgYWxyZWFkeSwgaGVyZSBpcyB0aGUgZm9sb3dpbmc6IAUAAAAHYXNzZXRJZAMJAABmAAAAAgUAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAUAAAAGaGVpZ2h0CQAAAgAAAAEJAAEsAAAAAgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgIAAAAbR2FtaW5nIGlzIG5vdCBmaW5pc2hlZCB5ZXQgCQABpAAAAAEJAABlAAAAAgUAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAUAAAAGaGVpZ2h0AgAAACcgYmxvY2tzIHJlbWFpbmluZywgaXQgd2lsbCB0YWtlIGFyb3VuZCAJAAGkAAAAAQkAAGUAAAACBQAAABNnYW1laW5nRmluaXNoSGVpZ2h0BQAAAAZoZWlnaHQCAAAACCBtaW51dGVzBAAAAApyYW5kb25OYW1lCQEAAAANZ2V0UmFuZG9tTmFtZQAAAAIFAAAACGdhbWVUeElkBQAAABNnYW1laW5nRmluaXNoSGVpZ2h0BAAAAAVhc3NldAkABEMAAAAHBQAAAApyYW5kb25OYW1lBQAAAApyYW5kb25OYW1lAAAAAAAAAAABAAAAAAAAAAAABwUAAAAEdW5pdAUAAAATZ2FtZWluZ0ZpbmlzaEhlaWdodAQAAAAHYXNzZXRJZAkABDgAAAABBQAAAAVhc3NldAkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgUAAAAQZ2FtZWluZ1N0YXR1c0tleQUAAAAMR2FtZUZpbmlzaGVkCQAETAAAAAIJAQAAAAtTdHJpbmdFbnRyeQAAAAIFAAAACmFzc2V0SWRLZXkJAAJYAAAAAQUAAAAHYXNzZXRJZAkABEwAAAACCQEAAAALU3RyaW5nRW50cnkAAAACCQACWAAAAAEFAAAAB2Fzc2V0SWQFAAAACmFzc2V0SWRLZXkJAARMAAAAAgUAAAAFYXNzZXQJAARMAAAAAgkBAAAADlNjcmlwdFRyYW5zZmVyAAAAAwgFAAAAAWkAAAAGY2FsbGVyAAAAAAAAAAABBQAAAAdhc3NldElkBQAAAANuaWwAAAAAQoAqxw==", "height": 1754412, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AVqsbv3hRTW93NmnvgHpyaDiJQxM9bige3iMXM2G4XVC Next: 8Qkj7nvKRjWn4gVvi2RbJMkR2WqF1aTPJuJXrwdWfVed Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let gameNumberKey = "$GAME_NUMBER" | |
5 | 5 | ||
6 | - | let lastPlayKey = "$LAST_PLAY" | |
7 | - | ||
8 | 6 | let testKey = "$TEST" | |
9 | 7 | ||
10 | - | let | |
8 | + | let delayForGame = 2 | |
11 | 9 | ||
12 | - | let | |
10 | + | let GameStarted = 1 | |
13 | 11 | ||
14 | - | func payoutcalc (number) = { | |
15 | - | let house = 6 | |
16 | - | let base = 10000 | |
17 | - | let rate = ((base * (100 - 6)) / (number * 100)) | |
18 | - | rate | |
12 | + | let GameFinished = 2 | |
13 | + | ||
14 | + | func getGameStatusKey (address,gameId) = "a" | |
15 | + | ||
16 | + | ||
17 | + | func getGameTxIdKey (address,gameId) = (((address + "_") + toString(gameId)) + "_txid") | |
18 | + | ||
19 | + | ||
20 | + | func getGameingFinishHeightKey (address,gameId) = (((address + "_") + toString(gameId)) + "_fh") | |
21 | + | ||
22 | + | ||
23 | + | func getAssetIdKey (address,gameId) = (((address + "_") + toString(gameId)) + "_di") | |
24 | + | ||
25 | + | ||
26 | + | func tryGetInteger (key) = { | |
27 | + | let val = match getInteger(this, key) { | |
28 | + | case b: Int => | |
29 | + | b | |
30 | + | case _ => | |
31 | + | 0 | |
32 | + | } | |
33 | + | val | |
19 | 34 | } | |
20 | 35 | ||
21 | 36 | ||
22 | - | func randomizer (i) = { | |
23 | - | let lastPlay = match getBinary(this, lastPlayKey) { | |
24 | - | case s: ByteVector => | |
25 | - | s | |
26 | - | case _: Unit => | |
27 | - | base58'2ee4oFDYriWJ9EMeR' | |
28 | - | case _ => | |
29 | - | throw("Match error") | |
30 | - | } | |
31 | - | let rand = (((((lastPlay + i.transactionId) + i.callerPublicKey) + lastBlock.generationSignature) + toBytes(lastBlock.timestamp)) + toBytes(lastBlock.height)) | |
32 | - | sha256(rand) | |
37 | + | func getRandomNumber (variants,txId,gameingFinishHeight,offset) = { | |
38 | + | let randomSeedBlock = value(blockInfoByHeight((gameingFinishHeight - 1))) | |
39 | + | let randomHash = sha256((txId + value(randomSeedBlock.vrf))) | |
40 | + | (toInt(randomHash, (offset * 8)) % variants) | |
33 | 41 | } | |
34 | 42 | ||
35 | 43 | ||
36 | - | func startLotto (i,guessStart,guessEnd) = { | |
37 | - | let waves = wavesBalance(this) | |
38 | - | let playLimit = (waves.available / 100) | |
39 | - | let payment = i.payments[0] | |
40 | - | if (!(isDefined(payment))) | |
41 | - | then throw("Should be with Payment in Waves") | |
42 | - | else if (isDefined(payment.assetId)) | |
43 | - | then throw("Payment should be in Waves") | |
44 | - | else if ((payment.amount > playLimit)) | |
45 | - | then throw(("Payment should be less than " + toString(playLimit))) | |
46 | - | else if ((0 > guessStart)) | |
47 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
48 | - | else if ((guessEnd > 99)) | |
49 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
50 | - | else if ((guessStart > guessEnd)) | |
51 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
52 | - | else if ((5 > ((guessEnd - guessStart) + 1))) | |
53 | - | then throw("guessStart and guessEnd Must be at least 5 apart") | |
54 | - | else if ((((guessEnd - guessStart) + 1) > 95)) | |
55 | - | then throw("guessStart and guessEnd Must not be at least 95 apart") | |
56 | - | else { | |
57 | - | let callerAddress = toBase58String(i.caller.bytes) | |
58 | - | let transactionId = toBase58String(i.transactionId) | |
59 | - | let randhash = randomizer(i) | |
60 | - | let rand = (toInt(randhash) % 100) | |
61 | - | let gameId = match getInteger(this, gameNumberKey) { | |
62 | - | case a: Int => | |
63 | - | a | |
64 | - | case _: Unit => | |
65 | - | 1 | |
66 | - | case _ => | |
67 | - | throw("Match error") | |
68 | - | } | |
69 | - | let gameKey = ((callerAddress + "_") + toString(gameId)) | |
70 | - | if (if (((guessEnd + 1) > rand)) | |
71 | - | then (rand > (guessStart - 1)) | |
72 | - | else false) | |
73 | - | then { | |
74 | - | let str = ((((((((((toString(WON) + "_WON_") + transactionId) + "_") + gameKey) + "_") + toString(guessStart)) + "-") + toString(guessEnd)) + "_") + toString(rand)) | |
75 | - | let payoutRate = payoutcalc(((guessEnd - guessStart) + 1)) | |
76 | - | let transferAmount = ((payment.amount * payoutRate) / 100) | |
77 | - | [IntegerEntry(lastPlayKey, rand), StringEntry(gameKey, str), IntegerEntry(gameNumberKey, (gameId + 1)), StringEntry(testKey, ((((toString(payoutRate) + "_") + toString(payment.amount)) + "_") + toString(transferAmount))), ScriptTransfer(i.caller, transferAmount, unit)] | |
78 | - | } | |
79 | - | else { | |
80 | - | let str = ((((((((((toString(LOSE) + "_LOSE_") + transactionId) + "_") + gameKey) + "_") + toString(guessStart)) + "-") + toString(guessEnd)) + "_") + toString(rand)) | |
81 | - | let asset = Issue("asd", "description", 1, 0, false, unit, lastBlock.height) | |
82 | - | let assetId = calculateAssetId(asset) | |
83 | - | [IntegerEntry(lastPlayKey, rand), StringEntry(gameKey, str), IntegerEntry(gameNumberKey, (gameId + 1)), ScriptTransfer(i.caller, 1, assetId)] | |
84 | - | } | |
85 | - | } | |
44 | + | func getRandomName (txId,gameingFinishHeight) = { | |
45 | + | let rand = getRandomNumber(2, txId, gameingFinishHeight, 0) | |
46 | + | if ((rand == 0)) | |
47 | + | then "type1" | |
48 | + | else "type2" | |
86 | 49 | } | |
87 | 50 | ||
88 | 51 | ||
89 | 52 | @Callable(i) | |
90 | - | func zero2hero (guessStart,guessEnd) = startLotto(i, guessStart, guessEnd) | |
53 | + | func startAssetGaming () = { | |
54 | + | let firstPayment = value(i.payments[0]) | |
55 | + | let gameId = tryGetInteger(gameNumberKey) | |
56 | + | [IntegerEntry(getGameStatusKey(toString(i.caller), gameId), GameStarted), StringEntry(getGameTxIdKey(toString(i.caller), gameId), toBase58String(i.transactionId)), IntegerEntry(getGameingFinishHeightKey(toString(i.caller), gameId), (height + delayForGame)), IntegerEntry(gameNumberKey, (gameId + 1))] | |
57 | + | } | |
91 | 58 | ||
92 | 59 | ||
93 | 60 | ||
94 | 61 | @Callable(i) | |
95 | - | func payoutcalct (number) = { | |
96 | - | let rate = payoutcalc(number) | |
97 | - | [StringEntry(testKey, toString(rate))] | |
62 | + | func finishAssetGaming (gameId) = { | |
63 | + | let gameingStatusKey = getGameStatusKey(toString(i.caller), gameId) | |
64 | + | let finishHeightKey = getGameingFinishHeightKey(toString(i.caller), gameId) | |
65 | + | let assetIdKey = getAssetIdKey(toString(i.caller), gameId) | |
66 | + | let gameTxIdKey = getGameTxIdKey(toString(i.caller), gameId) | |
67 | + | let gameingTxStatus = tryGetInteger(gameingStatusKey) | |
68 | + | let gameingFinishHeight = getIntegerValue(this, finishHeightKey) | |
69 | + | let gameTxId = fromBase58String(getStringValue(this, gameTxIdKey)) | |
70 | + | if ((gameingTxStatus == GameFinished)) | |
71 | + | then { | |
72 | + | let assetId = getStringValue(this, getAssetIdKey(toString(i.caller), gameId)) | |
73 | + | throw(("The asset was gamed and claimed already, here is the folowing: " + assetId)) | |
74 | + | } | |
75 | + | else if ((gameingFinishHeight > height)) | |
76 | + | then throw((((("Gaming is not finished yet " + toString((gameingFinishHeight - height))) + " blocks remaining, it will take around ") + toString((gameingFinishHeight - height))) + " minutes")) | |
77 | + | else { | |
78 | + | let randonName = getRandomName(gameTxId, gameingFinishHeight) | |
79 | + | let asset = Issue(randonName, randonName, 1, 0, false, unit, gameingFinishHeight) | |
80 | + | let assetId = calculateAssetId(asset) | |
81 | + | [IntegerEntry(gameingStatusKey, GameFinished), StringEntry(assetIdKey, toBase58String(assetId)), StringEntry(toBase58String(assetId), assetIdKey), asset, ScriptTransfer(i.caller, 1, assetId)] | |
82 | + | } | |
98 | 83 | } | |
99 | 84 | ||
100 | 85 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let gameNumberKey = "$GAME_NUMBER" | |
5 | 5 | ||
6 | - | let lastPlayKey = "$LAST_PLAY" | |
7 | - | ||
8 | 6 | let testKey = "$TEST" | |
9 | 7 | ||
10 | - | let | |
8 | + | let delayForGame = 2 | |
11 | 9 | ||
12 | - | let | |
10 | + | let GameStarted = 1 | |
13 | 11 | ||
14 | - | func payoutcalc (number) = { | |
15 | - | let house = 6 | |
16 | - | let base = 10000 | |
17 | - | let rate = ((base * (100 - 6)) / (number * 100)) | |
18 | - | rate | |
12 | + | let GameFinished = 2 | |
13 | + | ||
14 | + | func getGameStatusKey (address,gameId) = "a" | |
15 | + | ||
16 | + | ||
17 | + | func getGameTxIdKey (address,gameId) = (((address + "_") + toString(gameId)) + "_txid") | |
18 | + | ||
19 | + | ||
20 | + | func getGameingFinishHeightKey (address,gameId) = (((address + "_") + toString(gameId)) + "_fh") | |
21 | + | ||
22 | + | ||
23 | + | func getAssetIdKey (address,gameId) = (((address + "_") + toString(gameId)) + "_di") | |
24 | + | ||
25 | + | ||
26 | + | func tryGetInteger (key) = { | |
27 | + | let val = match getInteger(this, key) { | |
28 | + | case b: Int => | |
29 | + | b | |
30 | + | case _ => | |
31 | + | 0 | |
32 | + | } | |
33 | + | val | |
19 | 34 | } | |
20 | 35 | ||
21 | 36 | ||
22 | - | func randomizer (i) = { | |
23 | - | let lastPlay = match getBinary(this, lastPlayKey) { | |
24 | - | case s: ByteVector => | |
25 | - | s | |
26 | - | case _: Unit => | |
27 | - | base58'2ee4oFDYriWJ9EMeR' | |
28 | - | case _ => | |
29 | - | throw("Match error") | |
30 | - | } | |
31 | - | let rand = (((((lastPlay + i.transactionId) + i.callerPublicKey) + lastBlock.generationSignature) + toBytes(lastBlock.timestamp)) + toBytes(lastBlock.height)) | |
32 | - | sha256(rand) | |
37 | + | func getRandomNumber (variants,txId,gameingFinishHeight,offset) = { | |
38 | + | let randomSeedBlock = value(blockInfoByHeight((gameingFinishHeight - 1))) | |
39 | + | let randomHash = sha256((txId + value(randomSeedBlock.vrf))) | |
40 | + | (toInt(randomHash, (offset * 8)) % variants) | |
33 | 41 | } | |
34 | 42 | ||
35 | 43 | ||
36 | - | func startLotto (i,guessStart,guessEnd) = { | |
37 | - | let waves = wavesBalance(this) | |
38 | - | let playLimit = (waves.available / 100) | |
39 | - | let payment = i.payments[0] | |
40 | - | if (!(isDefined(payment))) | |
41 | - | then throw("Should be with Payment in Waves") | |
42 | - | else if (isDefined(payment.assetId)) | |
43 | - | then throw("Payment should be in Waves") | |
44 | - | else if ((payment.amount > playLimit)) | |
45 | - | then throw(("Payment should be less than " + toString(playLimit))) | |
46 | - | else if ((0 > guessStart)) | |
47 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
48 | - | else if ((guessEnd > 99)) | |
49 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
50 | - | else if ((guessStart > guessEnd)) | |
51 | - | then throw("guessStart and guessEnd Must be in between 0-99") | |
52 | - | else if ((5 > ((guessEnd - guessStart) + 1))) | |
53 | - | then throw("guessStart and guessEnd Must be at least 5 apart") | |
54 | - | else if ((((guessEnd - guessStart) + 1) > 95)) | |
55 | - | then throw("guessStart and guessEnd Must not be at least 95 apart") | |
56 | - | else { | |
57 | - | let callerAddress = toBase58String(i.caller.bytes) | |
58 | - | let transactionId = toBase58String(i.transactionId) | |
59 | - | let randhash = randomizer(i) | |
60 | - | let rand = (toInt(randhash) % 100) | |
61 | - | let gameId = match getInteger(this, gameNumberKey) { | |
62 | - | case a: Int => | |
63 | - | a | |
64 | - | case _: Unit => | |
65 | - | 1 | |
66 | - | case _ => | |
67 | - | throw("Match error") | |
68 | - | } | |
69 | - | let gameKey = ((callerAddress + "_") + toString(gameId)) | |
70 | - | if (if (((guessEnd + 1) > rand)) | |
71 | - | then (rand > (guessStart - 1)) | |
72 | - | else false) | |
73 | - | then { | |
74 | - | let str = ((((((((((toString(WON) + "_WON_") + transactionId) + "_") + gameKey) + "_") + toString(guessStart)) + "-") + toString(guessEnd)) + "_") + toString(rand)) | |
75 | - | let payoutRate = payoutcalc(((guessEnd - guessStart) + 1)) | |
76 | - | let transferAmount = ((payment.amount * payoutRate) / 100) | |
77 | - | [IntegerEntry(lastPlayKey, rand), StringEntry(gameKey, str), IntegerEntry(gameNumberKey, (gameId + 1)), StringEntry(testKey, ((((toString(payoutRate) + "_") + toString(payment.amount)) + "_") + toString(transferAmount))), ScriptTransfer(i.caller, transferAmount, unit)] | |
78 | - | } | |
79 | - | else { | |
80 | - | let str = ((((((((((toString(LOSE) + "_LOSE_") + transactionId) + "_") + gameKey) + "_") + toString(guessStart)) + "-") + toString(guessEnd)) + "_") + toString(rand)) | |
81 | - | let asset = Issue("asd", "description", 1, 0, false, unit, lastBlock.height) | |
82 | - | let assetId = calculateAssetId(asset) | |
83 | - | [IntegerEntry(lastPlayKey, rand), StringEntry(gameKey, str), IntegerEntry(gameNumberKey, (gameId + 1)), ScriptTransfer(i.caller, 1, assetId)] | |
84 | - | } | |
85 | - | } | |
44 | + | func getRandomName (txId,gameingFinishHeight) = { | |
45 | + | let rand = getRandomNumber(2, txId, gameingFinishHeight, 0) | |
46 | + | if ((rand == 0)) | |
47 | + | then "type1" | |
48 | + | else "type2" | |
86 | 49 | } | |
87 | 50 | ||
88 | 51 | ||
89 | 52 | @Callable(i) | |
90 | - | func zero2hero (guessStart,guessEnd) = startLotto(i, guessStart, guessEnd) | |
53 | + | func startAssetGaming () = { | |
54 | + | let firstPayment = value(i.payments[0]) | |
55 | + | let gameId = tryGetInteger(gameNumberKey) | |
56 | + | [IntegerEntry(getGameStatusKey(toString(i.caller), gameId), GameStarted), StringEntry(getGameTxIdKey(toString(i.caller), gameId), toBase58String(i.transactionId)), IntegerEntry(getGameingFinishHeightKey(toString(i.caller), gameId), (height + delayForGame)), IntegerEntry(gameNumberKey, (gameId + 1))] | |
57 | + | } | |
91 | 58 | ||
92 | 59 | ||
93 | 60 | ||
94 | 61 | @Callable(i) | |
95 | - | func payoutcalct (number) = { | |
96 | - | let rate = payoutcalc(number) | |
97 | - | [StringEntry(testKey, toString(rate))] | |
62 | + | func finishAssetGaming (gameId) = { | |
63 | + | let gameingStatusKey = getGameStatusKey(toString(i.caller), gameId) | |
64 | + | let finishHeightKey = getGameingFinishHeightKey(toString(i.caller), gameId) | |
65 | + | let assetIdKey = getAssetIdKey(toString(i.caller), gameId) | |
66 | + | let gameTxIdKey = getGameTxIdKey(toString(i.caller), gameId) | |
67 | + | let gameingTxStatus = tryGetInteger(gameingStatusKey) | |
68 | + | let gameingFinishHeight = getIntegerValue(this, finishHeightKey) | |
69 | + | let gameTxId = fromBase58String(getStringValue(this, gameTxIdKey)) | |
70 | + | if ((gameingTxStatus == GameFinished)) | |
71 | + | then { | |
72 | + | let assetId = getStringValue(this, getAssetIdKey(toString(i.caller), gameId)) | |
73 | + | throw(("The asset was gamed and claimed already, here is the folowing: " + assetId)) | |
74 | + | } | |
75 | + | else if ((gameingFinishHeight > height)) | |
76 | + | then throw((((("Gaming is not finished yet " + toString((gameingFinishHeight - height))) + " blocks remaining, it will take around ") + toString((gameingFinishHeight - height))) + " minutes")) | |
77 | + | else { | |
78 | + | let randonName = getRandomName(gameTxId, gameingFinishHeight) | |
79 | + | let asset = Issue(randonName, randonName, 1, 0, false, unit, gameingFinishHeight) | |
80 | + | let assetId = calculateAssetId(asset) | |
81 | + | [IntegerEntry(gameingStatusKey, GameFinished), StringEntry(assetIdKey, toBase58String(assetId)), StringEntry(toBase58String(assetId), assetIdKey), asset, ScriptTransfer(i.caller, 1, assetId)] | |
82 | + | } | |
98 | 83 | } | |
99 | 84 | ||
100 | 85 |
github/deemru/w8io/169f3d6 31.23 ms ◑![]()