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:
Old | New | Differences | |
---|---|---|---|
42 | 42 | } | |
43 | 43 | ||
44 | 44 | ||
45 | - | func claimResult (address) = claimAliasResult(address, usdnIdStr) | |
45 | + | func claimResult (address) = (claimAliasResult(address, usdnIdStr) ++ claimAliasResult(address, puzzleIdStr)) | |
46 | 46 | ||
47 | 47 | ||
48 | 48 | func checkNFTValidity (assetId) = match getString(Address(base58'3P7FFQkgALLZDJpCf3smY517wjgPMswGoRP'), (("art_" + toBase58String(assetId)) + "_type")) { |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let usdnId = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p' | |
5 | 5 | ||
6 | 6 | let usdnIdStr = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" | |
7 | 7 | ||
8 | 8 | let puzzleId = base58'HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS' | |
9 | 9 | ||
10 | 10 | let puzzleIdStr = "HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS" | |
11 | 11 | ||
12 | 12 | let Scale = 1000000000000 | |
13 | 13 | ||
14 | 14 | func tryGetInteger (key) = match getInteger(this, key) { | |
15 | 15 | case b: Int => | |
16 | 16 | b | |
17 | 17 | case _ => | |
18 | 18 | 0 | |
19 | 19 | } | |
20 | 20 | ||
21 | 21 | ||
22 | 22 | func tryGetString (key) = match getString(this, key) { | |
23 | 23 | case a: String => | |
24 | 24 | a | |
25 | 25 | case _ => | |
26 | 26 | "" | |
27 | 27 | } | |
28 | 28 | ||
29 | 29 | ||
30 | 30 | func claimAliasResult (address,assetIdStr) = { | |
31 | 31 | let addressStr = toString(address) | |
32 | 32 | let currentInterest = tryGetInteger((("global_lastCheck_" + assetIdStr) + "_interest")) | |
33 | 33 | let stakedAmount = tryGetInteger((addressStr + "_staked")) | |
34 | 34 | let lastCheckInterestInState = tryGetInteger((((addressStr + "_lastCheck_") + assetIdStr) + "_interest")) | |
35 | 35 | let lastCheckInterest = if ((lastCheckInterestInState == 0)) | |
36 | 36 | then Scale | |
37 | 37 | else lastCheckInterestInState | |
38 | 38 | let reward = if ((lastCheckInterest > 0)) | |
39 | 39 | then fraction((currentInterest - lastCheckInterest), stakedAmount, Scale) | |
40 | 40 | else 0 | |
41 | 41 | [IntegerEntry((((addressStr + "_lastCheck_") + assetIdStr) + "_interest"), currentInterest), IntegerEntry((((addressStr + "_") + assetIdStr) + "_claimed"), (tryGetInteger((((addressStr + "_") + assetIdStr) + "_claimed")) + reward)), ScriptTransfer(address, reward, fromBase58String(assetIdStr))] | |
42 | 42 | } | |
43 | 43 | ||
44 | 44 | ||
45 | - | func claimResult (address) = claimAliasResult(address, usdnIdStr) | |
45 | + | func claimResult (address) = (claimAliasResult(address, usdnIdStr) ++ claimAliasResult(address, puzzleIdStr)) | |
46 | 46 | ||
47 | 47 | ||
48 | 48 | func checkNFTValidity (assetId) = match getString(Address(base58'3P7FFQkgALLZDJpCf3smY517wjgPMswGoRP'), (("art_" + toBase58String(assetId)) + "_type")) { | |
49 | 49 | case x: String => | |
50 | 50 | 5 | |
51 | 51 | case _ => | |
52 | 52 | if ((getString(Address(base58'3PFQjjDMiZKQZdu5JqTHD7HwgSXyp9Rw9By'), (("nft_" + toBase58String(assetId)) + "_issuer")) == "3PMki5sHBsQb4KgDknbUwsL3YgxaCzaZnCJ")) | |
53 | 53 | then 1 | |
54 | 54 | else 0 | |
55 | 55 | } | |
56 | 56 | ||
57 | 57 | ||
58 | 58 | @Callable(i) | |
59 | 59 | func stake () = { | |
60 | 60 | let addressStr = toString(i.caller) | |
61 | 61 | let nftId = if ((i.payments[0].amount == 1)) | |
62 | 62 | then value(i.payments[0].assetId) | |
63 | 63 | else throw("please attach NFT") | |
64 | 64 | let assetIdStr = toBase58String(usdnId) | |
65 | 65 | let currentInterest = tryGetInteger((("global_lastCheck_" + assetIdStr) + "_interest")) | |
66 | 66 | let totalStakedAmount = tryGetInteger("global_staked") | |
67 | 67 | let assetPower = fraction(10000, checkNFTValidity(nftId), 5) | |
68 | 68 | let NFTName = if ((assetPower == 10000)) | |
69 | 69 | then "Eagle NFT" | |
70 | 70 | else "Ania NFT" | |
71 | 71 | if ((assetPower == 0)) | |
72 | 72 | then throw("not valid NFT attached") | |
73 | 73 | 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)]) | |
74 | 74 | } | |
75 | 75 | ||
76 | 76 | ||
77 | 77 | ||
78 | 78 | @Callable(i) | |
79 | 79 | func unStake (nftIdStr) = { | |
80 | 80 | let assetPower = fraction(10000, checkNFTValidity(fromBase58String(nftIdStr)), 5) | |
81 | 81 | let addressStr = toString(i.caller) | |
82 | 82 | let stakedAmount = tryGetInteger((addressStr + "_staked")) | |
83 | 83 | let nftOwner = tryGetString((nftIdStr + "_owner")) | |
84 | 84 | if ((addressStr != nftOwner)) | |
85 | 85 | then throw("you don't have NFT available") | |
86 | 86 | 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))]) | |
87 | 87 | } | |
88 | 88 | ||
89 | 89 | ||
90 | 90 | ||
91 | 91 | @Callable(i) | |
92 | 92 | func claimReward () = claimResult(i.caller) | |
93 | 93 | ||
94 | 94 | ||
95 | 95 | ||
96 | 96 | @Callable(i) | |
97 | 97 | func topUpReward () = { | |
98 | 98 | let pmtAsset = value(i.payments[0].assetId) | |
99 | 99 | let pmtAmount = i.payments[0].amount | |
100 | 100 | let amount = if ((pmtAsset == usdnId)) | |
101 | 101 | then { | |
102 | 102 | let b0 = assetBalance(this, puzzleId) | |
103 | 103 | if ((b0 == b0)) | |
104 | 104 | then { | |
105 | 105 | let inv = invoke(Address(base58'3PBHyEwmERR1CEkrTNbPj2bgyisTfPRqfee'), "exchange", [1], i.payments) | |
106 | 106 | if ((inv == inv)) | |
107 | 107 | then { | |
108 | 108 | let b1 = assetBalance(this, puzzleId) | |
109 | 109 | if ((b1 == b1)) | |
110 | 110 | then (b1 - b0) | |
111 | 111 | else throw("Strict value is not equal to itself.") | |
112 | 112 | } | |
113 | 113 | else throw("Strict value is not equal to itself.") | |
114 | 114 | } | |
115 | 115 | else throw("Strict value is not equal to itself.") | |
116 | 116 | } | |
117 | 117 | else if ((pmtAsset == puzzleId)) | |
118 | 118 | then pmtAmount | |
119 | 119 | else throw("not correct asset attached") | |
120 | 120 | if ((amount == amount)) | |
121 | 121 | then { | |
122 | 122 | let currentInterest = tryGetInteger((("global_lastCheck_" + puzzleIdStr) + "_interest")) | |
123 | 123 | let totalStakedAmount = tryGetInteger("global_staked") | |
124 | 124 | let interestDelta = if ((totalStakedAmount > 0)) | |
125 | 125 | then fraction(amount, Scale, totalStakedAmount) | |
126 | 126 | else 0 | |
127 | 127 | $Tuple2([IntegerEntry((("global_" + puzzleIdStr) + "_earnings"), (tryGetInteger((("global_" + puzzleIdStr) + "_earnings")) + amount)), IntegerEntry((("global_lastCheck_" + puzzleIdStr) + "_interest"), (currentInterest + interestDelta))], amount) | |
128 | 128 | } | |
129 | 129 | else throw("Strict value is not equal to itself.") | |
130 | 130 | } | |
131 | 131 | ||
132 | 132 | ||
133 | 133 | @Verifier(tx) | |
134 | 134 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
135 | 135 |
github/deemru/w8io/6500d08 29.70 ms ◑