tx · AcJUmqbKU5rdASQSatyKku8N5Me3dqsoRUW8PnRCAgSz 3P7jrtZsbrDVZFcF8AgmpJ8qQxRAzxCNsit: -0.00700000 Waves 2023.09.12 20:05 [3818211] smart account 3P7jrtZsbrDVZFcF8AgmpJ8qQxRAzxCNsit > SELF 0.00000000 Waves
{ "type": 13, "id": "AcJUmqbKU5rdASQSatyKku8N5Me3dqsoRUW8PnRCAgSz", "fee": 700000, "feeAssetId": null, "timestamp": 1694538364572, "version": 1, "sender": "3P7jrtZsbrDVZFcF8AgmpJ8qQxRAzxCNsit", "senderPublicKey": "7jQAY4oPmY68S5ehfbKJcpYKYoUcTTRtQYvHWmCjp8kD", "proofs": [ "LGPyKiSmfFiyEUJQUgcshdJBqXCc69tKqbXksHQMcqQ2rQK7R3NQqhpcfhLwwNpqxZCcE4YeqnPjSGaYkDhwJsY" ], "script": "base64:BgIYCAISBAoCCAESAwoBARIAEgASABIDCgEIHwASY29uZmlnQWRkcmVzc1N0b3JlAg1jb25maWdBZGRyZXNzAA1jb25maWdBZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFEmNvbmZpZ0FkZHJlc3NTdG9yZQIgdm90aW5nIHJld2FyZHM6IG5vIGNvbmZpZ0FkZHJlc3MCFmludmFsaWQgY29uZmlnIGFkZHJlc3MAD3N0YWtpbmdDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhBjb250cmFjdF9zdGFraW5nAhNubyBzdGFraW5nX2NvbnRyYWN0AhhpbnZhbGlkIHN0YWtpbmcgY29udHJhY3QADm1pbnRlckNvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD2NvbnRyYWN0X21pbnRlcgISbm8gY29udHJhY3RfbWludGVyAhdpbnZhbGlkIG1pbnRlciBjb250cmFjdAAKcHdyQXNzZXRJZAkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIMcG93ZXJBc3NldElkAhZwd3IgYXNzZXQgaWQgbm90IGZvdW5kAQh3cml0ZUludAIDa2V5BXZhbHVlAwkAZgIAAAUFdmFsdWUJAAIBCQCsAgIJAKwCAgkArAICAhd3cml0aW5nIG5lZ2F0aXZlIHZhbHVlIAkApAMBBQV2YWx1ZQIJIGZvciBrZXkgBQNrZXkJAQxJbnRlZ2VyRW50cnkCBQNrZXkFBXZhbHVlARB3cml0ZUNvbnN0U3RyaW5nAgNrZXkFdmFsdWUDCQEBIQEJAQlpc0RlZmluZWQBCQCdCAIFBHRoaXMFA2tleQkBC1N0cmluZ0VudHJ5AgUDa2V5BQV2YWx1ZQkAAgEJAKwCAgIVYWxyZWFkeSBpbml0aWFsaXplZDogBQNrZXkBDXdyaXRlQ29uc3RJbnQCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJoIAgUEdGhpcwUDa2V5CQEMSW50ZWdlckVudHJ5AgUDa2V5BQV2YWx1ZQkAAgEJAKwCAgIQYWxyZWFkeSBleGlzdHM6IAUDa2V5AQhjaGFuZ2VCeQIDa2V5BXZhbHVlCQEId3JpdGVJbnQCBQNrZXkJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFA2tleQAABQV2YWx1ZQEFYXNJbnQBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgNJbnQEA2ludAUHJG1hdGNoMAUDaW50CQACAQIZd3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IEludAEJb3BBbGxvd2VkAQJvcAQBYQkA/AcEBQ1jb25maWdBZGRyZXNzAglvcEFsbG93ZWQJAMwIAgUCb3AFA25pbAUDbmlsAwkAAAIFAWEFAWEGCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAAZIRUlHSFQFBmhlaWdodAAPdm90aW5nRW5kc1N0b3JlAgt2b3RpbmdfZW5kcwAKZXBvY2hTdG9yZQIFZXBvY2gABWVwb2NoCQELdmFsdWVPckVsc2UCCQCfCAEFCmVwb2NoU3RvcmUAAAENZXBvY2hBcHJTdG9yZQEBZQkArAICCQCsAgICBmVwb2NoXwkApAMBBQFlAgRfYXByAQ9lcG9jaFBvd2VyU3RvcmUBAWUJAKwCAgkArAICAgZlcG9jaF8JAKQDAQUBZQIGX3Bvd2VyARBlcG9jaEhlaWdodFN0b3JlAQFlCQCsAgIJAKwCAgIGZXBvY2hfCQCkAwEFAWUCB19oZWlnaHQADmVwb2NoTWluQmxvY2tzCQELdmFsdWVPckVsc2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MJAKwCAgkApQgBBQR0aGlzAhFfZXBvY2hfbWluX2Jsb2NrcwkAaAIAoAsADgAQdm90aW5nUmV3YXJkc0FwcgkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIJAKUIAQUEdGhpcwITX3ZvdGluZ19yZXdhcmRzX2FwcgC5AQAHQXByQmFzZQDoBwAFUkJhc2UAgICE/qbe4READWJsb2Nrc1BlclllYXIJAGgCCQBoAgDtAgAYADwBD3RvdGFsVm90ZXNTdG9yZQEBZQkArAICCQCsAgICBmVwb2NoXwkApAMBBQFlAgxfdG90YWxfdm90ZXMBDnVzZXJWb3Rlc1N0b3JlAgFlBHVzZXIJAKwCAgkArAICCQCsAgICBmVwb2NoXwkApAMBBQFlAgxfdXNlcl92b3Rlc18FBHVzZXIBFW5leHRDbGFpbWVkRXBvY2hTdG9yZQEEdXNlcgkArAICAhNuZXh0X2NsYWltZWRfZXBvY2hfBQR1c2VyARB1c2VyQ2xhaW1lZFN0b3JlAQR1c2VyCQCsAgICCGNsYWltZWRfBQR1c2VyARB0b3RhbFBvd2VyU3Rha2VkAAkBBWFzSW50AQkA/AcEBQ9zdGFraW5nQ29udHJhY3QCCnRvdGFsUG93ZXIFA25pbAUDbmlsAQxlcG9jaFJld2FyZHMDBHVzZXIBZQ9uZXh0RXBvY2hIZWlnaHQEC2Vwb2NoSGVpZ2h0CQCfCAEJARBlcG9jaEhlaWdodFN0b3JlAQUBZQMJAQEhAQkBCWlzRGVmaW5lZAEFC2Vwb2NoSGVpZ2h0AAAEBXRvdGFsCQELdmFsdWVPckVsc2UCCQCfCAEJAQ90b3RhbFZvdGVzU3RvcmUBBQFlAAADCQAAAgUFdG90YWwAAAAABAl1c2VyVm90ZXMJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBDnVzZXJWb3Rlc1N0b3JlAgUBZQUEdXNlcgAABAlSVXNlclBhcnQJAGsDBQl1c2VyVm90ZXMFBVJCYXNlBQV0b3RhbAQGYmxvY2tzCQBlAgUPbmV4dEVwb2NoSGVpZ2h0CQEFdmFsdWUBBQtlcG9jaEhlaWdodAMJAAACBQZibG9ja3MAAAAABANhcHIJARFAZXh0ck5hdGl2ZSgxMDU1KQEJAQ1lcG9jaEFwclN0b3JlAQUBZQQFcG93ZXIJARFAZXh0ck5hdGl2ZSgxMDU1KQEJAQ9lcG9jaFBvd2VyU3RvcmUBBQFlBAx0b3RhbFJld2FyZHMJAGsDBQVwb3dlcgkAaAIFBmJsb2NrcwUDYXByCQBoAgUHQXByQmFzZQUNYmxvY2tzUGVyWWVhcgkAawMFDHRvdGFsUmV3YXJkcwUJUlVzZXJQYXJ0BQVSQmFzZQEJY2xhaW1hYmxlAQR1c2VyCgEEZm9sZAIDYWNjA25hXwQLJHQwMzM4OTM0MDcFA2FjYwQBZQgFCyR0MDMzODkzNDA3Al8xBANzdW0IBQskdDAzMzg5MzQwNwJfMgQLZXBvY2hIZWlnaHQJAJ8IAQkBEGVwb2NoSGVpZ2h0U3RvcmUBBQFlAwkBASEBCQEJaXNEZWZpbmVkAQULZXBvY2hIZWlnaHQFA2FjYwQJbmV4dEVwb2NoCQBkAgUBZQABBA9uZXh0RXBvY2hIZWlnaHQJAJ8IAQkBEGVwb2NoSGVpZ2h0U3RvcmUBBQluZXh0RXBvY2gDCQEBIQEJAQlpc0RlZmluZWQBBQ9uZXh0RXBvY2hIZWlnaHQFA2FjYwkAlAoCBQluZXh0RXBvY2gJAGQCBQNzdW0JAQxlcG9jaFJld2FyZHMDBQR1c2VyBQFlCQEFdmFsdWUBBQ9uZXh0RXBvY2hIZWlnaHQEBmxpc3QzMAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALCQDMCAIADAkAzAgCAA0JAMwIAgAOCQDMCAIADwkAzAgCABAJAMwIAgARCQDMCAIAEgkAzAgCABMJAMwIAgAUCQDMCAIAFQkAzAgCABYJAMwIAgAXCQDMCAIAGAkAzAgCABkJAMwIAgAaCQDMCAIAGwkAzAgCABwJAMwIAgAdCQDMCAIAHgUDbmlsCgACJGwFBmxpc3QzMAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEVbmV4dENsYWltZWRFcG9jaFN0b3JlAQUEdXNlcgAAAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBBGZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDMwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAAVABYAFwAYABkAGgAbABwAHQAeAQphZHZpc2VVc2VyAQdhZGRyZXNzBAskdDA0MDEyNDA2MAkBCWNsYWltYWJsZQEFB2FkZHJlc3MECW5leHRFcG9jaAgFCyR0MDQwMTI0MDYwAl8xBApjbGFpbWFibGUxCAULJHQwNDAxMjQwNjACXzIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIIaGVpZ2h0OiAJAKQDAQUGSEVJR0hUAg0sIGNsYWltYWJsZTogCQCkAwEFCmNsYWltYWJsZTECFywgY2xhaW1hYmxlX3RpbGxfZXBvY2g6CQCkAwEFCW5leHRFcG9jaAIRLCBjbGFpbWFibGVfdGlsbDoJAKQDAQkBC3ZhbHVlT3JFbHNlAgkAnwgBCQEQZXBvY2hIZWlnaHRTdG9yZQEFCW5leHRFcG9jaAD///////////8BAhcsIG5leHRfY2xhaW1hYmxlX2Vwb2NoOgkApAMBCQELdmFsdWVPckVsc2UCCQCfCAEJARVuZXh0Q2xhaW1lZEVwb2NoU3RvcmUBBQdhZGRyZXNzAAACCywgY2xhaW1lZDogCQCkAwEJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBEHVzZXJDbGFpbWVkU3RvcmUBBQdhZGRyZXNzAAACCywgcGVuZGluZzogCQCkAwEJAQxlcG9jaFJld2FyZHMDBQdhZGRyZXNzBQVlcG9jaAUGSEVJR0hUBgFpAQljb3VudFZvdGUCBHVzZXIFdm90ZXMJAMwIAgkBCGNoYW5nZUJ5AgkBD3RvdGFsVm90ZXNTdG9yZQEFBWVwb2NoBQV2b3RlcwkAzAgCCQEIY2hhbmdlQnkCCQEOdXNlclZvdGVzU3RvcmUCBQVlcG9jaAUEdXNlcgUFdm90ZXMFA25pbAFpAQp2b3RpbmdFbmRzAQFoAwkAZgIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUPdm90aW5nRW5kc1N0b3JlAAAFAWgFA25pbAkAzAgCCQEMSW50ZWdlckVudHJ5AgUPdm90aW5nRW5kc1N0b3JlBQFoBQNuaWwBaQEMaW5pdGlhbEVwb2NoAAkAzAgCCQENd3JpdGVDb25zdEludAIFCmVwb2NoU3RvcmUAAAkAzAgCCQENd3JpdGVDb25zdEludAIJARBlcG9jaEhlaWdodFN0b3JlAQAABQZIRUlHSFQJAMwIAgkBDXdyaXRlQ29uc3RJbnQCCQENZXBvY2hBcHJTdG9yZQEAAAUQdm90aW5nUmV3YXJkc0FwcgkAzAgCCQENd3JpdGVDb25zdEludAIJAQ9lcG9jaFBvd2VyU3RvcmUBAAAJARB0b3RhbFBvd2VyU3Rha2VkAAUDbmlsAWkBCW5leHRFcG9jaAAEBmNoZWNrcwkBCW9wQWxsb3dlZAECGXZvdGluZ19yZXdhcmRzX25leHRfZXBvY2gDCQAAAgUGY2hlY2tzBQZjaGVja3MDCQBmAgkBC3ZhbHVlT3JFbHNlAgkAnwgBBQ92b3RpbmdFbmRzU3RvcmUAAAUGSEVJR0hUCQACAQIbdm90aW5nIGlzIGFjdGl2ZS4gdHJ5IGxhdGVyAwkAZgIJAGQCCQELdmFsdWVPckVsc2UCCQCfCAEJARBlcG9jaEhlaWdodFN0b3JlAQUFZXBvY2gAAAUOZXBvY2hNaW5CbG9ja3MFBkhFSUdIVAkAAgECCXRvbyBlYXJseQQIbmV3RXBvY2gJAGQCBQVlcG9jaAABCQDMCAIJAQhjaGFuZ2VCeQIJAQ90b3RhbFZvdGVzU3RvcmUBBQVlcG9jaAAACQDMCAIJAQh3cml0ZUludAIFCmVwb2NoU3RvcmUFCG5ld0Vwb2NoCQDMCAIJAQ13cml0ZUNvbnN0SW50AgkBEGVwb2NoSGVpZ2h0U3RvcmUBBQhuZXdFcG9jaAUGSEVJR0hUCQDMCAIJAQ13cml0ZUNvbnN0SW50AgkBDWVwb2NoQXByU3RvcmUBBQhuZXdFcG9jaAUQdm90aW5nUmV3YXJkc0FwcgkAzAgCCQENd3JpdGVDb25zdEludAIJAQ9lcG9jaFBvd2VyU3RvcmUBBQhuZXdFcG9jaAkBEHRvdGFsUG93ZXJTdGFrZWQABQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEFY2xhaW0ABAZjaGVja3MJAQlvcEFsbG93ZWQBAhR2b3RpbmdfcmV3YXJkc19jbGFpbQMJAAACBQZjaGVja3MFBmNoZWNrcwQEdXNlcgkApQgBCAUBaQZjYWxsZXIECyR0MDU5MDE1OTUxCQEJY2xhaW1hYmxlAQUEdXNlcgQQbmV4dENsYWltZWRFcG9jaAgFCyR0MDU5MDE1OTUxAl8xBAdyZXdhcmRzCAULJHQwNTkwMTU5NTECXzIEAW0JAPwHBAUObWludGVyQ29udHJhY3QCBG1pbnQJAMwIAgUHcmV3YXJkcwUDbmlsBQNuaWwDCQAAAgUBbQUBbQQBcwkA/AcEBQ9zdGFraW5nQ29udHJhY3QCCHN0YWtlRm9yCQDMCAIFBHVzZXIFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUKcHdyQXNzZXRJZAUHcmV3YXJkcwUDbmlsAwkAAAIFAXMFAXMJAMwIAgkBCHdyaXRlSW50AgkBFW5leHRDbGFpbWVkRXBvY2hTdG9yZQEFBHVzZXIFEG5leHRDbGFpbWVkRXBvY2gJAMwIAgkBCGNoYW5nZUJ5AgkBEHVzZXJDbGFpbWVkU3RvcmUBBQR1c2VyBQdyZXdhcmRzBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEEaW5pdAEGY29uZmlnCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSY29uZmlnQWRkcmVzc1N0b3JlBQZjb25maWcFA25pbADg6RFz", "chainId": 87, "height": 3818211, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6i7xMng8mkhb4mekPKXfVms8LGm9mNMASFSiaP7JoUEL Next: Cgrqk5VZWuAYNPoAGUBZYPEmfMW73cpB3N9AqmSfaWKw Diff:
Old | New | Differences | |
---|---|---|---|
88 | 88 | ||
89 | 89 | ||
90 | 90 | func epochRewards (user,e,nextEpochHeight) = { | |
91 | - | let | |
92 | - | if (( | |
91 | + | let epochHeight = getInteger(epochHeightStore(e)) | |
92 | + | if (!(isDefined(epochHeight))) | |
93 | 93 | then 0 | |
94 | 94 | else { | |
95 | - | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
96 | - | let RUserPart = fraction(userVotes, RBase, total) | |
97 | - | let epochHeight = getInteger(epochHeightStore(e)) | |
98 | - | if (!(isDefined(epochHeight))) | |
95 | + | let total = valueOrElse(getInteger(totalVotesStore(e)), 0) | |
96 | + | if ((total == 0)) | |
99 | 97 | then 0 | |
100 | 98 | else { | |
99 | + | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
100 | + | let RUserPart = fraction(userVotes, RBase, total) | |
101 | 101 | let blocks = (nextEpochHeight - value(epochHeight)) | |
102 | 102 | if ((blocks == 0)) | |
103 | 103 | then 0 | |
113 | 113 | ||
114 | 114 | ||
115 | 115 | func claimable (user) = { | |
116 | - | let nextClaimedEpoch = valueOrElse(getInteger(nextClaimedEpochStore(user)), 0) | |
117 | 116 | func fold (acc,na_) = { | |
118 | - | let $ | |
119 | - | let e = $ | |
120 | - | let sum = $ | |
121 | - | let | |
122 | - | if (!(isDefined( | |
117 | + | let $t033893407 = acc | |
118 | + | let e = $t033893407._1 | |
119 | + | let sum = $t033893407._2 | |
120 | + | let epochHeight = getInteger(epochHeightStore(e)) | |
121 | + | if (!(isDefined(epochHeight))) | |
123 | 122 | then acc | |
124 | 123 | else { | |
125 | - | let totalValue = value(total) | |
126 | 124 | let nextEpoch = (e + 1) | |
127 | - | if ((totalValue == 0)) | |
128 | - | then $Tuple2(nextEpoch, sum) | |
129 | - | else { | |
130 | - | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
131 | - | let RUserPart = fraction(userVotes, RBase, totalValue) | |
132 | - | let epochHeight = getInteger(epochHeightStore(e)) | |
133 | - | let nextEpochHeight = getInteger(epochHeightStore(nextEpoch)) | |
134 | - | if (if (!(isDefined(epochHeight))) | |
135 | - | then true | |
136 | - | else !(isDefined(nextEpochHeight))) | |
137 | - | then acc | |
138 | - | else { | |
139 | - | let blocks = (value(nextEpochHeight) - value(epochHeight)) | |
140 | - | let apr = getIntegerValue(epochAprStore(e)) | |
141 | - | let power = getIntegerValue(epochPowerStore(e)) | |
142 | - | let totalRewards = fraction(power, (blocks * apr), (AprBase * blocksPerYear)) | |
143 | - | let userRewards = fraction(totalRewards, RUserPart, RBase) | |
144 | - | $Tuple2(nextEpoch, (sum + userRewards)) | |
145 | - | } | |
146 | - | } | |
125 | + | let nextEpochHeight = getInteger(epochHeightStore(nextEpoch)) | |
126 | + | if (!(isDefined(nextEpochHeight))) | |
127 | + | then acc | |
128 | + | else $Tuple2(nextEpoch, (sum + epochRewards(user, e, value(nextEpochHeight)))) | |
147 | 129 | } | |
148 | 130 | } | |
149 | 131 | ||
150 | - | let $l = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20] | |
132 | + | let list30 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30] | |
133 | + | let $l = list30 | |
151 | 134 | let $s = size($l) | |
152 | - | let $acc0 = $Tuple2( | |
135 | + | let $acc0 = $Tuple2(valueOrElse(getInteger(nextClaimedEpochStore(user)), 0), 0) | |
153 | 136 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
154 | 137 | then $a | |
155 | 138 | else fold($a, $l[$i]) | |
156 | 139 | ||
157 | 140 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
158 | 141 | then $a | |
159 | - | else throw("List size exceeds | |
142 | + | else throw("List size exceeds 30") | |
160 | 143 | ||
161 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
144 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30) | |
162 | 145 | } | |
163 | 146 | ||
164 | 147 | ||
165 | 148 | func adviseUser (address) = { | |
166 | - | let $ | |
167 | - | let nextEpoch = $ | |
168 | - | let claimable1 = $ | |
169 | - | ((((((((("height: " + toString(HEIGHT)) + ", claimable: ") + toString(claimable1)) + ", claimable_till:") + toString(valueOrElse(getInteger(epochHeightStore(nextEpoch)), -1))) + ", claimed: ") + toString(valueOrElse(getInteger(userClaimedStore(address)), 0))) + ", pending: ") + toString(epochRewards(address, epoch, HEIGHT))) | |
149 | + | let $t040124060 = claimable(address) | |
150 | + | let nextEpoch = $t040124060._1 | |
151 | + | let claimable1 = $t040124060._2 | |
152 | + | ((((((((((((("height: " + toString(HEIGHT)) + ", claimable: ") + toString(claimable1)) + ", claimable_till_epoch:") + toString(nextEpoch)) + ", claimable_till:") + toString(valueOrElse(getInteger(epochHeightStore(nextEpoch)), -1))) + ", next_claimable_epoch:") + toString(valueOrElse(getInteger(nextClaimedEpochStore(address)), 0))) + ", claimed: ") + toString(valueOrElse(getInteger(userClaimedStore(address)), 0))) + ", pending: ") + toString(epochRewards(address, epoch, HEIGHT))) | |
170 | 153 | } | |
171 | 154 | ||
172 | 155 | ||
183 | 166 | ||
184 | 167 | ||
185 | 168 | @Callable(i) | |
186 | - | func initialEpoch () = [writeConstInt(epochStore, 0), writeConstInt(epochHeightStore(0), | |
169 | + | func initialEpoch () = [writeConstInt(epochStore, 0), writeConstInt(epochHeightStore(0), HEIGHT), writeConstInt(epochAprStore(0), votingRewardsApr), writeConstInt(epochPowerStore(0), totalPowerStaked())] | |
187 | 170 | ||
188 | 171 | ||
189 | 172 | ||
190 | 173 | @Callable(i) | |
191 | 174 | func nextEpoch () = { | |
192 | - | let checks = opAllowed("voting_rewards_next_epoch | |
175 | + | let checks = opAllowed("voting_rewards_next_epoch") | |
193 | 176 | if ((checks == checks)) | |
194 | 177 | then if ((valueOrElse(getInteger(votingEndsStore), 0) > HEIGHT)) | |
195 | 178 | then throw("voting is active. try later") | |
206 | 189 | ||
207 | 190 | @Callable(i) | |
208 | 191 | func claim () = { | |
209 | - | let checks = opAllowed("voting_rewards_claim | |
192 | + | let checks = opAllowed("voting_rewards_claim") | |
210 | 193 | if ((checks == checks)) | |
211 | 194 | then { | |
212 | 195 | let user = toString(i.caller) | |
213 | - | let $t063476570 = claimable(user) | |
214 | - | let newNextClaimedEpoch = $t063476570._1 | |
215 | - | let rewards = $t063476570._2 | |
216 | - | [writeInt(nextClaimedEpochStore(user), newNextClaimedEpoch), changeBy(userClaimedStore(user), rewards)] | |
196 | + | let $t059015951 = claimable(user) | |
197 | + | let nextClaimedEpoch = $t059015951._1 | |
198 | + | let rewards = $t059015951._2 | |
199 | + | let m = invoke(minterContract, "mint", [rewards], nil) | |
200 | + | if ((m == m)) | |
201 | + | then { | |
202 | + | let s = invoke(stakingContract, "stakeFor", [user], [AttachedPayment(pwrAssetId, rewards)]) | |
203 | + | if ((s == s)) | |
204 | + | then [writeInt(nextClaimedEpochStore(user), nextClaimedEpoch), changeBy(userClaimedStore(user), rewards)] | |
205 | + | else throw("Strict value is not equal to itself.") | |
206 | + | } | |
207 | + | else throw("Strict value is not equal to itself.") | |
217 | 208 | } | |
218 | 209 | else throw("Strict value is not equal to itself.") | |
219 | 210 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let configAddressStore = "configAddress" | |
5 | 5 | ||
6 | 6 | let configAddress = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, configAddressStore), "voting rewards: no configAddress")), "invalid config address") | |
7 | 7 | ||
8 | 8 | let stakingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "contract_staking"), "no staking_contract")), "invalid staking contract") | |
9 | 9 | ||
10 | 10 | let minterContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "contract_minter"), "no contract_minter")), "invalid minter contract") | |
11 | 11 | ||
12 | 12 | let pwrAssetId = fromBase58String(valueOrErrorMessage(getString(configAddress, "powerAssetId"), "pwr asset id not found")) | |
13 | 13 | ||
14 | 14 | func writeInt (key,value) = if ((0 > value)) | |
15 | 15 | then throw(((("writing negative value " + toString(value)) + " for key ") + key)) | |
16 | 16 | else IntegerEntry(key, value) | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | func writeConstString (key,value) = if (!(isDefined(getString(this, key)))) | |
20 | 20 | then StringEntry(key, value) | |
21 | 21 | else throw(("already initialized: " + key)) | |
22 | 22 | ||
23 | 23 | ||
24 | 24 | func writeConstInt (key,value) = if (!(isDefined(getInteger(this, key)))) | |
25 | 25 | then IntegerEntry(key, value) | |
26 | 26 | else throw(("already exists: " + key)) | |
27 | 27 | ||
28 | 28 | ||
29 | 29 | func changeBy (key,value) = writeInt(key, (valueOrElse(getInteger(this, key), 0) + value)) | |
30 | 30 | ||
31 | 31 | ||
32 | 32 | func asInt (value) = match value { | |
33 | 33 | case int: Int => | |
34 | 34 | int | |
35 | 35 | case _ => | |
36 | 36 | throw("wrong type, expected: Int") | |
37 | 37 | } | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func opAllowed (op) = { | |
41 | 41 | let a = invoke(configAddress, "opAllowed", [op], nil) | |
42 | 42 | if ((a == a)) | |
43 | 43 | then true | |
44 | 44 | else throw("Strict value is not equal to itself.") | |
45 | 45 | } | |
46 | 46 | ||
47 | 47 | ||
48 | 48 | let HEIGHT = height | |
49 | 49 | ||
50 | 50 | let votingEndsStore = "voting_ends" | |
51 | 51 | ||
52 | 52 | let epochStore = "epoch" | |
53 | 53 | ||
54 | 54 | let epoch = valueOrElse(getInteger(epochStore), 0) | |
55 | 55 | ||
56 | 56 | func epochAprStore (e) = (("epoch_" + toString(e)) + "_apr") | |
57 | 57 | ||
58 | 58 | ||
59 | 59 | func epochPowerStore (e) = (("epoch_" + toString(e)) + "_power") | |
60 | 60 | ||
61 | 61 | ||
62 | 62 | func epochHeightStore (e) = (("epoch_" + toString(e)) + "_height") | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | let epochMinBlocks = valueOrElse(getInteger(configAddress, (toString(this) + "_epoch_min_blocks")), (1440 * 14)) | |
66 | 66 | ||
67 | 67 | let votingRewardsApr = valueOrElse(getInteger(configAddress, (toString(this) + "_voting_rewards_apr")), 185) | |
68 | 68 | ||
69 | 69 | let AprBase = 1000 | |
70 | 70 | ||
71 | 71 | let RBase = 10000000000000000 | |
72 | 72 | ||
73 | 73 | let blocksPerYear = ((365 * 24) * 60) | |
74 | 74 | ||
75 | 75 | func totalVotesStore (e) = (("epoch_" + toString(e)) + "_total_votes") | |
76 | 76 | ||
77 | 77 | ||
78 | 78 | func userVotesStore (e,user) = ((("epoch_" + toString(e)) + "_user_votes_") + user) | |
79 | 79 | ||
80 | 80 | ||
81 | 81 | func nextClaimedEpochStore (user) = ("next_claimed_epoch_" + user) | |
82 | 82 | ||
83 | 83 | ||
84 | 84 | func userClaimedStore (user) = ("claimed_" + user) | |
85 | 85 | ||
86 | 86 | ||
87 | 87 | func totalPowerStaked () = asInt(invoke(stakingContract, "totalPower", nil, nil)) | |
88 | 88 | ||
89 | 89 | ||
90 | 90 | func epochRewards (user,e,nextEpochHeight) = { | |
91 | - | let | |
92 | - | if (( | |
91 | + | let epochHeight = getInteger(epochHeightStore(e)) | |
92 | + | if (!(isDefined(epochHeight))) | |
93 | 93 | then 0 | |
94 | 94 | else { | |
95 | - | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
96 | - | let RUserPart = fraction(userVotes, RBase, total) | |
97 | - | let epochHeight = getInteger(epochHeightStore(e)) | |
98 | - | if (!(isDefined(epochHeight))) | |
95 | + | let total = valueOrElse(getInteger(totalVotesStore(e)), 0) | |
96 | + | if ((total == 0)) | |
99 | 97 | then 0 | |
100 | 98 | else { | |
99 | + | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
100 | + | let RUserPart = fraction(userVotes, RBase, total) | |
101 | 101 | let blocks = (nextEpochHeight - value(epochHeight)) | |
102 | 102 | if ((blocks == 0)) | |
103 | 103 | then 0 | |
104 | 104 | else { | |
105 | 105 | let apr = getIntegerValue(epochAprStore(e)) | |
106 | 106 | let power = getIntegerValue(epochPowerStore(e)) | |
107 | 107 | let totalRewards = fraction(power, (blocks * apr), (AprBase * blocksPerYear)) | |
108 | 108 | fraction(totalRewards, RUserPart, RBase) | |
109 | 109 | } | |
110 | 110 | } | |
111 | 111 | } | |
112 | 112 | } | |
113 | 113 | ||
114 | 114 | ||
115 | 115 | func claimable (user) = { | |
116 | - | let nextClaimedEpoch = valueOrElse(getInteger(nextClaimedEpochStore(user)), 0) | |
117 | 116 | func fold (acc,na_) = { | |
118 | - | let $ | |
119 | - | let e = $ | |
120 | - | let sum = $ | |
121 | - | let | |
122 | - | if (!(isDefined( | |
117 | + | let $t033893407 = acc | |
118 | + | let e = $t033893407._1 | |
119 | + | let sum = $t033893407._2 | |
120 | + | let epochHeight = getInteger(epochHeightStore(e)) | |
121 | + | if (!(isDefined(epochHeight))) | |
123 | 122 | then acc | |
124 | 123 | else { | |
125 | - | let totalValue = value(total) | |
126 | 124 | let nextEpoch = (e + 1) | |
127 | - | if ((totalValue == 0)) | |
128 | - | then $Tuple2(nextEpoch, sum) | |
129 | - | else { | |
130 | - | let userVotes = valueOrElse(getInteger(userVotesStore(e, user)), 0) | |
131 | - | let RUserPart = fraction(userVotes, RBase, totalValue) | |
132 | - | let epochHeight = getInteger(epochHeightStore(e)) | |
133 | - | let nextEpochHeight = getInteger(epochHeightStore(nextEpoch)) | |
134 | - | if (if (!(isDefined(epochHeight))) | |
135 | - | then true | |
136 | - | else !(isDefined(nextEpochHeight))) | |
137 | - | then acc | |
138 | - | else { | |
139 | - | let blocks = (value(nextEpochHeight) - value(epochHeight)) | |
140 | - | let apr = getIntegerValue(epochAprStore(e)) | |
141 | - | let power = getIntegerValue(epochPowerStore(e)) | |
142 | - | let totalRewards = fraction(power, (blocks * apr), (AprBase * blocksPerYear)) | |
143 | - | let userRewards = fraction(totalRewards, RUserPart, RBase) | |
144 | - | $Tuple2(nextEpoch, (sum + userRewards)) | |
145 | - | } | |
146 | - | } | |
125 | + | let nextEpochHeight = getInteger(epochHeightStore(nextEpoch)) | |
126 | + | if (!(isDefined(nextEpochHeight))) | |
127 | + | then acc | |
128 | + | else $Tuple2(nextEpoch, (sum + epochRewards(user, e, value(nextEpochHeight)))) | |
147 | 129 | } | |
148 | 130 | } | |
149 | 131 | ||
150 | - | let $l = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20] | |
132 | + | let list30 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30] | |
133 | + | let $l = list30 | |
151 | 134 | let $s = size($l) | |
152 | - | let $acc0 = $Tuple2( | |
135 | + | let $acc0 = $Tuple2(valueOrElse(getInteger(nextClaimedEpochStore(user)), 0), 0) | |
153 | 136 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
154 | 137 | then $a | |
155 | 138 | else fold($a, $l[$i]) | |
156 | 139 | ||
157 | 140 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
158 | 141 | then $a | |
159 | - | else throw("List size exceeds | |
142 | + | else throw("List size exceeds 30") | |
160 | 143 | ||
161 | - | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
144 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30) | |
162 | 145 | } | |
163 | 146 | ||
164 | 147 | ||
165 | 148 | func adviseUser (address) = { | |
166 | - | let $ | |
167 | - | let nextEpoch = $ | |
168 | - | let claimable1 = $ | |
169 | - | ((((((((("height: " + toString(HEIGHT)) + ", claimable: ") + toString(claimable1)) + ", claimable_till:") + toString(valueOrElse(getInteger(epochHeightStore(nextEpoch)), -1))) + ", claimed: ") + toString(valueOrElse(getInteger(userClaimedStore(address)), 0))) + ", pending: ") + toString(epochRewards(address, epoch, HEIGHT))) | |
149 | + | let $t040124060 = claimable(address) | |
150 | + | let nextEpoch = $t040124060._1 | |
151 | + | let claimable1 = $t040124060._2 | |
152 | + | ((((((((((((("height: " + toString(HEIGHT)) + ", claimable: ") + toString(claimable1)) + ", claimable_till_epoch:") + toString(nextEpoch)) + ", claimable_till:") + toString(valueOrElse(getInteger(epochHeightStore(nextEpoch)), -1))) + ", next_claimable_epoch:") + toString(valueOrElse(getInteger(nextClaimedEpochStore(address)), 0))) + ", claimed: ") + toString(valueOrElse(getInteger(userClaimedStore(address)), 0))) + ", pending: ") + toString(epochRewards(address, epoch, HEIGHT))) | |
170 | 153 | } | |
171 | 154 | ||
172 | 155 | ||
173 | 156 | @Callable(i) | |
174 | 157 | func countVote (user,votes) = [changeBy(totalVotesStore(epoch), votes), changeBy(userVotesStore(epoch, user), votes)] | |
175 | 158 | ||
176 | 159 | ||
177 | 160 | ||
178 | 161 | @Callable(i) | |
179 | 162 | func votingEnds (h) = if ((valueOrElse(getInteger(votingEndsStore), 0) > h)) | |
180 | 163 | then nil | |
181 | 164 | else [IntegerEntry(votingEndsStore, h)] | |
182 | 165 | ||
183 | 166 | ||
184 | 167 | ||
185 | 168 | @Callable(i) | |
186 | - | func initialEpoch () = [writeConstInt(epochStore, 0), writeConstInt(epochHeightStore(0), | |
169 | + | func initialEpoch () = [writeConstInt(epochStore, 0), writeConstInt(epochHeightStore(0), HEIGHT), writeConstInt(epochAprStore(0), votingRewardsApr), writeConstInt(epochPowerStore(0), totalPowerStaked())] | |
187 | 170 | ||
188 | 171 | ||
189 | 172 | ||
190 | 173 | @Callable(i) | |
191 | 174 | func nextEpoch () = { | |
192 | - | let checks = opAllowed("voting_rewards_next_epoch | |
175 | + | let checks = opAllowed("voting_rewards_next_epoch") | |
193 | 176 | if ((checks == checks)) | |
194 | 177 | then if ((valueOrElse(getInteger(votingEndsStore), 0) > HEIGHT)) | |
195 | 178 | then throw("voting is active. try later") | |
196 | 179 | else if (((valueOrElse(getInteger(epochHeightStore(epoch)), 0) + epochMinBlocks) > HEIGHT)) | |
197 | 180 | then throw("too early") | |
198 | 181 | else { | |
199 | 182 | let newEpoch = (epoch + 1) | |
200 | 183 | [changeBy(totalVotesStore(epoch), 0), writeInt(epochStore, newEpoch), writeConstInt(epochHeightStore(newEpoch), HEIGHT), writeConstInt(epochAprStore(newEpoch), votingRewardsApr), writeConstInt(epochPowerStore(newEpoch), totalPowerStaked())] | |
201 | 184 | } | |
202 | 185 | else throw("Strict value is not equal to itself.") | |
203 | 186 | } | |
204 | 187 | ||
205 | 188 | ||
206 | 189 | ||
207 | 190 | @Callable(i) | |
208 | 191 | func claim () = { | |
209 | - | let checks = opAllowed("voting_rewards_claim | |
192 | + | let checks = opAllowed("voting_rewards_claim") | |
210 | 193 | if ((checks == checks)) | |
211 | 194 | then { | |
212 | 195 | let user = toString(i.caller) | |
213 | - | let $t063476570 = claimable(user) | |
214 | - | let newNextClaimedEpoch = $t063476570._1 | |
215 | - | let rewards = $t063476570._2 | |
216 | - | [writeInt(nextClaimedEpochStore(user), newNextClaimedEpoch), changeBy(userClaimedStore(user), rewards)] | |
196 | + | let $t059015951 = claimable(user) | |
197 | + | let nextClaimedEpoch = $t059015951._1 | |
198 | + | let rewards = $t059015951._2 | |
199 | + | let m = invoke(minterContract, "mint", [rewards], nil) | |
200 | + | if ((m == m)) | |
201 | + | then { | |
202 | + | let s = invoke(stakingContract, "stakeFor", [user], [AttachedPayment(pwrAssetId, rewards)]) | |
203 | + | if ((s == s)) | |
204 | + | then [writeInt(nextClaimedEpochStore(user), nextClaimedEpoch), changeBy(userClaimedStore(user), rewards)] | |
205 | + | else throw("Strict value is not equal to itself.") | |
206 | + | } | |
207 | + | else throw("Strict value is not equal to itself.") | |
217 | 208 | } | |
218 | 209 | else throw("Strict value is not equal to itself.") | |
219 | 210 | } | |
220 | 211 | ||
221 | 212 | ||
222 | 213 | ||
223 | 214 | @Callable(i) | |
224 | 215 | func init (config) = [writeConstString(configAddressStore, config)] | |
225 | 216 | ||
226 | 217 |
github/deemru/w8io/3ef1775 45.19 ms ◑