2022.07.28 15:19 [3225160] smart account 3PJKKT7gsWiPBJj11gkF3Xv7gKt8s2WPdTr > SELF 0.00000000 Waves

{ "type": 13, "id": "7j9MVKoVvcrjGzez3tMkEWvqB1cMUBmvetZ6iLicQbsz", "fee": 1100000, "feeAssetId": null, "timestamp": 1659010752658, "version": 1, "sender": "3PJKKT7gsWiPBJj11gkF3Xv7gKt8s2WPdTr", "senderPublicKey": "FAqqjX7JqvqLh2QGTR3ziyCnSsWSoj9gVo4uPahtmhKr", "proofs": [ "k6zabeodiKhmagN9SQb7qghixMeuPp32WT4xMQmbqnsQMDJ65AcHRc9X4e8dshrpxXCfLiB3vuwPTSxsrnvN6dr" ], "script": "base64:BgIpCAISAwoBCBIAEgMKAQgSABIDCgEIEgUKAwgIARIECgIICBIFCgMICAEoAQd0aHJvd0lmAgljb25kaXRpb24FZXJyb3IDBQljb25kaXRpb24JAAIBBQVlcnJvcgYBCHdyaXRlSW50AgNrZXkFdmFsdWUDCQBmAgAABQV2YWx1ZQkAAgEJAKwCAgkArAICCQCsAgICF3dyaXRpbmcgbmVnYXRpdmUgdmFsdWUgCQCkAwEFBXZhbHVlAgkgZm9yIGtleSAFA2tleQkBDEludGVnZXJFbnRyeQIFA2tleQUFdmFsdWUBCGNoYW5nZUJ5AgNrZXkFdmFsdWUJAQh3cml0ZUludAIFA2tleQkAZAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUDa2V5AAAFBXZhbHVlAQxmcmFjdGlvbkNlaWwDBXZhbHVlCW51bWVyYXRvcgtkZW5vbWluYXRvcgQEY2FuZAkAawMFBXZhbHVlBQludW1lcmF0b3IFC2Rlbm9taW5hdG9yBAFEALPmk6gLBAVleGFjdAkAAAIJAGoCCQBoAgkAagIFBGNhbmQFAUQJAGoCBQtkZW5vbWluYXRvcgUBRAUBRAkAagIJAGgCCQBqAgUFdmFsdWUFAUQJAGoCBQludW1lcmF0b3IFAUQFAUQDBQVleGFjdAUEY2FuZAkAZAIFBGNhbmQAAQEQd3JpdGVDb25zdFN0cmluZwIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzBQNrZXkJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUJAAIBCQCsAgICFWFscmVhZHkgaW5pdGlhbGl6ZWQ6IAUDa2V5ABJjb25maWdBZGRyZXNzU3RvcmUCDWNvbmZpZ0FkZHJlc3MAC29yYWNsZVN0b3JlAg5vcmFjbGVfYWRkcmVzcwEScmVzZXJ2ZUZhY3RvclN0b3JlAQdhc3NldElkCQCsAgIFB2Fzc2V0SWQCDl9SZXNlcnZlRmFjdG9yAAltYWluU3RvcmUCBG1haW4ADWNvbmZpZ0FkZHJlc3MJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUSY29uZmlnQWRkcmVzc1N0b3JlAiNwcm90ZWN0ZWQtcmVzZXJ2ZTogbm8gY29uZmlnQWRkcmVzcwIWaW52YWxpZCBjb25maWcgYWRkcmVzcwENcmVzZXJ2ZUZhY3RvcgEHYXNzZXRJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MJARJyZXNlcnZlRmFjdG9yU3RvcmUBBQdhc3NldElkAhBubyByZXNlcnZlRmFjdG9yAQpnZXRCYWxhbmNlAg5hZGRyZXNzT3JBbGlhcwdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmJ2BQckbWF0Y2gwCQDwBwIFDmFkZHJlc3NPckFsaWFzBQJidgMJAAECBQckbWF0Y2gwAgRVbml0BAF1BQckbWF0Y2gwCAkA7wcBBQ5hZGRyZXNzT3JBbGlhcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgEJb3BBbGxvd2VkAgdhc3NldElkAm9wBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCBQdhc3NldElkCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvABJtYXliZU9yYWNsZUFkZHJlc3MEByRtYXRjaDAJAJ0IAgUNY29uZmlnQWRkcmVzcwULb3JhY2xlU3RvcmUDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQCmCAEFAXMFBHVuaXQBC29yYWNsZVByaWNlAQdhc3NldElkBAckbWF0Y2gwCQD8BwQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgUSbWF5YmVPcmFjbGVBZGRyZXNzAglubyBvcmFjbGUCBXByaWNlCQDMCAIFB2Fzc2V0SWQFA25pbAUDbmlsAwkAAQIFByRtYXRjaDACA0ludAQBaQUHJG1hdGNoMAUBaQkAAgECD2JhZCBvcmFjbGUgZGF0YQAGSEVJR0hUBQZoZWlnaHQABmFzc2V0cwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhhwcm90ZWN0ZWRfcmVzZXJ2ZV9hc3NldHMCAAALYXNzZXRzQXJyYXkDCQAAAgUGYXNzZXRzAgAFA25pbAkAvAkCBQZhc3NldHMCAXwBEXRvdGFsRGVwb3NpdFN0b3JlAQdhc3NldElkCQCsAgICDHRvdGFsU3VwcGx5XwUHYXNzZXRJZAEQdG90YWxTaGFyZXNTdG9yZQEHYXNzZXRJZAkArAICAgx0b3RhbFNoYXJlc18FB2Fzc2V0SWQBD3VzZXJTaGFyZXNTdG9yZQIHYXNzZXRJZAR1c2VyCQCsAgIJAKwCAgkArAICAgt1c2VyU2hhcmVzXwUHYXNzZXRJZAIBXwUEdXNlcgERaGFzUHJvdGVjdGVkU3RvcmUBBHVzZXIJAKwCAgIVcHJvdGVjdGVkX2NvbGxhdGVyYWxfBQR1c2VyARNwcm90ZWN0ZWRBc3NldFN0b3JlAQR1c2VyCQCsAgICEHByb3RlY3RlZF9hc3NldF8FBHVzZXIBDHRvdGFsRGVwb3NpdAEHYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAnwgBCQERdG90YWxEZXBvc2l0U3RvcmUBBQdhc3NldElkAAABC3RvdGFsU2hhcmVzAQdhc3NldElkCQELdmFsdWVPckVsc2UCCQCfCAEJARB0b3RhbFNoYXJlc1N0b3JlAQUHYXNzZXRJZAAAAQp1c2VyU2hhcmVzAgdhc3NldElkBHVzZXIJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBD3VzZXJTaGFyZXNTdG9yZQIFB2Fzc2V0SWQFBHVzZXIAAAELdXNlckRlcG9zaXQCB2Fzc2V0SWQEdXNlcgQCdHMJAQt0b3RhbFNoYXJlcwEFB2Fzc2V0SWQEAnRkCQEMdG90YWxEZXBvc2l0AQUHYXNzZXRJZAQCdXMJAQp1c2VyU2hhcmVzAgUHYXNzZXRJZAUEdXNlcgMJAAACBQJ0cwAAAAAJAGsDBQJ0ZAUCdXMFAnRzARFoYXNSZWd1bGFyRGVwb3NpdAEEdXNlcgQIcmVz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JGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAEOc2hhcmVzVG9BbW91bnQCB2Fzc2V0SWQGc2hhcmVzBAJ0cwkBC3RvdGFsU2hhcmVzAQUHYXNzZXRJZAQCdGQJAQx0b3RhbERlcG9zaXQBBQdhc3NldElkAwMJAAACBQJ0cwAABgkAAAIFAnRkAAAFBnNoYXJlcwkAawMFBnNoYXJlcwUCdGQFAnRzAQ5hbW91bnRUb1NoYXJlcwMHYXNzZXRJZANhbXQEY2VpbAQCdHMJAQt0b3RhbFNoYXJlcwEFB2Fzc2V0SWQEAnRkCQEMdG90YWxEZXBvc2l0AQUHYXNzZXRJZAMDCQAAAgUCdHMAAAYJAAACBQJ0ZAAABQNhbXQDBQRjZWlsCQEMZnJhY3Rpb25DZWlsAwUDYW10BQJ0cwUCdGQJAGsDBQNhbXQFAnRzBQJ0ZAEPdmFsaWRhdGVBc3NldElkAQdhc3NldElkCQEHdGhyb3dJZgIJAQEhAQkBCGNvbnRhaW5zAgUGYXNzZXRzBQdhc3NldElkAhVhc3NldElkIG5vdCBwZXJtaXR0ZWQBCmFzc2V0SWRTdHIBA2FpZAQHJG1hdGNoMAUDYWlkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmJ2BQckbWF0Y2gwCQDYBAEFAmJ2AwkAAQIFByRtYXRjaDACBFVuaXQEAXUFByRtYXRjaDACBVdBVkVTCQACAQILTWF0Y2ggZXJyb3IBDGFzc2V0U3RyVG9JZAEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwUEdW5pdAkA2QQBBQdhc3NldElkAQ1zdGFraW5nQWN0aW9uAgdhc3NldElkDWtlZXBBdEJhbGFuY2UEDWFjdHVhbEJhbGFuY2UDCQAAAgUHYXNzZXRJZAIFV0FWRVMICQDvBwEFBHRoaXMJYXZhaWxhYmxlCQDwBwIFBHRoaXMJANkEAQUHYXNzZXRJZAMJAAACBQ1hY3R1YWxCYWxhbmNlBQ1rZWVwQXRCYWxhbmNlBQR1bml0BA5zdGFraW5nRW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzCQCsAgICGnByb3RlY3RlZF9zdGFraW5nX2VuYWJsZWRfBQdhc3NldElkBwMJAQEhAQUOc3Rha2luZ0VuYWJsZWQFBHVuaXQEDnN0YWtpbmdBZGRyZXNzBARhZGRyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwkArAICAhlwcm90ZWN0ZWRfc3Rha2luZ19jb25maWdfBQdhc3NldElkCQCsAgICF25vIHN0YWtpbmcgYWRkcmVzcyBmb3IgBQdhc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUEYWRkcgkArAICCQCsAgIJAKwCAgIqcHJvdGVjdGVkUmVzZXJ2ZTogYmFkIHN0YWtpbmcgYWRkcmVzcyBmb3IgBQdhc3NldElkAgI6IAUEYWRkcgMJAGYCBQ1hY3R1YWxCYWxhbmNlBQ1rZWVwQXRCYWxhbmNlCQD8BwQFDnN0YWtpbmdBZGRyZXNzAgNwdXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDGFzc2V0U3RyVG9JZAEFB2Fzc2V0SWQJAGUCBQ1hY3R1YWxCYWxhbmNlBQ1rZWVwQXRCYWxhbmNlBQNuaWwJAPwHBAUOc3Rha2luZ0FkZHJlc3MCA2dldAkAzAgCCQBlAgUNa2VlcEF0QmFsYW5jZQUNYWN0dWFsQmFsYW5jZQUDbmlsBQNuaWwBEHdpdGhkcmF3SW50ZXJuYWwEBGZyb20CdG8HYXNzZXRJZAZhbW91bnQEBmNoZWNrcwkBD3ZhbGlkYXRlQXNzZXRJZAEFB2Fzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MECnJlYWxTaGFyZXMJAQp1c2VyU2hhcmVzAgUHYXNzZXRJZAUEZnJvbQQLJHQwNzQ2Nzc3NTEDCQAAAgUGYW1vdW50AP///////////wEECnJlYWxBbW91bnQJAQ5zaGFyZXNUb0Ftb3VudAIFB2Fzc2V0SWQFCnJlYWxTaGFyZXMJAJQKAgUKcmVhbFNoYXJlcwUKcmVhbEFtb3VudAMJAGcCAAAFBmFtb3VudAkAAgECJnByb3RlY3RlZC1yZXNlcnZlOiBub24tcG9zaXRpdmUgYW1vdW50CQCUCgIJAQ5hbW91bnRUb1NoYXJlcwMFB2Fzc2V0SWQFBmFtb3VudAYFBmFtb3VudAQId2RTaGFyZXMIBQskdDA3NDY3Nzc1MQJfMQQId2RBbW91bnQIBQskdDA3NDY3Nzc1MQJfMgQMbWF5YmVDbGVhblVwAwkAAAIFCnJlYWxTaGFyZXMFCHdkU2hhcmVzCQDMCAIJAQxCb29sZWFuRW50cnkCCQERaGFzUHJvdGVjdGVkU3RvcmUBBQRmcm9tBwkAzAgCCQELRGVsZXRlRW50cnkBCQETcHJvdGVjdGVkQXNzZXRTdG9yZQEFBGZyb20FA25pbAUDbmlsBAdzdGFraW5nCQENc3Rha2luZ0FjdGlvbgIFB2Fzc2V0SWQFCHdkQW1vdW50AwkAAAIFB3N0YWtpbmcFB3N0YWtpbmcJAJQKAgkAzggCBQxtYXliZUNsZWFuVXAJAMwIAgkBCGNoYW5nZUJ5AgkBEXRvdGFsRGVwb3NpdFN0b3JlAQUHYXNzZXRJZAkBAS0BBQh3ZEFtb3VudAkAzAgCCQEIY2hhbmdlQnkCCQEQdG90YWxTaGFyZXNTdG9yZQEFB2Fzc2V0SWQJAQEtAQUId2RTaGFyZXMJAMwIAgkBCGNoYW5nZUJ5AgkBD3VzZXJTaGFyZXNTdG9yZQIFB2Fzc2V0SWQFBGZyb20JAQEtAQUId2RTaGFyZXMJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUCdG8FCHdkQW1vdW50CQEMYXNzZXRTdHJUb0lkAQUHYXNzZXRJZAUDbmlsBQh3ZEFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEOc3VwcGx5SW50ZXJuYWwCBHVzZXIBaQMJARFoYXNSZWd1bGFyRGVwb3NpdAEFBHVzZXIJAAIBAjtwcm90ZWN0ZWQtcmVzZXJ2ZTogY2FuJ3QgaGF2ZSBwcm90ZWN0ZWQgd2hlbiByZWd1bGFyIGV4aXN0cwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECKnByb3RlY3RlZC1yZXNlcnZlOiBzaW5nbGUgcGF5bWVudCByZXF1aXJlZAQHYXNzZXRJZAkBCmFzc2V0SWRTdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQDCQAAAgUGYW1vdW50AAAFA25pbAQGY2hlY2tzAwkBD3ZhbGlkYXRlQXNzZXRJZAEFB2Fzc2V0SWQJAQlvcEFsbG93ZWQCBQdhc3NldElkAhtzdXBwbHlfcHJvdGVjdGVkX2NvbGxhdGVyYWwHAwkAAAIFBmNoZWNrcwUGY2hlY2tzBA1wcm90ZWN0ZWRGbGFnCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJARFoYXNQcm90ZWN0ZWRTdG9yZQEFBHVzZXIHBA5wcm90ZWN0ZWRBc3NldAkAnQgCBQR0aGlzCQETcHJvdGVjdGVkQXNzZXRTdG9yZQEFBHVzZXIEC2NvbnNpc3RlbmN5AwUNcHJvdGVjdGVkRmxhZwQHJG1hdGNoMAUOcHJvdGVjdGVkQXNzZXQDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwAwkAAAIFAXMFB2Fzc2V0SWQGCQACAQI7cHJvdGVjdGVkLXJlc2VydmU6IGNhbid0IGhhdmUgbW9yZSB0aGFuIG9uZSBhc3NldCBwcm90ZWN0ZWQJAAIBAiBwcm90ZWN0ZWQtcmVzZXJ2ZTpjbGVhbiB1cCBmaXJzdAQHJG1hdGNoMAUOcHJvdGVjdGVkQXNzZXQDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQACAQIjcHJvdGVjdGVkLXJlc2VydmU6IG1pc2NvbmZpZ3VyYXRpb24GBBBjb25zaXN0ZW5jeUNoZWNrCQEHdGhyb3dJZgIJAQEhAQULY29uc2lzdGVuY3kCDWluY29uc2lzdGVuY3kDCQAAAgUQY29uc2lzdGVuY3lDaGVjawUQY29uc2lzdGVuY3lDaGVjawQJbmV3U2hhcmVzCQEOYW1vdW50VG9TaGFyZXMDBQdhc3NldElkBQZhbW91bnQHBAdzdGFraW5nCQENc3Rha2luZ0FjdGlvbgIFB2Fzc2V0SWQAAAMJAAACBQdzdGFraW5nBQdzdGFraW5nCQDMCAIJAQhjaGFuZ2VCeQIJARF0b3RhbERlcG9zaXRTdG9yZQEFB2Fzc2V0SWQFBmFtb3VudAkAzAgCCQEIY2hhbmdlQnkCCQEQdG90YWxTaGFyZXNTdG9yZQEFB2Fzc2V0SWQFCW5ld1NoYXJlcwkAzAgCCQEIY2hhbmdlQnkCCQEPdXNlclNoYXJlc1N0b3JlAgUHYXNzZXRJZAUEdXNlcgUJbmV3U2hhcmVzCQDMCAIJAQxCb29sZWFuRW50cnkCCQERaGFzUHJvdGVjdGVkU3RvcmUBBQR1c2VyBgkAzAgCCQELU3RyaW5nRW50cnkCCQETcHJvdGVjdGVkQXNzZXRTdG9yZQEFBHVzZXIFB2Fzc2V0SWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLggBaQEKaW5pdGlhbGl6ZQENY29uZmlnQWRkcmVzcwkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFEmNvbmZpZ0FkZHJlc3NTdG9yZQUNY29uZmlnQWRkcmVzcwUDbmlsAWkBC2FkZEludGVyZXN0AAQHYXNzZXRJZAkBCmFzc2V0SWRTdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEBmNoZWNrcwkBD3ZhbGlkYXRlQXNzZXRJZAEFB2Fzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEB3N0YWtpbmcJAQ1zdGFraW5nQWN0aW9uAgUHYXNzZXRJZAAAAwkAAAIFB3N0YWtpbmcFB3N0YWtpbmcEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAMwIAgkBCGNoYW5nZUJ5AgkBEXRvdGFsRGVwb3NpdFN0b3JlAQUHYXNzZXRJZAUGYW1vdW50BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELYm9ycm93UG93ZXIBBHVzZXIJAJQKAgUDbmlsCQECYnABBQR1c2VyAWkBBnN1cHBseQAJAQ5zdXBwbHlJbnRlcm5hbAIJAKUIAQgFAWkGY2FsbGVyBQFpAWkBCXN1cHBseUZvcgEEdXNlcgQGY2hlY2tzCQEIbWFpbk9ubHkBBQFpAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQEOc3VwcGx5SW50ZXJuYWwCBQR1c2VyBQFpCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBC3dpdGhkcmF3Rm9yAwR1c2VyB2Fzc2V0SWQGYW1vdW50BAZjaGVja3MDCQEIbWFpbk9ubHkBBQFpCQEJb3BBbGxvd2VkAgUHYXNzZXRJZAIdd2l0aGRyYXdfcHJvdGVjdGVkX2NvbGxhdGVyYWwHAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQEQd2l0aGRyYXdJbnRlcm5hbAQFBHVzZXIFBHVzZXIFB2Fzc2V0SWQFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ53aXRoZHJhd1RvTWFpbgIEdXNlcgdhc3NldElkBAZjaGVja3MDCQEIbWFpbk9ubHkBBQFpCQEJb3BBbGxvd2VkAgUHYXNzZXRJZAIdY29sbGFwc2VfcHJvdGVjdGVkX2NvbGxhdGVyYWwHAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQEQd2l0aGRyYXdJbnRlcm5hbAQFBHVzZXIJAKUIAQgFAWkGY2FsbGVyBQdhc3NldElkAP///////////wEJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEPd2l0aGRyYXdUb01haW4yAwR1c2VyB2Fzc2V0SWQDYW10BAZjaGVja3MDCQEIbWFpbk9ubHkBBQFpCQEJb3BBbGxvd2VkAgUHYXNzZXRJZAIYd2l0aGRyYXdQcm90ZWN0ZWRUb01haW4yBwMJAAACBQZjaGVja3MFBmNoZWNrcwkBEHdpdGhkcmF3SW50ZXJuYWwEBQR1c2VyCQClCAEIBQFpBmNhbGxlcgUHYXNzZXRJZAUDYW10CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuABQr8h8=", "chainId": 87, "height": 3225160, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6WQF5q33XAPwKwsR4J5a2PVP4Az4QK4zbXsUL3J4Zr7L Next: 2FdU7eyXXUdXiMCfXY6CqAuCkfBZeqZmXU1pD8hKaunk Diff:
OldNewDifferences
444444 @Callable(i)
445445 func withdrawToMain2 (user,assetId,amt) = {
446446 let checks = if (mainOnly(i))
447- then opAllowed(assetId, "collapse_protected_collateral")
447+ then opAllowed(assetId, "withdrawProtectedToMain2")
448448 else false
449449 if ((checks == checks))
450450 then withdrawInternal(user, toString(i.caller), assetId, amt)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func throwIf (condition,error) = if (condition)
55 then throw(error)
66 else true
77
88
99 func writeInt (key,value) = if ((0 > value))
1010 then throw(((("writing negative value " + toString(value)) + " for key ") + key))
1111 else IntegerEntry(key, value)
1212
1313
1414 func changeBy (key,value) = writeInt(key, (valueOrElse(getInteger(this, key), 0) + value))
1515
1616
1717 func fractionCeil (value,numerator,denominator) = {
1818 let cand = fraction(value, numerator, denominator)
1919 let D = 3037000499
2020 let exact = ((((cand % D) * (denominator % D)) % D) == (((value % D) * (numerator % D)) % D))
2121 if (exact)
2222 then cand
2323 else (cand + 1)
2424 }
2525
2626
2727 func writeConstString (key,value) = if (!(isDefined(getString(this, key))))
2828 then StringEntry(key, value)
2929 else throw(("already initialized: " + key))
3030
3131
3232 let configAddressStore = "configAddress"
3333
3434 let oracleStore = "oracle_address"
3535
3636 func reserveFactorStore (assetId) = (assetId + "_ReserveFactor")
3737
3838
3939 let mainStore = "main"
4040
4141 let configAddress = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, configAddressStore), "protected-reserve: no configAddress")), "invalid config address")
4242
4343 func reserveFactor (assetId) = valueOrErrorMessage(getInteger(configAddress, reserveFactorStore(assetId)), "no reserveFactor")
4444
4545
4646 func getBalance (addressOrAlias,assetId) = match assetId {
4747 case bv: ByteVector =>
4848 assetBalance(addressOrAlias, bv)
4949 case u: Unit =>
5050 wavesBalance(addressOrAlias).available
5151 case _ =>
5252 throw("Match error")
5353 }
5454
5555
5656 func opAllowed (assetId,op) = match invoke(configAddress, "opAllowed", [assetId, op], nil) {
5757 case b: Boolean =>
5858 if (b)
5959 then true
6060 else throw("not allowed")
6161 case _ =>
6262 throw("opAllowed: unexpected result type")
6363 }
6464
6565
6666 func mainOnly (i) = if (contains(getStringValue(configAddress, "main"), toString(i.caller)))
6767 then true
6868 else throw("only main can do")
6969
7070
7171 let maybeOracleAddress = match getString(configAddress, oracleStore) {
7272 case s: String =>
7373 addressFromString(s)
7474 case _ =>
7575 unit
7676 }
7777
7878 func oraclePrice (assetId) = match invoke(valueOrErrorMessage(maybeOracleAddress, "no oracle"), "price", [assetId], nil) {
7979 case i: Int =>
8080 i
8181 case _ =>
8282 throw("bad oracle data")
8383 }
8484
8585
8686 let HEIGHT = height
8787
8888 let assets = valueOrElse(getString(configAddress, "protected_reserve_assets"), "")
8989
9090 let assetsArray = if ((assets == ""))
9191 then nil
9292 else split_4C(assets, "|")
9393
9494 func totalDepositStore (assetId) = ("totalSupply_" + assetId)
9595
9696
9797 func totalSharesStore (assetId) = ("totalShares_" + assetId)
9898
9999
100100 func userSharesStore (assetId,user) = ((("userShares_" + assetId) + "_") + user)
101101
102102
103103 func hasProtectedStore (user) = ("protected_collateral_" + user)
104104
105105
106106 func protectedAssetStore (user) = ("protected_asset_" + user)
107107
108108
109109 func totalDeposit (assetId) = valueOrElse(getInteger(totalDepositStore(assetId)), 0)
110110
111111
112112 func totalShares (assetId) = valueOrElse(getInteger(totalSharesStore(assetId)), 0)
113113
114114
115115 func userShares (assetId,user) = valueOrElse(getInteger(userSharesStore(assetId, user)), 0)
116116
117117
118118 func userDeposit (assetId,user) = {
119119 let ts = totalShares(assetId)
120120 let td = totalDeposit(assetId)
121121 let us = userShares(assetId, user)
122122 if ((ts == 0))
123123 then 0
124124 else fraction(td, us, ts)
125125 }
126126
127127
128128 func hasRegularDeposit (user) = {
129129 let reserves = split_4C(valueOrErrorMessage(getString(configAddress, "primary_reserves"), "protected: no reserves found in main"), "|")
130130 func asUserBalanceData (value) = match value {
131131 case x: (Int, Int, Int, Int, Int, Boolean) =>
132132 x
133133 case t =>
134134 throw("wrong type, expected: Int5&Boolean")
135135 }
136136
137137 func fold (acc,reserve) = {
138138 let ubd = asUserBalanceData(invoke(addressFromStringValue(reserve), "userBalance", [user], nil))
139139 if ((ubd._1 > 0))
140140 then throw("can't have protected when regular exists")
141141 else false
142142 }
143143
144144 let $l = reserves
145145 let $s = size($l)
146146 let $acc0 = false
147147 func $f0_1 ($a,$i) = if (($i >= $s))
148148 then $a
149149 else fold($a, $l[$i])
150150
151151 func $f0_2 ($a,$i) = if (($i >= $s))
152152 then $a
153153 else throw("List size exceeds 20")
154154
155155 $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)
156156 }
157157
158158
159159 func userState (user) = {
160160 func fold (acc,assetId) = (acc ++ [$Tuple2(assetId, userDeposit(assetId, user))])
161161
162162 let $l = assetsArray
163163 let $s = size($l)
164164 let $acc0 = nil
165165 func $f0_1 ($a,$i) = if (($i >= $s))
166166 then $a
167167 else fold($a, $l[$i])
168168
169169 func $f0_2 ($a,$i) = if (($i >= $s))
170170 then $a
171171 else throw("List size exceeds 20")
172172
173173 $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)
174174 }
175175
176176
177177 func bp (user) = {
178178 let factorsBase = 1000
179179 func collateralFactor (assetId) = valueOrErrorMessage(getInteger(configAddress, (assetId + "_CollateralFactor")), "no CollateralFactor in config")
180180
181181 func pow10 (n) = if ((n == 6))
182182 then 1000000
183183 else if ((n == 8))
184184 then 100000000
185185 else throw(("bad decimals: " + toString(n)))
186186
187187 func assetDecimals (assetId) = if ((assetId == "WAVES"))
188188 then 8
189189 else valueOrErrorMessage(assetInfo(fromBase58String(assetId)), "bad asset").decimals
190190
191191 func assetToUsd (assetId,amount) = fraction(amount, oraclePrice(assetId), pow10(assetDecimals(assetId)))
192192
193193 func fold (acc,data) = (acc + {
194194 let $t050635088 = data
195195 let assetId = $t050635088._1
196196 let amt = $t050635088._2
197197 fraction(assetToUsd(assetId, amt), collateralFactor(assetId), factorsBase)
198198 })
199199
200200 let $l = userState(user)
201201 let $s = size($l)
202202 let $acc0 = 0
203203 func $f0_1 ($a,$i) = if (($i >= $s))
204204 then $a
205205 else fold($a, $l[$i])
206206
207207 func $f0_2 ($a,$i) = if (($i >= $s))
208208 then $a
209209 else throw("List size exceeds 20")
210210
211211 $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)
212212 }
213213
214214
215215 func adviseUser (user) = {
216216 let borrowPower = bp(user)
217217 (("borrowPower = " + toString(borrowPower)) + {
218218 func fold (acc,pair) = ((((acc + ", ") + pair._1) + " = ") + toString(pair._2))
219219
220220 let $l = userState(user)
221221 let $s = size($l)
222222 let $acc0 = ""
223223 func $f0_1 ($a,$i) = if (($i >= $s))
224224 then $a
225225 else fold($a, $l[$i])
226226
227227 func $f0_2 ($a,$i) = if (($i >= $s))
228228 then $a
229229 else throw("List size exceeds 20")
230230
231231 $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)
232232 })
233233 }
234234
235235
236236 func sharesToAmount (assetId,shares) = {
237237 let ts = totalShares(assetId)
238238 let td = totalDeposit(assetId)
239239 if (if ((ts == 0))
240240 then true
241241 else (td == 0))
242242 then shares
243243 else fraction(shares, td, ts)
244244 }
245245
246246
247247 func amountToShares (assetId,amt,ceil) = {
248248 let ts = totalShares(assetId)
249249 let td = totalDeposit(assetId)
250250 if (if ((ts == 0))
251251 then true
252252 else (td == 0))
253253 then amt
254254 else if (ceil)
255255 then fractionCeil(amt, ts, td)
256256 else fraction(amt, ts, td)
257257 }
258258
259259
260260 func validateAssetId (assetId) = throwIf(!(contains(assets, assetId)), "assetId not permitted")
261261
262262
263263 func assetIdStr (aid) = match aid {
264264 case bv: ByteVector =>
265265 toBase58String(bv)
266266 case u: Unit =>
267267 "WAVES"
268268 case _ =>
269269 throw("Match error")
270270 }
271271
272272
273273 func assetStrToId (assetId) = if ((assetId == "WAVES"))
274274 then unit
275275 else fromBase58String(assetId)
276276
277277
278278 func stakingAction (assetId,keepAtBalance) = {
279279 let actualBalance = if ((assetId == "WAVES"))
280280 then wavesBalance(this).available
281281 else assetBalance(this, fromBase58String(assetId))
282282 if ((actualBalance == keepAtBalance))
283283 then unit
284284 else {
285285 let stakingEnabled = valueOrElse(getBoolean(configAddress, ("protected_staking_enabled_" + assetId)), false)
286286 if (!(stakingEnabled))
287287 then unit
288288 else {
289289 let stakingAddress = {
290290 let addr = valueOrErrorMessage(getString(configAddress, ("protected_staking_config_" + assetId)), ("no staking address for " + assetId))
291291 valueOrErrorMessage(addressFromString(addr), ((("protectedReserve: bad staking address for " + assetId) + ": ") + addr))
292292 }
293293 if ((actualBalance > keepAtBalance))
294294 then invoke(stakingAddress, "put", nil, [AttachedPayment(assetStrToId(assetId), (actualBalance - keepAtBalance))])
295295 else invoke(stakingAddress, "get", [(keepAtBalance - actualBalance)], nil)
296296 }
297297 }
298298 }
299299
300300
301301 func withdrawInternal (from,to,assetId,amount) = {
302302 let checks = validateAssetId(assetId)
303303 if ((checks == checks))
304304 then {
305305 let realShares = userShares(assetId, from)
306306 let $t074677751 = if ((amount == -1))
307307 then {
308308 let realAmount = sharesToAmount(assetId, realShares)
309309 $Tuple2(realShares, realAmount)
310310 }
311311 else if ((0 >= amount))
312312 then throw("protected-reserve: non-positive amount")
313313 else $Tuple2(amountToShares(assetId, amount, true), amount)
314314 let wdShares = $t074677751._1
315315 let wdAmount = $t074677751._2
316316 let maybeCleanUp = if ((realShares == wdShares))
317317 then [BooleanEntry(hasProtectedStore(from), false), DeleteEntry(protectedAssetStore(from))]
318318 else nil
319319 let staking = stakingAction(assetId, wdAmount)
320320 if ((staking == staking))
321321 then $Tuple2((maybeCleanUp ++ [changeBy(totalDepositStore(assetId), -(wdAmount)), changeBy(totalSharesStore(assetId), -(wdShares)), changeBy(userSharesStore(assetId, from), -(wdShares)), ScriptTransfer(addressFromStringValue(to), wdAmount, assetStrToId(assetId))]), wdAmount)
322322 else throw("Strict value is not equal to itself.")
323323 }
324324 else throw("Strict value is not equal to itself.")
325325 }
326326
327327
328328 func supplyInternal (user,i) = if (hasRegularDeposit(user))
329329 then throw("protected-reserve: can't have protected when regular exists")
330330 else if ((size(i.payments) != 1))
331331 then throw("protected-reserve: single payment required")
332332 else {
333333 let assetId = assetIdStr(i.payments[0].assetId)
334334 let amount = i.payments[0].amount
335335 if ((amount == 0))
336336 then nil
337337 else {
338338 let checks = if (validateAssetId(assetId))
339339 then opAllowed(assetId, "supply_protected_collateral")
340340 else false
341341 if ((checks == checks))
342342 then {
343343 let protectedFlag = valueOrElse(getBoolean(this, hasProtectedStore(user)), false)
344344 let protectedAsset = getString(this, protectedAssetStore(user))
345345 let consistency = if (protectedFlag)
346346 then match protectedAsset {
347347 case s: String =>
348348 if ((s == assetId))
349349 then true
350350 else throw("protected-reserve: can't have more than one asset protected")
351351 case _ =>
352352 throw("protected-reserve:clean up first")
353353 }
354354 else match protectedAsset {
355355 case s: String =>
356356 throw("protected-reserve: misconfiguration")
357357 case _ =>
358358 true
359359 }
360360 let consistencyCheck = throwIf(!(consistency), "inconsistency")
361361 if ((consistencyCheck == consistencyCheck))
362362 then {
363363 let newShares = amountToShares(assetId, amount, false)
364364 let staking = stakingAction(assetId, 0)
365365 if ((staking == staking))
366366 then [changeBy(totalDepositStore(assetId), amount), changeBy(totalSharesStore(assetId), newShares), changeBy(userSharesStore(assetId, user), newShares), BooleanEntry(hasProtectedStore(user), true), StringEntry(protectedAssetStore(user), assetId)]
367367 else throw("Strict value is not equal to itself.")
368368 }
369369 else throw("Strict value is not equal to itself.")
370370 }
371371 else throw("Strict value is not equal to itself.")
372372 }
373373 }
374374
375375
376376 @Callable(i)
377377 func initialize (configAddress) = [writeConstString(configAddressStore, configAddress)]
378378
379379
380380
381381 @Callable(i)
382382 func addInterest () = {
383383 let assetId = assetIdStr(i.payments[0].assetId)
384384 let checks = validateAssetId(assetId)
385385 if ((checks == checks))
386386 then {
387387 let staking = stakingAction(assetId, 0)
388388 if ((staking == staking))
389389 then {
390390 let amount = i.payments[0].amount
391391 [changeBy(totalDepositStore(assetId), amount)]
392392 }
393393 else throw("Strict value is not equal to itself.")
394394 }
395395 else throw("Strict value is not equal to itself.")
396396 }
397397
398398
399399
400400 @Callable(i)
401401 func borrowPower (user) = $Tuple2(nil, bp(user))
402402
403403
404404
405405 @Callable(i)
406406 func supply () = supplyInternal(toString(i.caller), i)
407407
408408
409409
410410 @Callable(i)
411411 func supplyFor (user) = {
412412 let checks = mainOnly(i)
413413 if ((checks == checks))
414414 then supplyInternal(user, i)
415415 else throw("Strict value is not equal to itself.")
416416 }
417417
418418
419419
420420 @Callable(i)
421421 func withdrawFor (user,assetId,amount) = {
422422 let checks = if (mainOnly(i))
423423 then opAllowed(assetId, "withdraw_protected_collateral")
424424 else false
425425 if ((checks == checks))
426426 then withdrawInternal(user, user, assetId, amount)
427427 else throw("Strict value is not equal to itself.")
428428 }
429429
430430
431431
432432 @Callable(i)
433433 func withdrawToMain (user,assetId) = {
434434 let checks = if (mainOnly(i))
435435 then opAllowed(assetId, "collapse_protected_collateral")
436436 else false
437437 if ((checks == checks))
438438 then withdrawInternal(user, toString(i.caller), assetId, -1)
439439 else throw("Strict value is not equal to itself.")
440440 }
441441
442442
443443
444444 @Callable(i)
445445 func withdrawToMain2 (user,assetId,amt) = {
446446 let checks = if (mainOnly(i))
447- then opAllowed(assetId, "collapse_protected_collateral")
447+ then opAllowed(assetId, "withdrawProtectedToMain2")
448448 else false
449449 if ((checks == checks))
450450 then withdrawInternal(user, toString(i.caller), assetId, amt)
451451 else throw("Strict value is not equal to itself.")
452452 }
453453
454454

github/deemru/w8io/786bc32 
55.34 ms