tx · 2VeGmfsW6V4W4FadivcpX5zKRiFX85FMxhF9QQkjNpuW

3PKUxbZaSYfsR7wu2HaAgiirHYwAMupDrYW:  -0.01000000 Waves

2023.02.22 15:34 [3526360] smart account 3PKUxbZaSYfsR7wu2HaAgiirHYwAMupDrYW > SELF 0.00000000 Waves

{ "type": 13, "id": "2VeGmfsW6V4W4FadivcpX5zKRiFX85FMxhF9QQkjNpuW", "fee": 1000000, "feeAssetId": null, "timestamp": 1677069337583, "version": 2, "chainId": 87, "sender": "3PKUxbZaSYfsR7wu2HaAgiirHYwAMupDrYW", "senderPublicKey": "3zM4iabKGceAs2Q6qdZX3kAviP41X4VtGjHRAHd6oB2E", "proofs": [ "4cN2WadRrUaefPaWh2FBp9dNapiygifXT7NZpn9NgnmnJYiGLSjy2qkcogquhgnufF4q7o5Ydg8GFfuob5VWx1vR" ], "script": "base64:BgINCAISABIDCgEIEgASAAoABnVzZG5JZAEgtiYpwwT1zlORpA5LdSQvZIxRsfrfr1QpvUjSHSqyqtEACXVzZG5JZFN0cgIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAACHB1enpsZUlkASDxGv4l/vaZOPRpKsTf4RLWR7LGyg66Nwmvd20fjqLlYwALcHV6emxlSWRTdHICLEhFQjhRYXc5eHJXcFdzOHRIc2lBVFlHQldEQnRQMlM3a2NQQUxyTXU0M0FTAAVTY2FsZQCAoJSljR0BDXRyeUdldEludGVnZXIBA2tleQQHJG1hdGNoMAkAmggCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIDSW50BAFiBQckbWF0Y2gwBQFiAAABDHRyeUdldFN0cmluZwEDa2V5BAckbWF0Y2gwCQCdCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAWEFByRtYXRjaDAFAWECAAEQY2xhaW1BbGlhc1Jlc3VsdAIHYWRkcmVzcwphc3NldElkU3RyBAphZGRyZXNzU3RyCQClCAEFB2FkZHJlc3MED2N1cnJlbnRJbnRlcmVzdAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgIRZ2xvYmFsX2xhc3RDaGVja18FCmFzc2V0SWRTdHICCV9pbnRlcmVzdAQMc3Rha2VkQW1vdW50CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgUKYWRkcmVzc1N0cgIHX3N0YWtlZAQYbGFzdENoZWNrSW50ZXJlc3RJblN0YXRlCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICCQCsAgIFCmFkZHJlc3NTdHICC19sYXN0Q2hlY2tfBQphc3NldElkU3RyAglfaW50ZXJlc3QEEWxhc3RDaGVja0ludGVyZXN0AwkAAAIFGGxhc3RDaGVja0ludGVyZXN0SW5TdGF0ZQAABQVTY2FsZQUYbGFzdENoZWNrSW50ZXJlc3RJblN0YXRlBAZyZXdhcmQDCQBmAgURbGFzdENoZWNrSW50ZXJlc3QAAAkAawMJAGUCBQ9jdXJyZW50SW50ZXJlc3QFEWxhc3RDaGVja0ludGVyZXN0BQxzdGFrZWRBbW91bnQFBVNjYWxlAAAJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIFCmFkZHJlc3NTdHICC19sYXN0Q2hlY2tfBQphc3NldElkU3RyAglfaW50ZXJlc3QFD2N1cnJlbnRJbnRlcmVzdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgUKYWRkcmVzc1N0cgIBXwUKYXNzZXRJZFN0cgIIX2NsYWltZWQJAGQCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICCQCsAgIFCmFkZHJlc3NTdHICAV8FCmFzc2V0SWRTdHICCF9jbGFpbWVkBQZyZXdhcmQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwUGcmV3YXJkCQDZBAEFCmFzc2V0SWRTdHIFA25pbAELY2xhaW1SZXN1bHQBB2FkZHJlc3MJAM4IAgkBEGNsYWltQWxpYXNSZXN1bHQCBQdhZGRyZXNzBQl1c2RuSWRTdHIJARBjbGFpbUFsaWFzUmVzdWx0AgUHYWRkcmVzcwULcHV6emxlSWRTdHIBEGNoZWNrTkZUVmFsaWRpdHkBB2Fzc2V0SWQEByRtYXRjaDAJAJ0IAgkBB0FkZHJlc3MBARoBVzpRYUeHpBd53GCVoLZmyzzeJS+uMO/79gkArAICCQCsAgICBGFydF8JANgEAQUHYXNzZXRJZAIFX3R5cGUDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAF4BQckbWF0Y2gwAAUDCQAAAgkAnQgCCQEHQWRkcmVzcwEBGgFXk93E0hfnIAr99yESTvDwdmcmgwN41FxMCQCsAgIJAKwCAgIEbmZ0XwkA2AQBBQdhc3NldElkAgdfaXNzdWVyAiMzUE1raTVzSEJzUWI0S2dEa25iVXdzTDNZZ3hhQ3phWm5DSgABAAAEAWkBBXN0YWtlAAQKYWRkcmVzc1N0cgkApQgBCAUBaQZjYWxsZXIEBW5mdElkAwkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AAEJAQV2YWx1ZQEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAkAAgECEXBsZWFzZSBhdHRhY2ggTkZUBAphc3NldElkU3RyCQDYBAEFBnVzZG5JZAQPY3VycmVudEludGVyZXN0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAhFnbG9iYWxfbGFzdENoZWNrXwUKYXNzZXRJZFN0cgIJX2ludGVyZXN0BBF0b3RhbFN0YWtlZEFtb3VudAkBDXRyeUdldEludGVnZXIBAg1nbG9iYWxfc3Rha2VkBAphc3NldFBvd2VyCQBrAwCQTgkBEGNoZWNrTkZUVmFsaWRpdHkBBQVuZnRJZAAFBAdORlROYW1lAwkAAAIFCmFzc2V0UG93ZXIAkE4CCUVhZ2xlIE5GVAIIQW5pYSBORlQDCQAAAgUKYXNzZXRQb3dlcgAACQACAQIWbm90IHZhbGlkIE5GVCBhdHRhY2hlZAkAzggCCQELY2xhaW1SZXN1bHQBCAUBaQZjYWxsZXIJAMwIAgkBDEludGVnZXJFbnRyeQICDWdsb2JhbF9zdGFrZWQJAGQCBRF0b3RhbFN0YWtlZEFtb3VudAUKYXNzZXRQb3dlcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQphZGRyZXNzU3RyAgdfc3Rha2VkCQBkAgkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFkZHJlc3NTdHICB19zdGFrZWQFCmFzc2V0UG93ZXIJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQDYBAEFBW5mdElkAgZfb3duZXIFCmFkZHJlc3NTdHIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgICCGFkZHJlc3NfCQClCAEIBQFpBmNhbGxlcgIFX25mdF8JANgEAQUFbmZ0SWQIBQlsYXN0QmxvY2sJdGltZXN0YW1wCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkA2AQBBQVuZnRJZAIFX25hbWUFB05GVE5hbWUFA25pbAFpAQd1blN0YWtlAQhuZnRJZFN0cgQKYXNzZXRQb3dlcgkAawMAkE4JARBjaGVja05GVFZhbGlkaXR5AQkA2QQBBQhuZnRJZFN0cgAFBAphZGRyZXNzU3RyCQClCAEIBQFpBmNhbGxlcgQMc3Rha2VkQW1vdW50CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgUKYWRkcmVzc1N0cgIHX3N0YWtlZAQIbmZ0T3duZXIJAQx0cnlHZXRTdHJpbmcBCQCsAgIFCG5mdElkU3RyAgZfb3duZXIDCQECIT0CBQphZGRyZXNzU3RyBQhuZnRPd25lcgkAAgECHHlvdSBkb24ndCBoYXZlIE5GVCBhdmFpbGFibGUJAM4IAgkBC2NsYWltUmVzdWx0AQgFAWkGY2FsbGVyCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCmFkZHJlc3NTdHICB19zdGFrZWQJAGUCBQxzdGFrZWRBbW91bnQFCmFzc2V0UG93ZXIJAMwIAgkBDEludGVnZXJFbnRyeQICDWdsb2JhbF9zdGFrZWQJAGUCCQENdHJ5R2V0SW50ZWdlcgECDWdsb2JhbF9zdGFrZWQFCmFzc2V0UG93ZXIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyAAEJANkEAQUIbmZ0SWRTdHIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICBQhuZnRJZFN0cgIGX293bmVyCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgICCGFkZHJlc3NfCQClCAEIBQFpBmNhbGxlcgIFX25mdF8FCG5mdElkU3RyBQNuaWwBaQELY2xhaW1SZXdhcmQACQELY2xhaW1SZXN1bHQBCAUBaQZjYWxsZXIBaQELdG9wVXBSZXdhcmQABAhwbXRBc3NldAkBBXZhbHVlAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBAlwbXRBbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BAZhbW91bnQDCQAAAgUIcG10QXNzZXQFBnVzZG5JZAQCYjAJAPAHAgUEdGhpcwUIcHV6emxlSWQDCQAAAgUCYjAFAmIwBANpbnYJAPwHBAkBB0FkZHJlc3MBARoBV2a1ojtcrnKV5nzK9Tr0/3WkqnTD33vrHwIIZXhjaGFuZ2UJAMwIAgABBQNuaWwIBQFpCHBheW1lbnRzAwkAAAIFA2ludgUDaW52BAJiMQkA8AcCBQR0aGlzBQhwdXp6bGVJZAMJAAACBQJiMQUCYjEJAGUCBQJiMQUCYjAJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUIcG10QXNzZXQFCHB1enpsZUlkBQlwbXRBbW91bnQJAAIBAhpub3QgY29ycmVjdCBhc3NldCBhdHRhY2hlZAMJAAACBQZhbW91bnQFBmFtb3VudAQPY3VycmVudEludGVyZXN0CQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAhFnbG9iYWxfbGFzdENoZWNrXwULcHV6emxlSWRTdHICCV9pbnRlcmVzdAQRdG90YWxTdGFrZWRBbW91bnQJAQ10cnlHZXRJbnRlZ2VyAQINZ2xvYmFsX3N0YWtlZAQNaW50ZXJlc3REZWx0YQMJAGYCBRF0b3RhbFN0YWtlZEFtb3VudAAACQBrAwUGYW1vdW50BQVTY2FsZQURdG90YWxTdGFrZWRBbW91bnQAAAkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIHZ2xvYmFsXwULcHV6emxlSWRTdHICCV9lYXJuaW5ncwkAZAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgICB2dsb2JhbF8FC3B1enpsZUlkU3RyAglfZWFybmluZ3MFBmFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICEWdsb2JhbF9sYXN0Q2hlY2tfBQtwdXp6bGVJZFN0cgIJX2ludGVyZXN0CQBkAgUPY3VycmVudEludGVyZXN0BQ1pbnRlcmVzdERlbHRhBQNuaWwFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXljGHwl", "height": 3526360, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 7668XWWnCa8Ai6kvdvd7we67TSeqHgXeNkFWdVjjEyGB Next: none Diff:
OldNewDifferences
4242 }
4343
4444
45-func claimResult (address) = claimAliasResult(address, usdnIdStr)
45+func claimResult (address) = (claimAliasResult(address, usdnIdStr) ++ claimAliasResult(address, puzzleIdStr))
4646
4747
4848 func checkNFTValidity (assetId) = match getString(Address(base58'3P7FFQkgALLZDJpCf3smY517wjgPMswGoRP'), (("art_" + toBase58String(assetId)) + "_type")) {
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let usdnId = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p'
55
66 let usdnIdStr = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"
77
88 let puzzleId = base58'HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS'
99
1010 let puzzleIdStr = "HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS"
1111
1212 let Scale = 1000000000000
1313
1414 func tryGetInteger (key) = match getInteger(this, key) {
1515 case b: Int =>
1616 b
1717 case _ =>
1818 0
1919 }
2020
2121
2222 func tryGetString (key) = match getString(this, key) {
2323 case a: String =>
2424 a
2525 case _ =>
2626 ""
2727 }
2828
2929
3030 func claimAliasResult (address,assetIdStr) = {
3131 let addressStr = toString(address)
3232 let currentInterest = tryGetInteger((("global_lastCheck_" + assetIdStr) + "_interest"))
3333 let stakedAmount = tryGetInteger((addressStr + "_staked"))
3434 let lastCheckInterestInState = tryGetInteger((((addressStr + "_lastCheck_") + assetIdStr) + "_interest"))
3535 let lastCheckInterest = if ((lastCheckInterestInState == 0))
3636 then Scale
3737 else lastCheckInterestInState
3838 let reward = if ((lastCheckInterest > 0))
3939 then fraction((currentInterest - lastCheckInterest), stakedAmount, Scale)
4040 else 0
4141 [IntegerEntry((((addressStr + "_lastCheck_") + assetIdStr) + "_interest"), currentInterest), IntegerEntry((((addressStr + "_") + assetIdStr) + "_claimed"), (tryGetInteger((((addressStr + "_") + assetIdStr) + "_claimed")) + reward)), ScriptTransfer(address, reward, fromBase58String(assetIdStr))]
4242 }
4343
4444
45-func claimResult (address) = claimAliasResult(address, usdnIdStr)
45+func claimResult (address) = (claimAliasResult(address, usdnIdStr) ++ claimAliasResult(address, puzzleIdStr))
4646
4747
4848 func checkNFTValidity (assetId) = match getString(Address(base58'3P7FFQkgALLZDJpCf3smY517wjgPMswGoRP'), (("art_" + toBase58String(assetId)) + "_type")) {
4949 case x: String =>
5050 5
5151 case _ =>
5252 if ((getString(Address(base58'3PFQjjDMiZKQZdu5JqTHD7HwgSXyp9Rw9By'), (("nft_" + toBase58String(assetId)) + "_issuer")) == "3PMki5sHBsQb4KgDknbUwsL3YgxaCzaZnCJ"))
5353 then 1
5454 else 0
5555 }
5656
5757
5858 @Callable(i)
5959 func stake () = {
6060 let addressStr = toString(i.caller)
6161 let nftId = if ((i.payments[0].amount == 1))
6262 then value(i.payments[0].assetId)
6363 else throw("please attach NFT")
6464 let assetIdStr = toBase58String(usdnId)
6565 let currentInterest = tryGetInteger((("global_lastCheck_" + assetIdStr) + "_interest"))
6666 let totalStakedAmount = tryGetInteger("global_staked")
6767 let assetPower = fraction(10000, checkNFTValidity(nftId), 5)
6868 let NFTName = if ((assetPower == 10000))
6969 then "Eagle NFT"
7070 else "Ania NFT"
7171 if ((assetPower == 0))
7272 then throw("not valid NFT attached")
7373 else (claimResult(i.caller) ++ [IntegerEntry("global_staked", (totalStakedAmount + assetPower)), IntegerEntry((addressStr + "_staked"), (tryGetInteger((addressStr + "_staked")) + assetPower)), StringEntry((toBase58String(nftId) + "_owner"), addressStr), IntegerEntry(((("address_" + toString(i.caller)) + "_nft_") + toBase58String(nftId)), lastBlock.timestamp), StringEntry((toBase58String(nftId) + "_name"), NFTName)])
7474 }
7575
7676
7777
7878 @Callable(i)
7979 func unStake (nftIdStr) = {
8080 let assetPower = fraction(10000, checkNFTValidity(fromBase58String(nftIdStr)), 5)
8181 let addressStr = toString(i.caller)
8282 let stakedAmount = tryGetInteger((addressStr + "_staked"))
8383 let nftOwner = tryGetString((nftIdStr + "_owner"))
8484 if ((addressStr != nftOwner))
8585 then throw("you don't have NFT available")
8686 else (claimResult(i.caller) ++ [IntegerEntry((addressStr + "_staked"), (stakedAmount - assetPower)), IntegerEntry("global_staked", (tryGetInteger("global_staked") - assetPower)), ScriptTransfer(i.caller, 1, fromBase58String(nftIdStr)), DeleteEntry((nftIdStr + "_owner")), DeleteEntry(((("address_" + toString(i.caller)) + "_nft_") + nftIdStr))])
8787 }
8888
8989
9090
9191 @Callable(i)
9292 func claimReward () = claimResult(i.caller)
9393
9494
9595
9696 @Callable(i)
9797 func topUpReward () = {
9898 let pmtAsset = value(i.payments[0].assetId)
9999 let pmtAmount = i.payments[0].amount
100100 let amount = if ((pmtAsset == usdnId))
101101 then {
102102 let b0 = assetBalance(this, puzzleId)
103103 if ((b0 == b0))
104104 then {
105105 let inv = invoke(Address(base58'3PBHyEwmERR1CEkrTNbPj2bgyisTfPRqfee'), "exchange", [1], i.payments)
106106 if ((inv == inv))
107107 then {
108108 let b1 = assetBalance(this, puzzleId)
109109 if ((b1 == b1))
110110 then (b1 - b0)
111111 else throw("Strict value is not equal to itself.")
112112 }
113113 else throw("Strict value is not equal to itself.")
114114 }
115115 else throw("Strict value is not equal to itself.")
116116 }
117117 else if ((pmtAsset == puzzleId))
118118 then pmtAmount
119119 else throw("not correct asset attached")
120120 if ((amount == amount))
121121 then {
122122 let currentInterest = tryGetInteger((("global_lastCheck_" + puzzleIdStr) + "_interest"))
123123 let totalStakedAmount = tryGetInteger("global_staked")
124124 let interestDelta = if ((totalStakedAmount > 0))
125125 then fraction(amount, Scale, totalStakedAmount)
126126 else 0
127127 $Tuple2([IntegerEntry((("global_" + puzzleIdStr) + "_earnings"), (tryGetInteger((("global_" + puzzleIdStr) + "_earnings")) + amount)), IntegerEntry((("global_lastCheck_" + puzzleIdStr) + "_interest"), (currentInterest + interestDelta))], amount)
128128 }
129129 else throw("Strict value is not equal to itself.")
130130 }
131131
132132
133133 @Verifier(tx)
134134 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
135135

github/deemru/w8io/6500d08 
29.70 ms