tx · 9uFDsTFqZ7nT7w1JeK2rd7JSootUmVJN2WgaCDtrBhJx 3MtsXxXqERvHEmkPiiuBESuixd9Y8qAU1PC: -0.01500000 Waves 2023.01.24 13:55 [2418951] smart account 3MtsXxXqERvHEmkPiiuBESuixd9Y8qAU1PC > SELF 0.00000000 Waves
{ "type": 13, "id": "9uFDsTFqZ7nT7w1JeK2rd7JSootUmVJN2WgaCDtrBhJx", "fee": 1500000, "feeAssetId": null, "timestamp": 1674557751763, "version": 2, "chainId": 84, "sender": "3MtsXxXqERvHEmkPiiuBESuixd9Y8qAU1PC", "senderPublicKey": "EBCSQaTtuxQBJyc62F142LxJ3hpQtCwuZ2z9kkoe6Vvt", "proofs": [ "6kjaFTcsTYrZDBwkxF5dGbCgPQPFijzsE4g2Fb6ocNJwpn2TdLirZLXRM6P2BgUCgM2RUhn5qCBZpaXWjEFQJVw", "5JMyv9B2ngCTkfvPoYSJ23wy2gfSt1tcg1BwdYtdBfNWwNHk1axbmbBwpBuR6GS9Ua7mVXYzEi1tjWpdMqpqE4Px" ], "script": "base64:BgIbCAISABIECgIICBIFCgMBBAESBAoCAQgSABIAPwAGb3JhY2xlCQEHQWRkcmVzcwEBGgFUSBOXDMDTM8wlMoC2KfenZGiAq+PMe0uZAAd2ZXJzaW9uAgUxLjAuMAAIa1ZlcnNpb24CB3ZlcnNpb24AB2tBY3RpdmUCBmFjdGl2ZQALa0FjdGl2ZUdsb2ICFGFjdGl2ZV9hbGxfY29udHJhY3RzAA9rTnVtYmVyT2ZWb3RpbmcCFHZvdGluZ19hY3RpdmVfbnVtYmVyAA1rSGVpZ2h0T2ZQb29sAg5fZmluaXNoX2hlaWdodAADa05vAg9fdG90YWxfdm90ZXNfbm8ABGtZZXMCEF90b3RhbF92b3Rlc195ZXMAB2tOb1VzZXICCF92b3RlX25vAAhrWWVzVXNlcgIJX3ZvdGVfeWVzAA9rU3RhdHVzT2ZWb3RpbmcCB19zdGF0dXMAD2tBbW91bnRPZlZvdGluZwIOdm90aW5nX2lkX2xhc3QAEmtNYXhBbW91bnRPZlZvdGluZwIRbWF4X2Ftb3VudF92b3RpbmcAD2tNYXhEYXlPZlZvdGluZwIObWF4X2RheV92b3RpbmcABmtDYXVzZQIOc2h1dGRvd25fY2F1c2UADGtDYW5jZWxDYXVzZQINX2NhbmNlbF9jYXVzZQAPa1VzZXJUb3RhbEdTV09QAg1fR1N3b3BfYW1vdW50AAVrTmFtZQILX2Fzc2V0X25hbWUACHZvdGluZ0lkAgdfdm90aW5nAA9hY3RpdmVWb3RlRmlyc3QCFHZvdGluZ19hY3RpdmVfY2VsbF8xABBhY3RpdmVWb3RlU2Vjb25kAhR2b3RpbmdfYWN0aXZlX2NlbGxfMgAPYWN0aXZlVm90ZVRoaXJkAhR2b3RpbmdfYWN0aXZlX2NlbGxfMwANa0FkbWluUHViS2V5MQILYWRtaW5fcHViXzEADWtBZG1pblB1YktleTICC2FkbWluX3B1Yl8yAA1rQWRtaW5QdWJLZXkzAgthZG1pbl9wdWJfMwAQa01vbmV5Qm94QWRkcmVzcwIRbW9uZXlfYm94X2FkZHJlc3MAC2tHb3ZBZGRyZXNzAhJnb3Zlcm5hbmNlX2FkZHJlc3MADGtGYXJtaW5nQWRkcgIPZmFybWluZ19hZGRyZXNzAAxrVVNETkFzc2V0SWQCDXVzZG5fYXNzZXRfaWQAB2tTV09QaWQCB1NXT1BfaWQADm51bWJlck9mVm90aW5nCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ9rTnVtYmVyT2ZWb3RpbmcADmFtb3VudE9mVm90aW5nCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzBQ9rQW1vdW50T2ZWb3RpbmcAD2ZpcnN0QWN0aXZlVm90ZQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQ9hY3RpdmVWb3RlRmlyc3QCAAAQc2Vjb25kQWN0aXZlVm90ZQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBRBhY3RpdmVWb3RlU2Vjb25kAgAAD3RoaXJkQWN0aXZlVm90ZQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQ9hY3RpdmVWb3RlVGhpcmQCAAAGYWN0aXZlCQERQGV4dHJOYXRpdmUoMTA1MSkCBQR0aGlzBQdrQWN0aXZlAAphY3RpdmVHbG9iCQELdmFsdWVPckVsc2UCCQCbCAIFBm9yYWNsZQULa0FjdGl2ZUdsb2IGACFjb21pc3Npb25Gb3JJbml0YWxpemF0aW9uT2ZWb3RpbmcAgJTr3AMAEW1heEFtb3VudE9mVm90aW5nAAMADm1heERheU9mVm90aW5nAAcAEnZvdGluZ1BlcmlvZExlbmd0aAkAaAIAowsFDm1heERheU9mVm90aW5nARNnZXRCYXNlNThGcm9tT3JhY2xlAQNrZXkEByRtYXRjaDAJAJ0IAgUGb3JhY2xlBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAZzdHJpbmcFByRtYXRjaDAJANkEAQUGc3RyaW5nBAdub3RoaW5nBQckbWF0Y2gwCQACAQkArAICBQNrZXkCCGlzIGVtcHR5AAxhZG1pblB1YktleTEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUNa0FkbWluUHViS2V5MQAMYWRtaW5QdWJLZXkyCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtBZG1pblB1YktleTIADGFkbWluUHViS2V5MwkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQ1rQWRtaW5QdWJLZXkzAApnb3ZBZGRyZXNzCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQULa0dvdkFkZHJlc3MAC2Zhcm1pbmdBZGRyCQEHQWRkcmVzcwEJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUMa0Zhcm1pbmdBZGRyAA9tb25leUJveEFkZHJlc3MJAQdBZGRyZXNzAQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBRBrTW9uZXlCb3hBZGRyZXNzAARVU0ROCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDGtVU0ROQXNzZXRJZAAEU1dPUAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQtmYXJtaW5nQWRkcgUHa1NXT1BpZAEIaXNBY3RpdmUAAwMFBmFjdGl2ZQUKYWN0aXZlR2xvYgcFBHVuaXQJAAIBAh9EQXBwIGlzIGluYWN0aXZlIGF0IHRoaXMgbW9tZW50AQtpc0FkbWluQ2FsbAEBaQMJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFDGFkbWluUHViS2V5MQkAzAgCBQxhZG1pblB1YktleTIJAMwIAgUMYWRtaW5QdWJLZXkzBQNuaWwIBQFpD2NhbGxlclB1YmxpY0tleQUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEMZ2V0QXNzZXRJbmZvAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwAwkBCWlzRGVmaW5lZAEJAOwHAQUCaWQECHN0cmluZ0lkCQDYBAEFAmlkBARpbmZvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQUCaWQJAKwCAgkArAICAgZBc3NldCAFCHN0cmluZ0lkAg4gZG9lc24ndCBleGlzdAkAlQoDBQhzdHJpbmdJZAgFBGluZm8EbmFtZQgFBGluZm8IZGVjaW1hbHMJAAIBAhRBc3NldCBpcyBub3QgZGVmaW5lZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAkAlQoDAgVXQVZFUwIFV0FWRVMACAkAAgECC01hdGNoIGVycm9yARJpc0FjdGl2ZVBvb2xFeGlzdHMDBXBvb2xzBmFzc2V0QQZhc3NldEIECXBvb2xzRGF0YQkAtQkCBQVwb29scwIBXwQMaXNQb29sRGVmaW5lCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzBQVwb29scwMDBQxpc1Bvb2xEZWZpbmUJAQIhPQIFBXBvb2xzAgAHBAZ2b3RpbmcJAJEDAgUJcG9vbHNEYXRhAAIECG5ld1Bvb2xzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUGYXNzZXRBAgFfBQZhc3NldEICAV8FBnZvdGluZwUIdm90aW5nSWQED2lzTmV3UG9vbERlZmluZQkBCWlzRGVmaW5lZAEJAJoIAgUEdGhpcwUIbmV3UG9vbHMEDmhlaWdodE9mVm90aW5nCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUGdm90aW5nBQ1rSGVpZ2h0T2ZQb29sAAAEDnN0YXR1c09mVm90aW5nCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJAKwCAgUGdm90aW5nBQ9rU3RhdHVzT2ZWb3RpbmcGAwUPaXNOZXdQb29sRGVmaW5lAwkAZgIFDmhlaWdodE9mVm90aW5nBQZoZWlnaHQDBQ5zdGF0dXNPZlZvdGluZwYHBwcHARRpc1VuYWN0aXZlUG9vbEV4aXN0cwEKcG9vbHNTdGF0ZQQFcG9vbHMJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwUKcG9vbHNTdGF0ZQIABAlwb29sc0RhdGEJALUJAgUFcG9vbHMCAV8EDGlzUG9vbERlZmluZQkBCWlzRGVmaW5lZAEJAJoIAgUEdGhpcwUFcG9vbHMDAwUMaXNQb29sRGVmaW5lCQECIT0CBQVwb29scwIABwQGdm90aW5nCQCRAwIFCXBvb2xzRGF0YQACBA5oZWlnaHRPZlZvdGluZwkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBnZvdGluZwUNa0hlaWdodE9mUG9vbAAABA5zdGF0dXNPZlZvdGluZwkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzCQCsAgIFBnZvdGluZwUPa1N0YXR1c09mVm90aW5nBgMJAGYCBQ5oZWlnaHRPZlZvdGluZwUGaGVpZ2h0AwUOc3RhdHVzT2ZWb3RpbmcCAAUKcG9vbHNTdGF0ZQUKcG9vbHNTdGF0ZQUKcG9vbHNTdGF0ZQEWaXNMYXN0QWN0aXZlUG9vbEV4aXN0cwIGYXNzZXRBBmFzc2V0QgMDCQESaXNBY3RpdmVQb29sRXhpc3RzAwUPZmlyc3RBY3RpdmVWb3RlBQZhc3NldEEFBmFzc2V0QgYJARJpc0FjdGl2ZVBvb2xFeGlzdHMDBRBzZWNvbmRBY3RpdmVWb3RlBQZhc3NldEEFBmFzc2V0QgYJARJpc0FjdGl2ZVBvb2xFeGlzdHMDBQ90aGlyZEFjdGl2ZVZvdGUFBmFzc2V0QQUGYXNzZXRCAQ1nZXRBY3RpdmVQb29sAQZ2b3RpbmcEDmhlaWdodE9mVm90aW5nCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkApAMBBQZ2b3RpbmcFDWtIZWlnaHRPZlBvb2wAAAQOc3RhdHVzT2ZWb3RpbmcJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICCQCkAwEFBnZvdGluZwUPa1N0YXR1c09mVm90aW5nBgQNY3VycmVudEhlaWdodAUGaGVpZ2h0AwkAZgIAAAUGdm90aW5nAAADCQEBIQEFDnN0YXR1c09mVm90aW5nAAADCQBmAgUOaGVpZ2h0T2ZWb3RpbmcFDWN1cnJlbnRIZWlnaHQAAQAAARlnZXRBY3RpdmVWb3RpbmdQb29sQW1vdW50AAkAZAIJAGQCCQENZ2V0QWN0aXZlUG9vbAEJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUPZmlyc3RBY3RpdmVWb3RlAP///////////wEJAQ1nZXRBY3RpdmVQb29sAQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBRBzZWNvbmRBY3RpdmVWb3RlAP///////////wEJAQ1nZXRBY3RpdmVQb29sAQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQ90aGlyZEFjdGl2ZVZvdGUA////////////AQEVZ2V0VW5hY3RpdmVWb3RpbmdQb29sAAMJAQIhPQIJARRpc1VuYWN0aXZlUG9vbEV4aXN0cwEFD2FjdGl2ZVZvdGVGaXJzdAIABQ9hY3RpdmVWb3RlRmlyc3QDCQECIT0CCQEUaXNVbmFjdGl2ZVBvb2xFeGlzdHMBBRBhY3RpdmVWb3RlU2Vjb25kAgAFEGFjdGl2ZVZvdGVTZWNvbmQDCQECIT0CCQEUaXNVbmFjdGl2ZVBvb2xFeGlzdHMBBQ9hY3RpdmVWb3RlVGhpcmQCAAUPYWN0aXZlVm90ZVRoaXJkAgABFmdldEFzc2V0SW5mb0Zyb21TdHJpbmcBCGFzc2V0U3RyAwkAAAIFCGFzc2V0U3RyAgVXQVZFUwUEdW5pdAkA2QQBBQhhc3NldFN0cgEUaXNDYWxsZXJJbkdvdmVybmFuY2UBBHVzZXIDCQBmAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQpnb3ZBZGRyZXNzCQCsAgIJAKUIAQUEdXNlcgUPa1VzZXJUb3RhbEdTV09QAAAAAAYHAQdzdXNwZW5kAQVjYXVzZQkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQcJAMwIAgkBC1N0cmluZ0VudHJ5AgUGa0NhdXNlBQVjYXVzZQUDbmlsBgFpAQRpbml0AAMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECK09ubHkgdGhlIERBcHAgaXRzZWxmIGNhbiBjYWxsIHRoaXMgZnVuY3Rpb24DCQEJaXNEZWZpbmVkAQkAmwgCBQR0aGlzBQdrQWN0aXZlCQACAQIWREFwcCBpcyBhbHJlYWR5IGFjdGl2ZQQSaW5pdE51bWJlck9mVm90aW5nAAAEEmluaXRBbW91bnRPZlZvdGluZwAABA1pbml0S2V5QWN0aXZlBgQKYWN0aXZlSW5pdAIACQDMCAIJAQtTdHJpbmdFbnRyeQIFCGtWZXJzaW9uBQd2ZXJzaW9uCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBQ1pbml0S2V5QWN0aXZlCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9rTnVtYmVyT2ZWb3RpbmcFEmluaXROdW1iZXJPZlZvdGluZwkAzAgCCQEMSW50ZWdlckVudHJ5AgUPa0Ftb3VudE9mVm90aW5nBRJpbml0QW1vdW50T2ZWb3RpbmcJAMwIAgkBDEludGVnZXJFbnRyeQIFEmtNYXhBbW91bnRPZlZvdGluZwURbWF4QW1vdW50T2ZWb3RpbmcJAMwIAgkBDEludGVnZXJFbnRyeQIFD2tNYXhEYXlPZlZvdGluZwUObWF4RGF5T2ZWb3RpbmcJAMwIAgkBC1N0cmluZ0VudHJ5AgUPYWN0aXZlVm90ZUZpcnN0BQphY3RpdmVJbml0CQDMCAIJAQtTdHJpbmdFbnRyeQIFEGFjdGl2ZVZvdGVTZWNvbmQFCmFjdGl2ZUluaXQJAMwIAgkBC1N0cmluZ0VudHJ5AgUPYWN0aXZlVm90ZVRoaXJkBQphY3RpdmVJbml0BQNuaWwBaQEUaW5pdFZvdGluZ0Zvck5ld1Bvb2wCBmFzc2V0QQZhc3NldEIJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAECyR0MDcwNjQ3MTM5CQCUCgIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQECXBtdEFtb3VudAgFCyR0MDcwNjQ3MTM5Al8xBApwbXRBc3NldElkCAULJHQwNzA2NDcxMzkCXzIECyR0MDcxNDQ3MjQzCQCUCgIJARZnZXRBc3NldEluZm9Gcm9tU3RyaW5nAQUGYXNzZXRBCQEWZ2V0QXNzZXRJbmZvRnJvbVN0cmluZwEFBmFzc2V0QgQMcG9vbEFzc2V0SWRBCAULJHQwNzE0NDcyNDMCXzEEDHBvb2xBc3NldElkQggFCyR0MDcxNDQ3MjQzAl8yBAx1bmFjdGl2ZVZvdGUJARVnZXRVbmFjdGl2ZVZvdGluZ1Bvb2wABBFuZXdOdW1iZXJPZlZvdGluZwkBGWdldEFjdGl2ZVZvdGluZ1Bvb2xBbW91bnQABAxpc1Bvb2xFeGlzdHMJARZpc0xhc3RBY3RpdmVQb29sRXhpc3RzAgUGYXNzZXRBBQZhc3NldEIECyR0MDc0MTM3NDkxCQEMZ2V0QXNzZXRJbmZvAQUMcG9vbEFzc2V0SWRBBA5wbXRTdHJBc3NldElkQQgFCyR0MDc0MTM3NDkxAl8xBA1wbXRBc3NldE5hbWVBCAULJHQwNzQxMzc0OTECXzIEDHBtdERlY2ltYWxzQQgFCyR0MDc0MTM3NDkxAl8zBAskdDA3NDk2NzU3NAkBDGdldEFzc2V0SW5mbwEFDHBvb2xBc3NldElkQgQOcG10U3RyQXNzZXRJZEIIBQskdDA3NDk2NzU3NAJfMQQNcG10QXNzZXROYW1lQggFCyR0MDc0OTY3NTc0Al8yBAxwbXREZWNpbWFsc0IIBQskdDA3NDk2NzU3NAJfMwMJAAACBQxwb29sQXNzZXRJZEEFDHBvb2xBc3NldElkQgkAAgECGEFzc2V0cyBtdXN0IGJlIGRpZmZlcmVudAMFDGlzUG9vbEV4aXN0cwkAAgECGFRoaXMgcG9vbCBhbHJlYWR5IGV4aXN0cwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECG09uZSBhdHRhY2hlZCBhc3NldCBleHBlY3RlZAMJAQIhPQIFCnBtdEFzc2V0SWQFBFNXT1AJAAIBAhlZb3UgbXVzdCB1c2UgYSBTV09QIHRva2VuAwMJAAACBQZhc3NldEECAAYJAAACBQZhc3NldEICAAkAAgECFUFzc2V0cyBjYW4ndCBiZSBlbXB0eQMJAQIhPQIFCXBtdEFtb3VudAUhY29taXNzaW9uRm9ySW5pdGFsaXphdGlvbk9mVm90aW5nCQACAQIhWW91IG5lZWQgdG8gYXR0YWNoIDEwIFNXT1AgdG9rZW5zAwkBASEBAwMJAAACBQxwb29sQXNzZXRJZEIFBFVTRE4GCQAAAgUMcG9vbEFzc2V0SWRCBQR1bml0BgkAAAIFDHBvb2xBc3NldElkQgUEU1dPUAkAAgECImFzc2V0QiBtdXN0IGJlIFVTRE4sIFdBVkVTIG9yIFNXT1ADAwkAZgIJAGQCBRFuZXdOdW1iZXJPZlZvdGluZwABBRFtYXhBbW91bnRPZlZvdGluZwYJAAACBQx1bmFjdGl2ZVZvdGUCAAkAAgEJAKwCAgIkVG9vIG1hbnkgdm90aW5ncy4gTWF4aW11bSBxdWFudGl0eTogCQCkAwEFEW1heEFtb3VudE9mVm90aW5nCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUGYXNzZXRBAgFfBQZhc3NldEICAV8JAKQDAQUOYW1vdW50T2ZWb3RpbmcFCHZvdGluZ0lkBQ5hbW91bnRPZlZvdGluZwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCkAwEFDmFtb3VudE9mVm90aW5nBQ1rSGVpZ2h0T2ZQb29sCQBkAgUGaGVpZ2h0BRJ2b3RpbmdQZXJpb2RMZW5ndGgJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAKwCAgkApAMBBQ5hbW91bnRPZlZvdGluZwUPa1N0YXR1c09mVm90aW5nBgkAzAgCCQEMSW50ZWdlckVudHJ5AgUPa0Ftb3VudE9mVm90aW5nCQBkAgUOYW1vdW50T2ZWb3RpbmcAAQkAzAgCCQEMSW50ZWdlckVudHJ5AgUPa051bWJlck9mVm90aW5nCQBkAgURbmV3TnVtYmVyT2ZWb3RpbmcAAQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFBmFzc2V0QQUFa05hbWUFDXBtdEFzc2V0TmFtZUEJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICBQZhc3NldEIFBWtOYW1lBQ1wbXRBc3NldE5hbWVCCQDMCAIJAQtTdHJpbmdFbnRyeQIFDHVuYWN0aXZlVm90ZQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBmFzc2V0QQIBXwUGYXNzZXRCAgFfCQCkAwEFDmFtb3VudE9mVm90aW5nBQh2b3RpbmdJZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQ9tb25leUJveEFkZHJlc3MFCXBtdEFtb3VudAUKcG10QXNzZXRJZAUDbmlsAWkBC3ZvdGVGb3JQb29sAwZ2b3RpbmcHeWVzT3JObwd2b3RlQW10CQELdmFsdWVPckVsc2UCCQEIaXNBY3RpdmUABA1jdXJyZW50SGVpZ2h0BQZoZWlnaHQEDnBvb2xJbml0SGVpZ2h0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgkApAMBBQZ2b3RpbmcFDWtIZWlnaHRPZlBvb2wCEUVtcHR5IHBvb2wgaGVpZ2h0BA5zdGF0dXNPZlZvdGluZwkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzCQCsAgIJAKQDAQUGdm90aW5nBQ9rU3RhdHVzT2ZWb3RpbmcGBBR1c2VyU1dPUGluR292ZXJuYW5jZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQpnb3ZBZGRyZXNzCQCsAgIJAKUIAQgFAWkGY2FsbGVyBQ9rVXNlclRvdGFsR1NXT1AAAAQNdG90YWxWb3RlVXNlcgMFB3llc09yTm8JAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBnZvdGluZwUHa05vVXNlcgAABQd2b3RlQW10CQBkAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIBXwkApAMBBQZ2b3RpbmcFCGtZZXNVc2VyAAAFB3ZvdGVBbXQDCQEBIQEJARRpc0NhbGxlckluR292ZXJuYW5jZQEIBQFpBmNhbGxlcgkAAgECKlRoaXMgYWRkcmVzcyBoYXMgMCBTV09QIGluIEdvdmVybmFuY2UgZEFwcAMJAQEhAQUOc3RhdHVzT2ZWb3RpbmcJAAIBAhhUaGlzIHZvdGluZyB3YXMgY2FuY2VsZWQDCQBmAgUNY3VycmVudEhlaWdodAUOcG9vbEluaXRIZWlnaHQJAAIBAhdUaGlzIHZvdGluZyB3YXMgZXhwaXJlZAMJAGYCAAAFB3ZvdGVBbXQJAAIBAiRUaGUgbnVtYmVyIG9mIHZvdGVzIG11c3QgYmUgcG9zaXRpdmUDCQBmAgUNdG90YWxWb3RlVXNlcgUUdXNlclNXT1BpbkdvdmVybmFuY2UJAAIBCQCsAgIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIFIGhhcyAJAKQDAQUUdXNlclNXT1BpbkdvdmVybmFuY2UCFSBHU1dPUCBpbiBnb3Zlcm5hbmNlLgMFB3llc09yTm8EC29sZFZvdGVVc2VyCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBnZvdGluZwUIa1llc1VzZXIAAAQHbmV3Vm90ZQkAZAIJAGUCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkApAMBBQZ2b3RpbmcFBGtZZXMAAAULb2xkVm90ZVVzZXIFB3ZvdGVBbXQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkApAMBBQZ2b3RpbmcFBGtZZXMFB25ld1ZvdGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBnZvdGluZwUIa1llc1VzZXIFB3ZvdGVBbXQFA25pbAQLb2xkVm90ZVVzZXIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUGdm90aW5nBQdrTm9Vc2VyAAAEB25ld1ZvdGUJAGQCCQBlAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIJAKQDAQUGdm90aW5nBQNrTm8AAAULb2xkVm90ZVVzZXIFB3ZvdGVBbXQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkApAMBBQZ2b3RpbmcFA2tObwUHbmV3Vm90ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUGdm90aW5nBQdrTm9Vc2VyBQd2b3RlQW10BQNuaWwBaQEMY2FuY2VsVm90aW5nAgZ2b3RpbmcFY2F1c2UJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEDnN0YXR1c09mVm90aW5nCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJAKwCAgkApAMBBQZ2b3RpbmcFD2tTdGF0dXNPZlZvdGluZwYDCQEBIQEFDnN0YXR1c09mVm90aW5nCQACAQkArAICCQCsAgICB1ZvdGluZyAJAKQDAQUGdm90aW5nAhkgaGFzIGFscmVhZHkgYmVlbiBzdG9wcGVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQ9rTnVtYmVyT2ZWb3RpbmcJAGUCBQ5udW1iZXJPZlZvdGluZwABCQDMCAIJAQxCb29sZWFuRW50cnkCCQCsAgIJAKQDAQUGdm90aW5nBQ9rU3RhdHVzT2ZWb3RpbmcHCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkApAMBBQZ2b3RpbmcFDGtDYW5jZWxDYXVzZQUFY2F1c2UFA25pbAFpAQhzaHV0ZG93bgAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDCQEBIQEFBmFjdGl2ZQkAAgEJAKwCAgIiREFwcCBpcyBhbHJlYWR5IHN1c3BlbmRlZC4gQ2F1c2U6IAkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQZrQ2F1c2UCGnRoZSBjYXVzZSB3YXNuJ3Qgc3BlY2lmaWVkCQEHc3VzcGVuZAECD1BhdXNlZCBieSBhZG1pbgFpAQhhY3RpdmF0ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDBQZhY3RpdmUJAAIBAhZEQXBwIGlzIGFscmVhZHkgYWN0aXZlCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBgkAzAgCCQELRGVsZXRlRW50cnkBBQZrQ2F1c2UFA25pbAECdHgBBnZlcmlmeQAEEmFkbWluUHViS2V5MVNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFDGFkbWluUHViS2V5MQABAAAEEmFkbWluUHViS2V5MlNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFDGFkbWluUHViS2V5MgABAAAEEmFkbWluUHViS2V5M1NpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAIFDGFkbWluUHViS2V5MwABAAAJAGcCCQBkAgkAZAIFEmFkbWluUHViS2V5MVNpZ25lZAUSYWRtaW5QdWJLZXkyU2lnbmVkBRJhZG1pblB1YktleTNTaWduZWQAAjpKtPU=", "height": 2418951, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: CASrHiWAPJ7kDzihqwofETm427Ks23cZM9wtQpG4HRVW Next: 5YSCxJxKnqqKT9DMV1jdBrzne3AEoZDupJPVp4UAT9kS Full:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let oracle = Address(base58'3MvVBtsXroQpy1tsPw21TU2ET9A8WfmrNjz') | |
5 | 5 | ||
6 | 6 | let version = "1.0.0" | |
7 | 7 | ||
8 | 8 | let kVersion = "version" | |
9 | 9 | ||
10 | 10 | let kActive = "active" | |
11 | 11 | ||
12 | 12 | let kActiveGlob = "active_all_contracts" | |
13 | 13 | ||
14 | 14 | let kNumberOfVoting = "voting_active_number" | |
15 | 15 | ||
16 | 16 | let kHeightOfPool = "_finish_height" | |
17 | 17 | ||
18 | 18 | let kNo = "_total_votes_no" | |
19 | 19 | ||
20 | 20 | let kYes = "_total_votes_yes" | |
21 | 21 | ||
22 | 22 | let kNoUser = "_vote_no" | |
23 | 23 | ||
24 | 24 | let kYesUser = "_vote_yes" | |
25 | 25 | ||
26 | 26 | let kStatusOfVoting = "_status" | |
27 | 27 | ||
28 | 28 | let kAmountOfVoting = "voting_id_last" | |
29 | 29 | ||
30 | 30 | let kMaxAmountOfVoting = "max_amount_voting" | |
31 | 31 | ||
32 | 32 | let kMaxDayOfVoting = "max_day_voting" | |
33 | 33 | ||
34 | 34 | let kCause = "shutdown_cause" | |
35 | 35 | ||
36 | 36 | let kCancelCause = "_cancel_cause" | |
37 | 37 | ||
38 | 38 | let kUserTotalGSWOP = "_GSwop_amount" | |
39 | 39 | ||
40 | 40 | let kName = "_asset_name" | |
41 | 41 | ||
42 | 42 | let votingId = "_voting" | |
43 | 43 | ||
44 | 44 | let activeVoteFirst = "voting_active_cell_1" | |
45 | 45 | ||
46 | 46 | let activeVoteSecond = "voting_active_cell_2" | |
47 | 47 | ||
48 | 48 | let activeVoteThird = "voting_active_cell_3" | |
49 | 49 | ||
50 | 50 | let kAdminPubKey1 = "admin_pub_1" | |
51 | 51 | ||
52 | 52 | let kAdminPubKey2 = "admin_pub_2" | |
53 | 53 | ||
54 | 54 | let kAdminPubKey3 = "admin_pub_3" | |
55 | 55 | ||
56 | 56 | let kMoneyBoxAddress = "money_box_address" | |
57 | 57 | ||
58 | 58 | let kGovAddress = "governance_address" | |
59 | 59 | ||
60 | 60 | let kFarmingAddr = "farming_address" | |
61 | 61 | ||
62 | 62 | let kUSDNAssetId = "usdn_asset_id" | |
63 | 63 | ||
64 | 64 | let kSWOPid = "SWOP_id" | |
65 | 65 | ||
66 | 66 | let numberOfVoting = getIntegerValue(this, kNumberOfVoting) | |
67 | 67 | ||
68 | 68 | let amountOfVoting = getIntegerValue(this, kAmountOfVoting) | |
69 | 69 | ||
70 | 70 | let firstActiveVote = valueOrElse(getString(this, activeVoteFirst), "") | |
71 | 71 | ||
72 | 72 | let secondActiveVote = valueOrElse(getString(this, activeVoteSecond), "") | |
73 | 73 | ||
74 | 74 | let thirdActiveVote = valueOrElse(getString(this, activeVoteThird), "") | |
75 | 75 | ||
76 | 76 | let active = getBooleanValue(this, kActive) | |
77 | 77 | ||
78 | 78 | let activeGlob = valueOrElse(getBoolean(oracle, kActiveGlob), true) | |
79 | 79 | ||
80 | 80 | let comissionForInitalizationOfVoting = 1000000000 | |
81 | 81 | ||
82 | 82 | let maxAmountOfVoting = 3 | |
83 | 83 | ||
84 | 84 | let maxDayOfVoting = 7 | |
85 | 85 | ||
86 | 86 | let votingPeriodLength = (1443 * maxDayOfVoting) | |
87 | 87 | ||
88 | 88 | func getBase58FromOracle (key) = match getString(oracle, key) { | |
89 | 89 | case string: String => | |
90 | 90 | fromBase58String(string) | |
91 | 91 | case nothing => | |
92 | 92 | throw((key + "is empty")) | |
93 | 93 | } | |
94 | 94 | ||
95 | 95 | ||
96 | 96 | let adminPubKey1 = getBase58FromOracle(kAdminPubKey1) | |
97 | 97 | ||
98 | 98 | let adminPubKey2 = getBase58FromOracle(kAdminPubKey2) | |
99 | 99 | ||
100 | 100 | let adminPubKey3 = getBase58FromOracle(kAdminPubKey3) | |
101 | 101 | ||
102 | 102 | let govAddress = Address(getBase58FromOracle(kGovAddress)) | |
103 | 103 | ||
104 | 104 | let farmingAddr = Address(getBase58FromOracle(kFarmingAddr)) | |
105 | 105 | ||
106 | 106 | let moneyBoxAddress = Address(getBase58FromOracle(kMoneyBoxAddress)) | |
107 | 107 | ||
108 | 108 | let USDN = getBase58FromOracle(kUSDNAssetId) | |
109 | 109 | ||
110 | 110 | let SWOP = fromBase58String(getStringValue(farmingAddr, kSWOPid)) | |
111 | 111 | ||
112 | 112 | func isActive () = if (if (active) | |
113 | 113 | then activeGlob | |
114 | 114 | else false) | |
115 | 115 | then unit | |
116 | 116 | else throw("DApp is inactive at this moment") | |
117 | 117 | ||
118 | 118 | ||
119 | 119 | func isAdminCall (i) = if (containsElement([adminPubKey1, adminPubKey2, adminPubKey3], i.callerPublicKey)) | |
120 | 120 | then unit | |
121 | 121 | else throw("Only admin can call this function") | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | func getAssetInfo (assetId) = match assetId { | |
125 | 125 | case id: ByteVector => | |
126 | 126 | if (isDefined(assetInfo(id))) | |
127 | 127 | then { | |
128 | 128 | let stringId = toBase58String(id) | |
129 | 129 | let info = valueOrErrorMessage(assetInfo(id), (("Asset " + stringId) + " doesn't exist")) | |
130 | 130 | $Tuple3(stringId, info.name, info.decimals) | |
131 | 131 | } | |
132 | 132 | else throw("Asset is not defined") | |
133 | 133 | case waves: Unit => | |
134 | 134 | $Tuple3("WAVES", "WAVES", 8) | |
135 | 135 | case _ => | |
136 | 136 | throw("Match error") | |
137 | 137 | } | |
138 | 138 | ||
139 | 139 | ||
140 | 140 | func isActivePoolExists (pools,assetA,assetB) = { | |
141 | 141 | let poolsData = split(pools, "_") | |
142 | 142 | let isPoolDefine = isDefined(getInteger(this, pools)) | |
143 | 143 | if (if (isPoolDefine) | |
144 | 144 | then (pools != "") | |
145 | 145 | else false) | |
146 | 146 | then { | |
147 | 147 | let voting = poolsData[2] | |
148 | 148 | let newPools = (((((assetA + "_") + assetB) + "_") + voting) + votingId) | |
149 | 149 | let isNewPoolDefine = isDefined(getInteger(this, newPools)) | |
150 | 150 | let heightOfVoting = valueOrElse(getInteger(this, (voting + kHeightOfPool)), 0) | |
151 | 151 | let statusOfVoting = valueOrElse(getBoolean(this, (voting + kStatusOfVoting)), true) | |
152 | 152 | if (isNewPoolDefine) | |
153 | 153 | then if ((heightOfVoting > height)) | |
154 | 154 | then if (statusOfVoting) | |
155 | 155 | then true | |
156 | 156 | else false | |
157 | 157 | else false | |
158 | 158 | else false | |
159 | 159 | } | |
160 | 160 | else false | |
161 | 161 | } | |
162 | 162 | ||
163 | 163 | ||
164 | 164 | func isUnactivePoolExists (poolsState) = { | |
165 | 165 | let pools = valueOrElse(getString(this, poolsState), "") | |
166 | 166 | let poolsData = split(pools, "_") | |
167 | 167 | let isPoolDefine = isDefined(getInteger(this, pools)) | |
168 | 168 | if (if (isPoolDefine) | |
169 | 169 | then (pools != "") | |
170 | 170 | else false) | |
171 | 171 | then { | |
172 | 172 | let voting = poolsData[2] | |
173 | 173 | let heightOfVoting = valueOrElse(getInteger(this, (voting + kHeightOfPool)), 0) | |
174 | 174 | let statusOfVoting = valueOrElse(getBoolean(this, (voting + kStatusOfVoting)), true) | |
175 | 175 | if ((heightOfVoting > height)) | |
176 | 176 | then if (statusOfVoting) | |
177 | 177 | then "" | |
178 | 178 | else poolsState | |
179 | 179 | else poolsState | |
180 | 180 | } | |
181 | 181 | else poolsState | |
182 | 182 | } | |
183 | 183 | ||
184 | 184 | ||
185 | 185 | func isLastActivePoolExists (assetA,assetB) = if (if (isActivePoolExists(firstActiveVote, assetA, assetB)) | |
186 | 186 | then true | |
187 | 187 | else isActivePoolExists(secondActiveVote, assetA, assetB)) | |
188 | 188 | then true | |
189 | 189 | else isActivePoolExists(thirdActiveVote, assetA, assetB) | |
190 | 190 | ||
191 | 191 | ||
192 | 192 | func getActivePool (voting) = { | |
193 | 193 | let heightOfVoting = valueOrElse(getInteger(this, (toString(voting) + kHeightOfPool)), 0) | |
194 | 194 | let statusOfVoting = valueOrElse(getBoolean(this, (toString(voting) + kStatusOfVoting)), true) | |
195 | 195 | let currentHeight = height | |
196 | 196 | if ((0 > voting)) | |
197 | 197 | then 0 | |
198 | 198 | else if (!(statusOfVoting)) | |
199 | 199 | then 0 | |
200 | 200 | else if ((heightOfVoting > currentHeight)) | |
201 | 201 | then 1 | |
202 | 202 | else 0 | |
203 | 203 | } | |
204 | 204 | ||
205 | 205 | ||
206 | 206 | func getActiveVotingPoolAmount () = ((getActivePool(valueOrElse(getInteger(this, firstActiveVote), -1)) + getActivePool(valueOrElse(getInteger(this, secondActiveVote), -1))) + getActivePool(valueOrElse(getInteger(this, thirdActiveVote), -1))) | |
207 | 207 | ||
208 | 208 | ||
209 | 209 | func getUnactiveVotingPool () = if ((isUnactivePoolExists(activeVoteFirst) != "")) | |
210 | 210 | then activeVoteFirst | |
211 | 211 | else if ((isUnactivePoolExists(activeVoteSecond) != "")) | |
212 | 212 | then activeVoteSecond | |
213 | 213 | else if ((isUnactivePoolExists(activeVoteThird) != "")) | |
214 | 214 | then activeVoteThird | |
215 | 215 | else "" | |
216 | 216 | ||
217 | 217 | ||
218 | 218 | func getAssetInfoFromString (assetStr) = if ((assetStr == "WAVES")) | |
219 | 219 | then unit | |
220 | 220 | else fromBase58String(assetStr) | |
221 | 221 | ||
222 | 222 | ||
223 | 223 | func isCallerInGovernance (user) = if ((valueOrElse(getInteger(govAddress, (toString(user) + kUserTotalGSWOP)), 0) > 0)) | |
224 | 224 | then true | |
225 | 225 | else false | |
226 | 226 | ||
227 | 227 | ||
228 | 228 | func suspend (cause) = [BooleanEntry(kActive, false), StringEntry(kCause, cause)] | |
229 | 229 | ||
230 | 230 | ||
231 | 231 | @Callable(i) | |
232 | 232 | func init () = if ((i.caller != this)) | |
233 | 233 | then throw("Only the DApp itself can call this function") | |
234 | 234 | else if (isDefined(getBoolean(this, kActive))) | |
235 | 235 | then throw("DApp is already active") | |
236 | 236 | else { | |
237 | 237 | let initNumberOfVoting = 0 | |
238 | 238 | let initAmountOfVoting = 0 | |
239 | 239 | let initKeyActive = true | |
240 | 240 | let activeInit = "" | |
241 | 241 | [StringEntry(kVersion, version), BooleanEntry(kActive, initKeyActive), IntegerEntry(kNumberOfVoting, initNumberOfVoting), IntegerEntry(kAmountOfVoting, initAmountOfVoting), IntegerEntry(kMaxAmountOfVoting, maxAmountOfVoting), IntegerEntry(kMaxDayOfVoting, maxDayOfVoting), StringEntry(activeVoteFirst, activeInit), StringEntry(activeVoteSecond, activeInit), StringEntry(activeVoteThird, activeInit)] | |
242 | 242 | } | |
243 | 243 | ||
244 | 244 | ||
245 | 245 | ||
246 | 246 | @Callable(i) | |
247 | 247 | func initVotingForNewPool (assetA,assetB) = valueOrElse(isActive(), { | |
248 | 248 | let $t070647139 = $Tuple2(i.payments[0].amount, i.payments[0].assetId) | |
249 | 249 | let pmtAmount = $t070647139._1 | |
250 | 250 | let pmtAssetId = $t070647139._2 | |
251 | 251 | let $t071447243 = $Tuple2(getAssetInfoFromString(assetA), getAssetInfoFromString(assetB)) | |
252 | 252 | let poolAssetIdA = $t071447243._1 | |
253 | 253 | let poolAssetIdB = $t071447243._2 | |
254 | 254 | let unactiveVote = getUnactiveVotingPool() | |
255 | 255 | let newNumberOfVoting = getActiveVotingPoolAmount() | |
256 | 256 | let isPoolExists = isLastActivePoolExists(assetA, assetB) | |
257 | 257 | let $t074137491 = getAssetInfo(poolAssetIdA) | |
258 | 258 | let pmtStrAssetIdA = $t074137491._1 | |
259 | 259 | let pmtAssetNameA = $t074137491._2 | |
260 | 260 | let pmtDecimalsA = $t074137491._3 | |
261 | 261 | let $t074967574 = getAssetInfo(poolAssetIdB) | |
262 | 262 | let pmtStrAssetIdB = $t074967574._1 | |
263 | 263 | let pmtAssetNameB = $t074967574._2 | |
264 | 264 | let pmtDecimalsB = $t074967574._3 | |
265 | 265 | if ((poolAssetIdA == poolAssetIdB)) | |
266 | 266 | then throw("Assets must be different") | |
267 | 267 | else if (isPoolExists) | |
268 | 268 | then throw("This pool already exists") | |
269 | 269 | else if ((size(i.payments) != 1)) | |
270 | 270 | then throw("One attached asset expected") | |
271 | 271 | else if ((pmtAssetId != SWOP)) | |
272 | 272 | then throw("You must use a SWOP token") | |
273 | 273 | else if (if ((assetA == "")) | |
274 | 274 | then true | |
275 | 275 | else (assetB == "")) | |
276 | 276 | then throw("Assets can't be empty") | |
277 | 277 | else if ((pmtAmount != comissionForInitalizationOfVoting)) | |
278 | 278 | then throw("You need to attach 10 SWOP tokens") | |
279 | 279 | else if (!(if (if ((poolAssetIdB == USDN)) | |
280 | 280 | then true | |
281 | 281 | else (poolAssetIdB == unit)) | |
282 | 282 | then true | |
283 | 283 | else (poolAssetIdB == SWOP))) | |
284 | 284 | then throw("assetB must be USDN, WAVES or SWOP") | |
285 | 285 | else if (if (((newNumberOfVoting + 1) > maxAmountOfVoting)) | |
286 | 286 | then true | |
287 | 287 | else (unactiveVote == "")) | |
288 | 288 | then throw(("Too many votings. Maximum quantity: " + toString(maxAmountOfVoting))) | |
289 | 289 | else [IntegerEntry((((((assetA + "_") + assetB) + "_") + toString(amountOfVoting)) + votingId), amountOfVoting), IntegerEntry((toString(amountOfVoting) + kHeightOfPool), (height + votingPeriodLength)), BooleanEntry((toString(amountOfVoting) + kStatusOfVoting), true), IntegerEntry(kAmountOfVoting, (amountOfVoting + 1)), IntegerEntry(kNumberOfVoting, (newNumberOfVoting + 1)), StringEntry((assetA + kName), pmtAssetNameA), StringEntry((assetB + kName), pmtAssetNameB), StringEntry(unactiveVote, (((((assetA + "_") + assetB) + "_") + toString(amountOfVoting)) + votingId)), ScriptTransfer(moneyBoxAddress, pmtAmount, pmtAssetId)] | |
290 | 290 | }) | |
291 | 291 | ||
292 | 292 | ||
293 | 293 | ||
294 | 294 | @Callable(i) | |
295 | 295 | func voteForPool (voting,yesOrNo,voteAmt) = valueOrElse(isActive(), { | |
296 | 296 | let currentHeight = height | |
297 | 297 | let poolInitHeight = valueOrErrorMessage(getIntegerValue(this, (toString(voting) + kHeightOfPool)), "Empty pool height") | |
298 | 298 | let statusOfVoting = valueOrElse(getBoolean(this, (toString(voting) + kStatusOfVoting)), true) | |
299 | 299 | let userSWOPinGovernance = valueOrElse(getInteger(govAddress, (toString(i.caller) + kUserTotalGSWOP)), 0) | |
300 | 300 | let totalVoteUser = if (yesOrNo) | |
301 | 301 | then (valueOrElse(getInteger(this, (((toString(i.caller) + "_") + toString(voting)) + kNoUser)), 0) + voteAmt) | |
302 | 302 | else (valueOrElse(getInteger(this, (((toString(i.caller) + "_") + toString(voting)) + kYesUser)), 0) + voteAmt) | |
303 | 303 | if (!(isCallerInGovernance(i.caller))) | |
304 | 304 | then throw("This address has 0 SWOP in Governance dApp") | |
305 | 305 | else if (!(statusOfVoting)) | |
306 | 306 | then throw("This voting was canceled") | |
307 | 307 | else if ((currentHeight > poolInitHeight)) | |
308 | 308 | then throw("This voting was expired") | |
309 | 309 | else if ((0 > voteAmt)) | |
310 | 310 | then throw("The number of votes must be positive") | |
311 | 311 | else if ((totalVoteUser > userSWOPinGovernance)) | |
312 | 312 | then throw((((toString(i.caller) + " has ") + toString(userSWOPinGovernance)) + " GSWOP in governance.")) | |
313 | 313 | else if (yesOrNo) | |
314 | 314 | then { | |
315 | 315 | let oldVoteUser = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + toString(voting)) + kYesUser)), 0) | |
316 | 316 | let newVote = ((valueOrElse(getInteger(this, (toString(voting) + kYes)), 0) - oldVoteUser) + voteAmt) | |
317 | 317 | [IntegerEntry((toString(voting) + kYes), newVote), IntegerEntry((((toString(i.caller) + "_") + toString(voting)) + kYesUser), voteAmt)] | |
318 | 318 | } | |
319 | 319 | else { | |
320 | 320 | let oldVoteUser = valueOrElse(getInteger(this, (((toString(i.caller) + "_") + toString(voting)) + kNoUser)), 0) | |
321 | 321 | let newVote = ((valueOrElse(getInteger(this, (toString(voting) + kNo)), 0) - oldVoteUser) + voteAmt) | |
322 | 322 | [IntegerEntry((toString(voting) + kNo), newVote), IntegerEntry((((toString(i.caller) + "_") + toString(voting)) + kNoUser), voteAmt)] | |
323 | 323 | } | |
324 | 324 | }) | |
325 | 325 | ||
326 | 326 | ||
327 | 327 | ||
328 | 328 | @Callable(i) | |
329 | 329 | func cancelVoting (voting,cause) = valueOrElse(isAdminCall(i), { | |
330 | 330 | let statusOfVoting = valueOrElse(getBoolean(this, (toString(voting) + kStatusOfVoting)), true) | |
331 | 331 | if (!(statusOfVoting)) | |
332 | 332 | then throw((("Voting " + toString(voting)) + " has already been stopped")) | |
333 | 333 | else [IntegerEntry(kNumberOfVoting, (numberOfVoting - 1)), BooleanEntry((toString(voting) + kStatusOfVoting), false), StringEntry((toString(voting) + kCancelCause), cause)] | |
334 | 334 | }) | |
335 | 335 | ||
336 | 336 | ||
337 | 337 | ||
338 | 338 | @Callable(i) | |
339 | 339 | func shutdown () = valueOrElse(isAdminCall(i), if (!(active)) | |
340 | 340 | then throw(("DApp is already suspended. Cause: " + valueOrElse(getString(this, kCause), "the cause wasn't specified"))) | |
341 | 341 | else suspend("Paused by admin")) | |
342 | 342 | ||
343 | 343 | ||
344 | 344 | ||
345 | 345 | @Callable(i) | |
346 | 346 | func activate () = valueOrElse(isAdminCall(i), if (active) | |
347 | 347 | then throw("DApp is already active") | |
348 | 348 | else [BooleanEntry(kActive, true), DeleteEntry(kCause)]) | |
349 | 349 | ||
350 | 350 | ||
351 | 351 | @Verifier(tx) | |
352 | 352 | func verify () = { | |
353 | 353 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
354 | 354 | then 1 | |
355 | 355 | else 0 | |
356 | 356 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
357 | 357 | then 1 | |
358 | 358 | else 0 | |
359 | 359 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
360 | 360 | then 1 | |
361 | 361 | else 0 | |
362 | 362 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
363 | 363 | } | |
364 | 364 |
github/deemru/w8io/169f3d6 55.18 ms ◑