tx · AMjDaf6Z1DJnhT8P8zZNMKCu59BhbQfWeXeFYnpiVFnz

3N4Kzbxu521DHPxcgrmZ4XUqN2kF6TqLTzs:  -0.01000000 Waves

2023.08.29 13:25 [2731871] smart account 3N4Kzbxu521DHPxcgrmZ4XUqN2kF6TqLTzs > SELF 0.00000000 Waves

{ "type": 13, "id": "AMjDaf6Z1DJnhT8P8zZNMKCu59BhbQfWeXeFYnpiVFnz", "fee": 1000000, "feeAssetId": null, "timestamp": 1693304808979, "version": 2, "chainId": 84, "sender": "3N4Kzbxu521DHPxcgrmZ4XUqN2kF6TqLTzs", "senderPublicKey": "8yQuxvQ2qLzXJrgbKZHbsfnNNjuU5wfHheyVujdALGsF", "proofs": [ "kiodSD6jsy6nUtLen999qcGzfV5LuAQv1zf55Y6pBA4BmFRPXZwo4dEJNUYYKGQ52hEA2vTAPY6KcpqLig1AfKM" ], "script": "base64:BgIZCAISABIAEgQKAggBEgUKAwgBCBIECgIIAQ0ADmxvdHRlcnlBc3NldElECQDZBAECLDNMejIzbVNVdlQxRXN3Y0JuMnNVUllKRzJhdDhyRzVhRnVVclRBd2FQTTZRAAp0aWNrZXRTaXplAAEBEGdldEludGVnZXJPckVsc2UCA2tleQN2YWwJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUDa2V5BQN2YWwBD2dldFN0cmluZ09yRWxzZQIDa2V5A3ZhbAkBC3ZhbHVlT3JFbHNlAgkAoggBBQNrZXkFA3ZhbAECbWsBAXgJALkJAgUBeAIBXwERa2V5QWRyVG90YWxTdGFrZWQBA2FkcgkBAm1rAQkAzAgCAgNhZHIJAMwIAgUDYWRyCQDMCAICC3RvdGFsU3Rha2VkBQNuaWwBFWtleUxvdHRlcnlUb3RhbFN0YWtlZAELbG90dGVyeU5hbWUJAQJtawEJAMwIAgIHbG90dGVyeQkAzAgCBQtsb3R0ZXJ5TmFtZQkAzAgCAgt0b3RhbFN0YWtlZAUDbmlsARhrZXlBZHJMb3R0ZXJ5VG90YWxTdGFrZWQCC2xvdHRlcnlOYW1lA2FkcgkBAm1rAQkAzAgCAgdsb3R0ZXJ5CQDMCAIFC2xvdHRlcnlOYW1lCQDMCAICA2FkcgkAzAgCBQNhZHIJAMwIAgILdG90YWxTdGFrZWQFA25pbAEVa2V5TG90dGVyeUZpbmFsSGVpZ2h0AQtsb3R0ZXJ5TmFtZQkBAm1rAQkAzAgCAgdsb3R0ZXJ5CQDMCAIFC2xvdHRlcnlOYW1lCQDMCAICC2ZpbmFsSGVpZ2h0BQNuaWwBFGtleUxvdHRlcnlQcml6ZVZhbHVlAgtsb3R0ZXJ5TmFtZQdwcml6ZUlECQECbWsBCQDMCAICB2xvdHRlcnkJAMwIAgULbG90dGVyeU5hbWUJAMwIAgIFcHJpemUJAMwIAgkApAMBBQdwcml6ZUlECQDMCAICBXZhbHVlBQNuaWwBFWtleUxvdHRlcnlQcml6ZUNob2ljZQILbG90dGVyeU5hbWUHcHJpemVJRAkBAm1rAQkAzAgCAgdsb3R0ZXJ5CQDMCAIFC2xvdHRlcnlOYW1lCQDMCAICBXByaXplCQDMCAIJAKQDAQUHcHJpemVJRAkAzAgCAgZjaG9pY2UFA25pbAASX2FjdGl2ZUxvdHRlcnlOYW1lCQECbWsBCQDMCAICBXBhcmFtCQDMCAICEWFjdGl2ZUxvdHRlcnlOYW1lBQNuaWwBEWFjdGl2ZUxvdHRlcnlOYW1lAAQLbG90dGVyeU5hbWUJAQ9nZXRTdHJpbmdPckVsc2UCBRJfYWN0aXZlTG90dGVyeU5hbWUCAAMJAAACBQtsb3R0ZXJ5TmFtZQIAAgAEEmxvdHRlcnlGaW5hbEhlaWdodAkBEUBleHRyTmF0aXZlKDEwNTUpAQkBFWtleUxvdHRlcnlGaW5hbEhlaWdodAEFC2xvdHRlcnlOYW1lAwkAZwIJAGUCBQZoZWlnaHQAAQUSbG90dGVyeUZpbmFsSGVpZ2h0AgAFC2xvdHRlcnlOYW1lBQFpAQVzdGFrZQAEC2xvdHRlcnlOYW1lCQERYWN0aXZlTG90dGVyeU5hbWUAAwkAAAIFC2xvdHRlcnlOYW1lAgAJAAIBAhJMb3R0ZXJ5IG5vdCBhY3RpdmUDCQAAAgkAkAMBCAUBaQhwYXltZW50cwAACQACAQIQTm8gcGF5bWVudCBhZGRlZAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECF1RvbyBtYW55IHBheW1lbnRzIGFkZGVkAwkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQ5sb3R0ZXJ5QXNzZXRJRAkAAgECFVdyb25nIHBheW1lbnQgYXNzZXRJZAQGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQMdGlja2V0QW1vdW50CQBpAgUGYW1vdW50BQp0aWNrZXRTaXplAwkAAAIFDHRpY2tldEFtb3VudAAACQACAQIlTm90IGVub3VnaCB0byBidXkgYXQgbGVhc3Qgb25lIHRpY2tldAQNY2FsbGVyQWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEE19sb3R0ZXJ5VG90YWxTdGFrZWQJARVrZXlMb3R0ZXJ5VG90YWxTdGFrZWQBBQtsb3R0ZXJ5TmFtZQQSbG90dGVyeVRvdGFsU3Rha2VkCQERQGV4dHJOYXRpdmUoMTA1NSkBBRNfbG90dGVyeVRvdGFsU3Rha2VkBAZfb3duZXIJAQJtawEJAMwIAgIFb3duZXIJAMwIAgULbG90dGVyeU5hbWUJAMwIAgkApAMBBRJsb3R0ZXJ5VG90YWxTdGFrZWQJAMwIAgkApAMBCQBlAgkAZAIFEmxvdHRlcnlUb3RhbFN0YWtlZAUMdGlja2V0QW1vdW50AAEFA25pbAQPX2FkclRvdGFsU3Rha2VkCQERa2V5QWRyVG90YWxTdGFrZWQBBQ1jYWxsZXJBZGRyZXNzBA5hZHJUb3RhbFN0YWtlZAkBEGdldEludGVnZXJPckVsc2UCBQ9fYWRyVG90YWxTdGFrZWQAAAQWX2FkckxvdHRlcnlUb3RhbFN0YWtlZAkBGGtleUFkckxvdHRlcnlUb3RhbFN0YWtlZAIFC2xvdHRlcnlOYW1lBQ1jYWxsZXJBZGRyZXNzBBVhZHJMb3R0ZXJ5VG90YWxTdGFrZWQJARBnZXRJbnRlZ2VyT3JFbHNlAgUWX2FkckxvdHRlcnlUb3RhbFN0YWtlZAAABAZjaGFuZ2UJAGUCBQZhbW91bnQJAGgCBQx0aWNrZXRBbW91bnQFCnRpY2tldFNpemUJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQZjaGFuZ2UFDmxvdHRlcnlBc3NldElECQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNfbG90dGVyeVRvdGFsU3Rha2VkCQBkAgUSbG90dGVyeVRvdGFsU3Rha2VkBQx0aWNrZXRBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgUGX293bmVyBQ1jYWxsZXJBZGRyZXNzCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9fYWRyVG90YWxTdGFrZWQJAGQCBQ5hZHJUb3RhbFN0YWtlZAUMdGlja2V0QW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCBRZfYWRyTG90dGVyeVRvdGFsU3Rha2VkCQBkAgUVYWRyTG90dGVyeVRvdGFsU3Rha2VkBQx0aWNrZXRBbW91bnQFA25pbAFpAQVjbGFpbQADCQBmAgkAkAMBCAUBaQhwYXltZW50cwAACQACAQISTm8gcGF5bWVudHMgbmVlZGVkBA1jYWxsZXJBZGRyZXNzCQClCAEIBQFpBmNhbGxlcgQLbG90dGVyeU5hbWUJARFhY3RpdmVMb3R0ZXJ5TmFtZQAEFXN0YWtlZEluQWN0aXZlTG90dGVyeQMJAAACBQtsb3R0ZXJ5TmFtZQIAAAAJARBnZXRJbnRlZ2VyT3JFbHNlAgkBGGtleUFkckxvdHRlcnlUb3RhbFN0YWtlZAIFC2xvdHRlcnlOYW1lBQ1jYWxsZXJBZGRyZXNzAAAED19hZHJUb3RhbFN0YWtlZAkBEWtleUFkclRvdGFsU3Rha2VkAQUNY2FsbGVyQWRkcmVzcwQOYWRyVG90YWxTdGFrZWQJARBnZXRJbnRlZ2VyT3JFbHNlAgUPX2FkclRvdGFsU3Rha2VkAAAECWF2YWlsYWJsZQkAZQIFDmFkclRvdGFsU3Rha2VkBRVzdGFrZWRJbkFjdGl2ZUxvdHRlcnkDCQBnAgAABQlhdmFpbGFibGUJAAIBAh1ObyBhc3NldHMgYXZhaWxhYmxlIGZvciBjbGFpbQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFCWF2YWlsYWJsZQUObG90dGVyeUFzc2V0SUQJAMwIAgkBDEludGVnZXJFbnRyeQIFD19hZHJUb3RhbFN0YWtlZAkAZQIFDmFkclRvdGFsU3Rha2VkBQlhdmFpbGFibGUFA25pbAFpAQxzdGFydExvdHRlcnkCC2xvdHRlcnlOYW1lEmxvdHRlcnlGaW5hbEhlaWdodAMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECCkFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgUSX2FjdGl2ZUxvdHRlcnlOYW1lBQtsb3R0ZXJ5TmFtZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFWtleUxvdHRlcnlGaW5hbEhlaWdodAEFC2xvdHRlcnlOYW1lBRJsb3R0ZXJ5RmluYWxIZWlnaHQJAMwIAgkBDEludGVnZXJFbnRyeQIJARVrZXlMb3R0ZXJ5VG90YWxTdGFrZWQBBQtsb3R0ZXJ5TmFtZQAABQNuaWwBaQEMZGVjbGFyZVByaXplAwtsb3R0ZXJ5TmFtZQdwcml6ZUlkCnByaXplVmFsdWUDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgpBZG1pbiBvbmx5CQDMCAIJAQtTdHJpbmdFbnRyeQIJARRrZXlMb3R0ZXJ5UHJpemVWYWx1ZQIFC2xvdHRlcnlOYW1lBQdwcml6ZUlkBQpwcml6ZVZhbHVlBQNuaWwBaQEUZmluYWxhaXplUHJpemVDaG9pY2UCC2xvdHRlcnlOYW1lB3ByaXplSWQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgpBZG1pbiBvbmx5BBJsb3R0ZXJ5RmluYWxIZWlnaHQJARFAZXh0ck5hdGl2ZSgxMDU1KQEJARVrZXlMb3R0ZXJ5RmluYWxIZWlnaHQBBQtsb3R0ZXJ5TmFtZQMJAGYCBRJsb3R0ZXJ5RmluYWxIZWlnaHQFBmhlaWdodAkAAgECF0xvdHRlcnkgaXMgbm90IG92ZXIgeWV0BBJsb3R0ZXJ5VG90YWxTdGFrZWQJARFAZXh0ck5hdGl2ZSgxMDU1KQEJARVrZXlMb3R0ZXJ5VG90YWxTdGFrZWQBBQtsb3R0ZXJ5TmFtZQMJAAACBRJsb3R0ZXJ5VG90YWxTdGFrZWQAAAkAAgECGk5vIG9uZSBlbnRlcmVkIHRoZSBsb3R0ZXJ5BBFsb3R0ZXJ5UHJpemVWYWx1ZQkBD2dldFN0cmluZ09yRWxzZQIJARRrZXlMb3R0ZXJ5UHJpemVWYWx1ZQIFC2xvdHRlcnlOYW1lBQdwcml6ZUlkAgADCQAAAgURbG90dGVyeVByaXplVmFsdWUCAAkAAgECFHByaXplIGRvZXMgbm90IGV4aXN0BApmaW5hbEJsb2NrCQEFdmFsdWUBCQDtBwEFEmxvdHRlcnlGaW5hbEhlaWdodAQKcmFuZG9tSGFzaAkA9wMBCQDLAQIJAMsBAgkAmgMBBQdwcml6ZUlkCQEFdmFsdWUBCAUKZmluYWxCbG9jawN2cmYJAJsDAQIMZG9kbGxsb3R0ZXJ5BAZjaG9pY2UJAGoCCQCyCQIFCnJhbmRvbUhhc2gAAAUSbG90dGVyeVRvdGFsU3Rha2VkCQDMCAIJAQtTdHJpbmdFbnRyeQICCGxhc3RIYXNoCQCmAwEJAJ4DAQUKcmFuZG9tSGFzaAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBFWtleUxvdHRlcnlQcml6ZUNob2ljZQIFC2xvdHRlcnlOYW1lBQdwcml6ZUlkBQZjaG9pY2UFA25pbAECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkqCQNj", "height": 2731871, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 51BgW4SmYs5vK97PoAV7Kwb2nQzRQbx3ZyWj1h5YjvcR Next: 5Cwf4Eeh5u7CAf2AdV9QixJpAb1tXcAwxsh9nCd5Ysnp Diff:
OldNewDifferences
131131 else {
132132 let finalBlock = value(blockInfoByHeight(lotteryFinalHeight))
133133 let randomHash = sha256(((toBytes(prizeId) + value(finalBlock.vrf)) + toBytes("dodlllottery")))
134- let rawChoice = toInt((toBigInt(randomHash) % toBigInt(lotteryTotalStaked)))
135- let choice = if ((0 > rawChoice))
136- then -(rawChoice)
137- else rawChoice
134+ let choice = (toInt(randomHash, 0) % lotteryTotalStaked)
138135 [StringEntry("lastHash", toString(toBigInt(randomHash))), IntegerEntry(keyLotteryPrizeChoice(lotteryName, prizeId), choice)]
139136 }
140137 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let lotteryAssetID = fromBase58String("3Lz23mSUvT1EswcBn2sURYJG2at8rG5aFuUrTAwaPM6Q")
55
66 let ticketSize = 1
77
88 func getIntegerOrElse (key,val) = valueOrElse(getInteger(key), val)
99
1010
1111 func getStringOrElse (key,val) = valueOrElse(getString(key), val)
1212
1313
1414 func mk (x) = makeString(x, "_")
1515
1616
1717 func keyAdrTotalStaked (adr) = mk(["adr", adr, "totalStaked"])
1818
1919
2020 func keyLotteryTotalStaked (lotteryName) = mk(["lottery", lotteryName, "totalStaked"])
2121
2222
2323 func keyAdrLotteryTotalStaked (lotteryName,adr) = mk(["lottery", lotteryName, "adr", adr, "totalStaked"])
2424
2525
2626 func keyLotteryFinalHeight (lotteryName) = mk(["lottery", lotteryName, "finalHeight"])
2727
2828
2929 func keyLotteryPrizeValue (lotteryName,prizeID) = mk(["lottery", lotteryName, "prize", toString(prizeID), "value"])
3030
3131
3232 func keyLotteryPrizeChoice (lotteryName,prizeID) = mk(["lottery", lotteryName, "prize", toString(prizeID), "choice"])
3333
3434
3535 let _activeLotteryName = mk(["param", "activeLotteryName"])
3636
3737 func activeLotteryName () = {
3838 let lotteryName = getStringOrElse(_activeLotteryName, "")
3939 if ((lotteryName == ""))
4040 then ""
4141 else {
4242 let lotteryFinalHeight = getIntegerValue(keyLotteryFinalHeight(lotteryName))
4343 if (((height - 1) >= lotteryFinalHeight))
4444 then ""
4545 else lotteryName
4646 }
4747 }
4848
4949
5050 @Callable(i)
5151 func stake () = {
5252 let lotteryName = activeLotteryName()
5353 if ((lotteryName == ""))
5454 then throw("Lottery not active")
5555 else if ((size(i.payments) == 0))
5656 then throw("No payment added")
5757 else if ((size(i.payments) != 1))
5858 then throw("Too many payments added")
5959 else if ((i.payments[0].assetId != lotteryAssetID))
6060 then throw("Wrong payment assetId")
6161 else {
6262 let amount = i.payments[0].amount
6363 let ticketAmount = (amount / ticketSize)
6464 if ((ticketAmount == 0))
6565 then throw("Not enough to buy at least one ticket")
6666 else {
6767 let callerAddress = toString(i.caller)
6868 let _lotteryTotalStaked = keyLotteryTotalStaked(lotteryName)
6969 let lotteryTotalStaked = getIntegerValue(_lotteryTotalStaked)
7070 let _owner = mk(["owner", lotteryName, toString(lotteryTotalStaked), toString(((lotteryTotalStaked + ticketAmount) - 1))])
7171 let _adrTotalStaked = keyAdrTotalStaked(callerAddress)
7272 let adrTotalStaked = getIntegerOrElse(_adrTotalStaked, 0)
7373 let _adrLotteryTotalStaked = keyAdrLotteryTotalStaked(lotteryName, callerAddress)
7474 let adrLotteryTotalStaked = getIntegerOrElse(_adrLotteryTotalStaked, 0)
7575 let change = (amount - (ticketAmount * ticketSize))
7676 [ScriptTransfer(i.caller, change, lotteryAssetID), IntegerEntry(_lotteryTotalStaked, (lotteryTotalStaked + ticketAmount)), StringEntry(_owner, callerAddress), IntegerEntry(_adrTotalStaked, (adrTotalStaked + ticketAmount)), IntegerEntry(_adrLotteryTotalStaked, (adrLotteryTotalStaked + ticketAmount))]
7777 }
7878 }
7979 }
8080
8181
8282
8383 @Callable(i)
8484 func claim () = if ((size(i.payments) > 0))
8585 then throw("No payments needed")
8686 else {
8787 let callerAddress = toString(i.caller)
8888 let lotteryName = activeLotteryName()
8989 let stakedInActiveLottery = if ((lotteryName == ""))
9090 then 0
9191 else getIntegerOrElse(keyAdrLotteryTotalStaked(lotteryName, callerAddress), 0)
9292 let _adrTotalStaked = keyAdrTotalStaked(callerAddress)
9393 let adrTotalStaked = getIntegerOrElse(_adrTotalStaked, 0)
9494 let available = (adrTotalStaked - stakedInActiveLottery)
9595 if ((0 >= available))
9696 then throw("No assets available for claim")
9797 else [ScriptTransfer(i.caller, available, lotteryAssetID), IntegerEntry(_adrTotalStaked, (adrTotalStaked - available))]
9898 }
9999
100100
101101
102102 @Callable(i)
103103 func startLottery (lotteryName,lotteryFinalHeight) = if ((i.caller != this))
104104 then throw("Admin only")
105105 else [StringEntry(_activeLotteryName, lotteryName), IntegerEntry(keyLotteryFinalHeight(lotteryName), lotteryFinalHeight), IntegerEntry(keyLotteryTotalStaked(lotteryName), 0)]
106106
107107
108108
109109 @Callable(i)
110110 func declarePrize (lotteryName,prizeId,prizeValue) = if ((i.caller != this))
111111 then throw("Admin only")
112112 else [StringEntry(keyLotteryPrizeValue(lotteryName, prizeId), prizeValue)]
113113
114114
115115
116116 @Callable(i)
117117 func finalaizePrizeChoice (lotteryName,prizeId) = if ((i.caller != this))
118118 then throw("Admin only")
119119 else {
120120 let lotteryFinalHeight = getIntegerValue(keyLotteryFinalHeight(lotteryName))
121121 if ((lotteryFinalHeight > height))
122122 then throw("Lottery is not over yet")
123123 else {
124124 let lotteryTotalStaked = getIntegerValue(keyLotteryTotalStaked(lotteryName))
125125 if ((lotteryTotalStaked == 0))
126126 then throw("No one entered the lottery")
127127 else {
128128 let lotteryPrizeValue = getStringOrElse(keyLotteryPrizeValue(lotteryName, prizeId), "")
129129 if ((lotteryPrizeValue == ""))
130130 then throw("prize does not exist")
131131 else {
132132 let finalBlock = value(blockInfoByHeight(lotteryFinalHeight))
133133 let randomHash = sha256(((toBytes(prizeId) + value(finalBlock.vrf)) + toBytes("dodlllottery")))
134- let rawChoice = toInt((toBigInt(randomHash) % toBigInt(lotteryTotalStaked)))
135- let choice = if ((0 > rawChoice))
136- then -(rawChoice)
137- else rawChoice
134+ let choice = (toInt(randomHash, 0) % lotteryTotalStaked)
138135 [StringEntry("lastHash", toString(toBigInt(randomHash))), IntegerEntry(keyLotteryPrizeChoice(lotteryName, prizeId), choice)]
139136 }
140137 }
141138 }
142139 }
143140
144141
145142 @Verifier(tx)
146143 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
147144

github/deemru/w8io/169f3d6 
45.24 ms