tx · 3rYKZE4t4NBdYai78q2yPzKoePBRbGnGYdU4z74m5jwD 3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT: -0.01000000 Waves 2023.05.28 13:29 [3663238] smart account 3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT > SELF 0.00000000 Waves
{ "type": 13, "id": "3rYKZE4t4NBdYai78q2yPzKoePBRbGnGYdU4z74m5jwD", "fee": 1000000, "feeAssetId": null, "timestamp": 1685269740787, "version": 2, "chainId": 87, "sender": "3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT", "senderPublicKey": "7kuQGHmvhzQW3ERxGyMrxfq3LuxHSJ6UdBZcuy498sf6", "proofs": [ "5mNZVCEup4j5mwzy8YgvUBnytMxtQYLtXNGCyD7VZu4rCqseD4sHTPCRtbfboQVPU83GsWHUBdnZ863qhyHKn7Gh" ], "script": "base64:BgIfCAISBAoCCAgSAwoBARIFCgMICAgSBAoCCAESAwoBCB0ADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQAB2tfYWRtaW4CB2tfYWRtaW4ABmtfc3RlcAIGa19zdGVwAAxrX3F1b3RlQXNzZXQCDGtfcXVvdGVBc3NldAAMa19zcG90TWFya2V0AgxrX3Nwb3RNYXJrZXQAD2tfZnV0dXJlc01hcmtldAIPa19mdXR1cmVzTWFya2V0ABNrX21pbkluY3JlYXNlU3ByZWFkAhNrX21pbkluY3JlYXNlU3ByZWFkAA5rX3Bvc2l0aW9uTG9uZwIOa19wb3NpdGlvbkxvbmcAD2tfcG9zaXRpb25TaG9ydAIPa19wb3NpdGlvblNob3J0ABBrX3Bvc2l0aW9uU3ByZWFkAhBrX3Bvc2l0aW9uU3ByZWFkAA9rX3Bvc2l0aW9uTW9uZXkCD2tfcG9zaXRpb25Nb25leQAOa19wb3NpdGlvblNpemUCDmtfcG9zaXRpb25TaXplAAxERUNJTUFMX1VOSVQJAGgCAAEJAGgCCQBoAgkAaAIJAGgCCQBoAgAKAAoACgAKAAoACgEEZGl2ZAICX3gCX3kJAG4EBQJfeAUMREVDSU1BTF9VTklUBQJfeQUISEFMRkVWRU4BBG11bGQCAl94Al95CQBuBAUCX3gFAl95BQxERUNJTUFMX1VOSVQFCEhBTEZFVkVOAAlESVJfU0hPUlQAAgEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEMYWRtaW5BZGRyZXNzAAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUHa19hZG1pbgENZ2V0UXVvdGVBc3NldAAJANkEAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUMa19xdW90ZUFzc2V0AQ1nZXRTcG90TWFya2V0AQZfYXNzZXQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFDGtfc3BvdE1hcmtldAUGX2Fzc2V0ARBnZXRGdXR1cmVzTWFya2V0AQZfYXNzZXQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFD2tfZnV0dXJlc01hcmtldAUGX2Fzc2V0ARFtaW5JbmNyZWFzZVNwcmVhZAAJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFE2tfbWluSW5jcmVhc2VTcHJlYWQBC2dldFBvc2l0aW9uAQZfYXNzZXQECGxvbmdTaXplCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQAAAMJAAACBQhsb25nU2l6ZQAACQCWCgQAAAAAAAAAAAkAlgoEBQhsb25nU2l6ZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFD2tfcG9zaXRpb25Nb25leQUGX2Fzc2V0AAABD2dldEFzc2V0QmFsYW5jZQEGX2Fzc2V0AwkAAAIFBl9hc3NldAIFV0FWRVMICQDvBwEFBHRoaXMHcmVndWxhcgkA8AcCBQR0aGlzCQDZBAEFBl9hc3NldAEKZ2V0QXNzZXRJZAEGX2Fzc2V0AwkAAAIFBl9hc3NldAIFV0FWRVMFBHVuaXQJANkEAQUGX2Fzc2V0AQlub3JtYWxpemUCB19hbW91bnQGX2Fzc2V0BAhkZWNpbWFscwMJAAACBQZfYXNzZXQCBVdBVkVTAAgICQEFdmFsdWUBCQDsBwEJANkEAQUGX2Fzc2V0CGRlY2ltYWxzAwkAAAIFCGRlY2ltYWxzAAgJAGkCBQdfYW1vdW50AGQDCQAAAgUIZGVjaW1hbHMABgUHX2Ftb3VudAkAAgECGkludmFsaWQgZGVjaW1hbHMgZm9yIGFzc2V0AQtkZU5vcm1hbGl6ZQIHX2Ftb3VudAZfYXNzZXQECGRlY2ltYWxzAwkAAAIFBl9hc3NldAIFV0FWRVMACAgJAQV2YWx1ZQEJAOwHAQkA2QQBBQZfYXNzZXQIZGVjaW1hbHMDCQAAAgUIZGVjaW1hbHMACAkAaAIFB19hbW91bnQAZAMJAAACBQhkZWNpbWFscwAGBQdfYW1vdW50CQACAQIaSW52YWxpZCBkZWNpbWFscyBmb3IgYXNzZXQBDnVwZGF0ZVBvc2l0aW9uBQZfYXNzZXQMX25ld0xvbmdTaXplDV9uZXdTaG9ydFNpemUNX25ld0F2Z1NwcmVhZA5fbmV3TW9uZXlTcGVudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvbkxvbmcFBl9hc3NldAUMX25ld0xvbmdTaXplCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAUNX25ld1Nob3J0U2l6ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUQa19wb3NpdGlvblNwcmVhZAUGX2Fzc2V0BQ1fbmV3QXZnU3ByZWFkCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uTW9uZXkFBl9hc3NldAUOX25ld01vbmV5U3BlbnQFA25pbAEOZGVsZXRlUG9zaXRpb24BBl9hc3NldAkAzAgCCQELRGVsZXRlRW50cnkBCQEOdG9Db21wb3NpdGVLZXkCBQ5rX3Bvc2l0aW9uTG9uZwUGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFD2tfcG9zaXRpb25TaG9ydAUGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAkAzAgCCQELRGVsZXRlRW50cnkBCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uTW9uZXkFBl9hc3NldAUDbmlsBQFpAQppbml0aWFsaXplAgZfYWRtaW4LX3F1b3RlQXNzZXQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhlJbnZhbGlkIGluaXRpYWxpemUgcGFyYW1zCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2tfYWRtaW4FBl9hZG1pbgkAzAgCCQELU3RyaW5nRW50cnkCBQxrX3F1b3RlQXNzZXQFC19xdW90ZUFzc2V0BQNuaWwBaQEOY2hhbmdlU2V0dGluZ3MBEl9taW5JbmNyZWFzZVNwcmVhZAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAh1JbnZhbGlkIGNoYW5nZVNldHRpbmdzIHBhcmFtcwkAzAgCCQEMSW50ZWdlckVudHJ5AgUTa19taW5JbmNyZWFzZVNwcmVhZAUSX21pbkluY3JlYXNlU3ByZWFkBQNuaWwBaQEJYWRkTWFya2V0AwZfYXNzZXQLX3Nwb3RNYXJrZXQOX2Z1dHVyZXNNYXJrZXQDCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MACQACAQIYSW52YWxpZCBhZGRNYXJrZXQgcGFyYW1zCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFDGtfc3BvdE1hcmtldAUGX2Fzc2V0BQtfc3BvdE1hcmtldAkAzAgCCQELU3RyaW5nRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX2Z1dHVyZXNNYXJrZXQFBl9hc3NldAUOX2Z1dHVyZXNNYXJrZXQFA25pbAFpARBpbmNyZWFzZVBvc2l0aW9uAgZfYXNzZXQPX3F1b3RlQXNzZXRTdGVwBApxdW90ZUFzc2V0CQENZ2V0UXVvdGVBc3NldAAECnNwb3RNYXJrZXQJAQ1nZXRTcG90TWFya2V0AQUGX2Fzc2V0BAthc3NldEJlZm9yZQkBD2dldEFzc2V0QmFsYW5jZQEFBl9hc3NldAMJAAACBQthc3NldEJlZm9yZQULYXNzZXRCZWZvcmUEB2J1eVNwb3QJAPwHBAUKc3BvdE1hcmtldAIEc3dhcAkAzAgCAAAJAMwIAgUGX2Fzc2V0CQDMCAIJAKUIAQUEdGhpcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQpxdW90ZUFzc2V0BQ9fcXVvdGVBc3NldFN0ZXAFA25pbAMJAAACBQdidXlTcG90BQdidXlTcG90BAphc3NldEFmdGVyCQEPZ2V0QXNzZXRCYWxhbmNlAQUGX2Fzc2V0AwkAAAIFCmFzc2V0QWZ0ZXIFCmFzc2V0QWZ0ZXIEC2Fzc2V0Qm91Z2h0CQBlAgUKYXNzZXRBZnRlcgULYXNzZXRCZWZvcmUED2Fzc2V0Qm91Z2h0Tm9ybQkBCW5vcm1hbGl6ZQIFC2Fzc2V0Qm91Z2h0BQZfYXNzZXQEEGJ1eVByaWNlTm9ybUZhY3QJAQRkaXZkAgUPX3F1b3RlQXNzZXRTdGVwBQ9hc3NldEJvdWdodE5vcm0EDWZ1dHVyZXNNYXJrZXQJARBnZXRGdXR1cmVzTWFya2V0AQUGX2Fzc2V0BAtwb3NpdGlvbktleQkArAICCQCsAgIJAKUIAQUEdGhpcwIBXwkApAMBBQlESVJfU0hPUlQED3Bvc2l0aW9uRnVsbEtleQkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvblNpemUFC3Bvc2l0aW9uS2V5BBRhc3NldFNob3J0Tm9ybUJlZm9yZQkBAS0BCQELdmFsdWVPckVsc2UCCQCaCAIFDWZ1dHVyZXNNYXJrZXQFD3Bvc2l0aW9uRnVsbEtleQAAAwkAAAIFFGFzc2V0U2hvcnROb3JtQmVmb3JlBRRhc3NldFNob3J0Tm9ybUJlZm9yZQQMc2hvcnRGdXR1cmVzCQD8BwQFDWZ1dHVyZXNNYXJrZXQCEGluY3JlYXNlUG9zaXRpb24JAMwIAgUJRElSX1NIT1JUCQDMCAIFDERFQ0lNQUxfVU5JVAkAzAgCAAAJAMwIAgIACQDMCAICAAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQpxdW90ZUFzc2V0BQ9fcXVvdGVBc3NldFN0ZXAFA25pbAMJAAACBQxzaG9ydEZ1dHVyZXMFDHNob3J0RnV0dXJlcwQTYXNzZXRTaG9ydE5vcm1BZnRlcgkBAS0BCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ1mdXR1cmVzTWFya2V0BQ9wb3NpdGlvbkZ1bGxLZXkDCQAAAgUTYXNzZXRTaG9ydE5vcm1BZnRlcgUTYXNzZXRTaG9ydE5vcm1BZnRlcgQOYXNzZXRTaG9ydE5vcm0JAGUCBRNhc3NldFNob3J0Tm9ybUFmdGVyBRRhc3NldFNob3J0Tm9ybUJlZm9yZQQSc2hvcnRQcmljZU5vcm1GYWN0CQEEZGl2ZAIFD19xdW90ZUFzc2V0U3RlcAUOYXNzZXRTaG9ydE5vcm0ECnNwcmVhZEZhY3QJAGUCBQxERUNJTUFMX1VOSVQJAQRkaXZkAgUQYnV5UHJpY2VOb3JtRmFjdAUSc2hvcnRQcmljZU5vcm1GYWN0BAltaW5TcHJlYWQJARFtaW5JbmNyZWFzZVNwcmVhZAADCQBmAgUKc3ByZWFkRmFjdAUJbWluU3ByZWFkBAskdDA2MTk4NjI2OAkBC2dldFBvc2l0aW9uAQUGX2Fzc2V0BAhsb25nU2l6ZQgFCyR0MDYxOTg2MjY4Al8xBAlzaG9ydFNpemUIBQskdDA2MTk4NjI2OAJfMgQJYXZnU3ByZWFkCAULJHQwNjE5ODYyNjgCXzMECm1vbmV5U3BlbnQIBQskdDA2MTk4NjI2OAJfNAQLbmV3TG9uZ1NpemUJAGQCBQhsb25nU2l6ZQUPYXNzZXRCb3VnaHROb3JtBAxuZXdTaG9ydFNpemUJAGQCBQlzaG9ydFNpemUFDmFzc2V0U2hvcnROb3JtBAxuZXdBdmdTcHJlYWQJAQRkaXZkAgkAZAIJAQRtdWxkAgUJYXZnU3ByZWFkCQBkAgUIbG9uZ1NpemUFCXNob3J0U2l6ZQkBBG11bGQCBQpzcHJlYWRGYWN0CQBkAgUPYXNzZXRCb3VnaHROb3JtBQ5hc3NldFNob3J0Tm9ybQkAZAIJAGQCCQBkAgUIbG9uZ1NpemUFCXNob3J0U2l6ZQUPYXNzZXRCb3VnaHROb3JtBQ5hc3NldFNob3J0Tm9ybQQNbmV3TW9uZXlTcGVudAkAZAIFCm1vbmV5U3BlbnQJAGgCBQ9fcXVvdGVBc3NldFN0ZXAAAgkBDnVwZGF0ZVBvc2l0aW9uBQUGX2Fzc2V0BQtuZXdMb25nU2l6ZQUMbmV3U2hvcnRTaXplBQxuZXdBdmdTcHJlYWQFDW5ld01vbmV5U3BlbnQEBGRhdGEJAMwIAgkApAMBBQ9hc3NldEJvdWdodE5vcm0JAMwIAgkApAMBBRBidXlQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUOYXNzZXRTaG9ydE5vcm0JAMwIAgkApAMBBRJzaG9ydFByaWNlTm9ybUZhY3QJAMwIAgkApAMBBQpzcHJlYWRGYWN0CQDMCAIJAKQDAQUJbWluU3ByZWFkBQNuaWwJAAIBCQCsAgICEEludmFsaWQgc3ByZWFkOiAJALkJAgUEZGF0YQIBLAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ1jbG9zZVBvc2l0aW9uAQZfYXNzZXQECnF1b3RlQXNzZXQJAQ1nZXRRdW90ZUFzc2V0AAQNcXVvdGVBc3NldFN0cgkA2AQBBQpxdW90ZUFzc2V0BApzcG90TWFya2V0CQENZ2V0U3BvdE1hcmtldAEFBl9hc3NldAQLJHQwNzI0MDczMTAJAQtnZXRQb3NpdGlvbgEFBl9hc3NldAQIbG9uZ1NpemUIBQskdDA3MjQwNzMxMAJfMQQJc2hvcnRTaXplCAULJHQwNzI0MDczMTACXzIECWF2Z1NwcmVhZAgFCyR0MDcyNDA3MzEwAl8zBAptb25leVNwZW50CAULJHQwNzI0MDczMTACXzQEEHF1b3RlQXNzZXRCZWZvcmUJAQ9nZXRBc3NldEJhbGFuY2UBBQ1xdW90ZUFzc2V0U3RyAwkAAAIFEHF1b3RlQXNzZXRCZWZvcmUFEHF1b3RlQXNzZXRCZWZvcmUECHNlbGxTcG90CQD8BwQFCnNwb3RNYXJrZXQCBHN3YXAJAMwIAgAACQDMCAIFDXF1b3RlQXNzZXRTdHIJAMwIAgkApQgBBQR0aGlzBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQpnZXRBc3NldElkAQUGX2Fzc2V0CQELZGVOb3JtYWxpemUCBQhsb25nU2l6ZQUGX2Fzc2V0BQNuaWwDCQAAAgUIc2VsbFNwb3QFCHNlbGxTcG90BA9xdW90ZUFzc2V0QWZ0ZXIJAQ9nZXRBc3NldEJhbGFuY2UBBQ1xdW90ZUFzc2V0U3RyAwkAAAIFD3F1b3RlQXNzZXRBZnRlcgUPcXVvdGVBc3NldEFmdGVyBAxhc3NldFNvbGRGb3IJAGUCBQ9xdW90ZUFzc2V0QWZ0ZXIFEHF1b3RlQXNzZXRCZWZvcmUEEGFzc2V0U29sZEZvck5vcm0JAQlub3JtYWxpemUCBQxhc3NldFNvbGRGb3IFDXF1b3RlQXNzZXRTdHIEEXNlbGxQcmljZU5vcm1GYWN0CQEEZGl2ZAIFEGFzc2V0U29sZEZvck5vcm0FCGxvbmdTaXplBA1mdXR1cmVzTWFya2V0CQEQZ2V0RnV0dXJlc01hcmtldAEFBl9hc3NldAQRcXVvdGVBc3NldEJlZm9yZTIJAQ9nZXRBc3NldEJhbGFuY2UBBQ1xdW90ZUFzc2V0U3RyAwkAAAIFEXF1b3RlQXNzZXRCZWZvcmUyBRFxdW90ZUFzc2V0QmVmb3JlMgQRY2xvc2VTaG9ydEZ1dHVyZXMJAPwHBAUNZnV0dXJlc01hcmtldAINY2xvc2VQb3NpdGlvbgkAzAgCBQlzaG9ydFNpemUJAMwIAgUJRElSX1NIT1JUCQDMCAIAAAkAzAgCBwkAzAgCAgAFA25pbAUDbmlsAwkAAAIFEWNsb3NlU2hvcnRGdXR1cmVzBRFjbG9zZVNob3J0RnV0dXJlcwQQcXVvdGVBc3NldEFmdGVyMgkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgUQcXVvdGVBc3NldEFmdGVyMgUQcXVvdGVBc3NldEFmdGVyMgQOc2hvcnRDbG9zZWRGb3IJAGUCBRBxdW90ZUFzc2V0QWZ0ZXIyBRFxdW90ZUFzc2V0QmVmb3JlMgQSc2hvcnRQcmljZU5vcm1GYWN0CQEEZGl2ZAIFDnNob3J0Q2xvc2VkRm9yBQlzaG9ydFNpemUECG1vbmV5R290CQBkAgUOc2hvcnRDbG9zZWRGb3IFDGFzc2V0U29sZEZvcgMJAGYCBQhtb25leUdvdAUKbW9uZXlTcGVudAkBDmRlbGV0ZVBvc2l0aW9uAQUGX2Fzc2V0BARkYXRhCQDMCAIJAKQDAQUQYXNzZXRTb2xkRm9yTm9ybQkAzAgCCQCkAwEFEXNlbGxQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUOc2hvcnRDbG9zZWRGb3IJAMwIAgkApAMBBRJzaG9ydFByaWNlTm9ybUZhY3QJAMwIAgkApAMBBQhtb25leUdvdAkAzAgCCQCkAwEFCm1vbmV5U3BlbnQFA25pbAkAAgEJAKwCAgIaSW52YWxpZCBzcHJlYWQgZm9yIGNsb3NlOiAJALkJAgUEZGF0YQIBLAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgDB7M3U", "height": 3663238, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 4ys7oSUFgxcDsjzHNdXzfrNnDbnBGK1A2dCeLeeYqxfb Next: none Diff:
Old | New | Differences | |
---|---|---|---|
139 | 139 | let assetBoughtNorm = normalize(assetBought, _asset) | |
140 | 140 | let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm) | |
141 | 141 | let futuresMarket = getFuturesMarket(_asset) | |
142 | - | let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
143 | - | if ((shortFutures == shortFutures)) | |
142 | + | let positionKey = ((toString(this) + "_") + toString(DIR_SHORT)) | |
143 | + | let positionFullKey = toCompositeKey(k_positionSize, positionKey) | |
144 | + | let assetShortNormBefore = -(valueOrElse(getInteger(futuresMarket, positionFullKey), 0)) | |
145 | + | if ((assetShortNormBefore == assetShortNormBefore)) | |
144 | 146 | then { | |
145 | - | let positionKey = ((toString(this) + "_") + toString(DIR_SHORT)) | |
146 | - | let positionFullKey = toCompositeKey(k_positionSize, positionKey) | |
147 | - | let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey)) | |
148 | - | let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm) | |
149 | - | let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact)) | |
150 | - | let minSpread = minIncreaseSpread() | |
151 | - | if ((spreadFact > minSpread)) | |
147 | + | let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
148 | + | if ((shortFutures == shortFutures)) | |
152 | 149 | then { | |
153 | - | let $t060306100 = getPosition(_asset) | |
154 | - | let longSize = $t060306100._1 | |
155 | - | let shortSize = $t060306100._2 | |
156 | - | let avgSpread = $t060306100._3 | |
157 | - | let moneySpent = $t060306100._4 | |
158 | - | let newLongSize = (longSize + assetBoughtNorm) | |
159 | - | let newShortSize = (shortSize + assetShortNorm) | |
160 | - | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
161 | - | let newMoneySpent = (moneySpent + (_quoteAssetStep * 2)) | |
162 | - | updatePosition(_asset, newLongSize, newShortSize, newAvgSpread, newMoneySpent) | |
150 | + | let assetShortNormAfter = -(getIntegerValue(futuresMarket, positionFullKey)) | |
151 | + | if ((assetShortNormAfter == assetShortNormAfter)) | |
152 | + | then { | |
153 | + | let assetShortNorm = (assetShortNormAfter - assetShortNormBefore) | |
154 | + | let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm) | |
155 | + | let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact)) | |
156 | + | let minSpread = minIncreaseSpread() | |
157 | + | if ((spreadFact > minSpread)) | |
158 | + | then { | |
159 | + | let $t061986268 = getPosition(_asset) | |
160 | + | let longSize = $t061986268._1 | |
161 | + | let shortSize = $t061986268._2 | |
162 | + | let avgSpread = $t061986268._3 | |
163 | + | let moneySpent = $t061986268._4 | |
164 | + | let newLongSize = (longSize + assetBoughtNorm) | |
165 | + | let newShortSize = (shortSize + assetShortNorm) | |
166 | + | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
167 | + | let newMoneySpent = (moneySpent + (_quoteAssetStep * 2)) | |
168 | + | updatePosition(_asset, newLongSize, newShortSize, newAvgSpread, newMoneySpent) | |
169 | + | } | |
170 | + | else { | |
171 | + | let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)] | |
172 | + | throw(("Invalid spread: " + makeString(data, ","))) | |
173 | + | } | |
174 | + | } | |
175 | + | else throw("Strict value is not equal to itself.") | |
163 | 176 | } | |
164 | - | else { | |
165 | - | let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)] | |
166 | - | throw(("Invalid spread: " + makeString(data, ","))) | |
167 | - | } | |
177 | + | else throw("Strict value is not equal to itself.") | |
168 | 178 | } | |
169 | 179 | else throw("Strict value is not equal to itself.") | |
170 | 180 | } | |
182 | 192 | let quoteAsset = getQuoteAsset() | |
183 | 193 | let quoteAssetStr = toBase58String(quoteAsset) | |
184 | 194 | let spotMarket = getSpotMarket(_asset) | |
185 | - | let $ | |
186 | - | let longSize = $ | |
187 | - | let shortSize = $ | |
188 | - | let avgSpread = $ | |
189 | - | let moneySpent = $ | |
195 | + | let $t072407310 = getPosition(_asset) | |
196 | + | let longSize = $t072407310._1 | |
197 | + | let shortSize = $t072407310._2 | |
198 | + | let avgSpread = $t072407310._3 | |
199 | + | let moneySpent = $t072407310._4 | |
190 | 200 | let quoteAssetBefore = getAssetBalance(quoteAssetStr) | |
191 | 201 | if ((quoteAssetBefore == quoteAssetBefore)) | |
192 | 202 | then { |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let k_initialized = "k_initialized" | |
5 | 5 | ||
6 | 6 | let k_admin = "k_admin" | |
7 | 7 | ||
8 | 8 | let k_step = "k_step" | |
9 | 9 | ||
10 | 10 | let k_quoteAsset = "k_quoteAsset" | |
11 | 11 | ||
12 | 12 | let k_spotMarket = "k_spotMarket" | |
13 | 13 | ||
14 | 14 | let k_futuresMarket = "k_futuresMarket" | |
15 | 15 | ||
16 | 16 | let k_minIncreaseSpread = "k_minIncreaseSpread" | |
17 | 17 | ||
18 | 18 | let k_positionLong = "k_positionLong" | |
19 | 19 | ||
20 | 20 | let k_positionShort = "k_positionShort" | |
21 | 21 | ||
22 | 22 | let k_positionSpread = "k_positionSpread" | |
23 | 23 | ||
24 | 24 | let k_positionMoney = "k_positionMoney" | |
25 | 25 | ||
26 | 26 | let k_positionSize = "k_positionSize" | |
27 | 27 | ||
28 | 28 | let DECIMAL_UNIT = (1 * (((((10 * 10) * 10) * 10) * 10) * 10)) | |
29 | 29 | ||
30 | 30 | func divd (_x,_y) = fraction(_x, DECIMAL_UNIT, _y, HALFEVEN) | |
31 | 31 | ||
32 | 32 | ||
33 | 33 | func muld (_x,_y) = fraction(_x, _y, DECIMAL_UNIT, HALFEVEN) | |
34 | 34 | ||
35 | 35 | ||
36 | 36 | let DIR_SHORT = 2 | |
37 | 37 | ||
38 | 38 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
39 | 39 | ||
40 | 40 | ||
41 | 41 | func adminAddress () = addressFromStringValue(getStringValue(this, k_admin)) | |
42 | 42 | ||
43 | 43 | ||
44 | 44 | func getQuoteAsset () = fromBase58String(getStringValue(this, k_quoteAsset)) | |
45 | 45 | ||
46 | 46 | ||
47 | 47 | func getSpotMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_spotMarket, _asset))) | |
48 | 48 | ||
49 | 49 | ||
50 | 50 | func getFuturesMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_futuresMarket, _asset))) | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | func minIncreaseSpread () = getIntegerValue(this, k_minIncreaseSpread) | |
54 | 54 | ||
55 | 55 | ||
56 | 56 | func getPosition (_asset) = { | |
57 | 57 | let longSize = valueOrElse(getInteger(this, toCompositeKey(k_positionLong, _asset)), 0) | |
58 | 58 | if ((longSize == 0)) | |
59 | 59 | then $Tuple4(0, 0, 0, 0) | |
60 | 60 | else $Tuple4(longSize, valueOrElse(getInteger(this, toCompositeKey(k_positionShort, _asset)), 0), valueOrElse(getInteger(this, toCompositeKey(k_positionSpread, _asset)), 0), valueOrElse(getInteger(this, toCompositeKey(k_positionMoney, _asset)), 0)) | |
61 | 61 | } | |
62 | 62 | ||
63 | 63 | ||
64 | 64 | func getAssetBalance (_asset) = if ((_asset == "WAVES")) | |
65 | 65 | then wavesBalance(this).regular | |
66 | 66 | else assetBalance(this, fromBase58String(_asset)) | |
67 | 67 | ||
68 | 68 | ||
69 | 69 | func getAssetId (_asset) = if ((_asset == "WAVES")) | |
70 | 70 | then unit | |
71 | 71 | else fromBase58String(_asset) | |
72 | 72 | ||
73 | 73 | ||
74 | 74 | func normalize (_amount,_asset) = { | |
75 | 75 | let decimals = if ((_asset == "WAVES")) | |
76 | 76 | then 8 | |
77 | 77 | else value(assetInfo(fromBase58String(_asset))).decimals | |
78 | 78 | if ((decimals == 8)) | |
79 | 79 | then (_amount / 100) | |
80 | 80 | else if ((decimals == 6)) | |
81 | 81 | then _amount | |
82 | 82 | else throw("Invalid decimals for asset") | |
83 | 83 | } | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func deNormalize (_amount,_asset) = { | |
87 | 87 | let decimals = if ((_asset == "WAVES")) | |
88 | 88 | then 8 | |
89 | 89 | else value(assetInfo(fromBase58String(_asset))).decimals | |
90 | 90 | if ((decimals == 8)) | |
91 | 91 | then (_amount * 100) | |
92 | 92 | else if ((decimals == 6)) | |
93 | 93 | then _amount | |
94 | 94 | else throw("Invalid decimals for asset") | |
95 | 95 | } | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func updatePosition (_asset,_newLongSize,_newShortSize,_newAvgSpread,_newMoneySpent) = [IntegerEntry(toCompositeKey(k_positionLong, _asset), _newLongSize), IntegerEntry(toCompositeKey(k_positionShort, _asset), _newShortSize), IntegerEntry(toCompositeKey(k_positionSpread, _asset), _newAvgSpread), IntegerEntry(toCompositeKey(k_positionMoney, _asset), _newMoneySpent)] | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | func deletePosition (_asset) = [DeleteEntry(toCompositeKey(k_positionLong, _asset)), DeleteEntry(toCompositeKey(k_positionShort, _asset)), DeleteEntry(toCompositeKey(k_positionSpread, _asset)), DeleteEntry(toCompositeKey(k_positionMoney, _asset))] | |
102 | 102 | ||
103 | 103 | ||
104 | 104 | @Callable(i) | |
105 | 105 | func initialize (_admin,_quoteAsset) = if ((i.caller != this)) | |
106 | 106 | then throw("Invalid initialize params") | |
107 | 107 | else [StringEntry(k_admin, _admin), StringEntry(k_quoteAsset, _quoteAsset)] | |
108 | 108 | ||
109 | 109 | ||
110 | 110 | ||
111 | 111 | @Callable(i) | |
112 | 112 | func changeSettings (_minIncreaseSpread) = if ((i.caller != adminAddress())) | |
113 | 113 | then throw("Invalid changeSettings params") | |
114 | 114 | else [IntegerEntry(k_minIncreaseSpread, _minIncreaseSpread)] | |
115 | 115 | ||
116 | 116 | ||
117 | 117 | ||
118 | 118 | @Callable(i) | |
119 | 119 | func addMarket (_asset,_spotMarket,_futuresMarket) = if ((i.caller != adminAddress())) | |
120 | 120 | then throw("Invalid addMarket params") | |
121 | 121 | else [StringEntry(toCompositeKey(k_spotMarket, _asset), _spotMarket), StringEntry(toCompositeKey(k_futuresMarket, _asset), _futuresMarket)] | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | ||
125 | 125 | @Callable(i) | |
126 | 126 | func increasePosition (_asset,_quoteAssetStep) = { | |
127 | 127 | let quoteAsset = getQuoteAsset() | |
128 | 128 | let spotMarket = getSpotMarket(_asset) | |
129 | 129 | let assetBefore = getAssetBalance(_asset) | |
130 | 130 | if ((assetBefore == assetBefore)) | |
131 | 131 | then { | |
132 | 132 | let buySpot = invoke(spotMarket, "swap", [0, _asset, toString(this)], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
133 | 133 | if ((buySpot == buySpot)) | |
134 | 134 | then { | |
135 | 135 | let assetAfter = getAssetBalance(_asset) | |
136 | 136 | if ((assetAfter == assetAfter)) | |
137 | 137 | then { | |
138 | 138 | let assetBought = (assetAfter - assetBefore) | |
139 | 139 | let assetBoughtNorm = normalize(assetBought, _asset) | |
140 | 140 | let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm) | |
141 | 141 | let futuresMarket = getFuturesMarket(_asset) | |
142 | - | let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
143 | - | if ((shortFutures == shortFutures)) | |
142 | + | let positionKey = ((toString(this) + "_") + toString(DIR_SHORT)) | |
143 | + | let positionFullKey = toCompositeKey(k_positionSize, positionKey) | |
144 | + | let assetShortNormBefore = -(valueOrElse(getInteger(futuresMarket, positionFullKey), 0)) | |
145 | + | if ((assetShortNormBefore == assetShortNormBefore)) | |
144 | 146 | then { | |
145 | - | let positionKey = ((toString(this) + "_") + toString(DIR_SHORT)) | |
146 | - | let positionFullKey = toCompositeKey(k_positionSize, positionKey) | |
147 | - | let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey)) | |
148 | - | let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm) | |
149 | - | let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact)) | |
150 | - | let minSpread = minIncreaseSpread() | |
151 | - | if ((spreadFact > minSpread)) | |
147 | + | let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
148 | + | if ((shortFutures == shortFutures)) | |
152 | 149 | then { | |
153 | - | let $t060306100 = getPosition(_asset) | |
154 | - | let longSize = $t060306100._1 | |
155 | - | let shortSize = $t060306100._2 | |
156 | - | let avgSpread = $t060306100._3 | |
157 | - | let moneySpent = $t060306100._4 | |
158 | - | let newLongSize = (longSize + assetBoughtNorm) | |
159 | - | let newShortSize = (shortSize + assetShortNorm) | |
160 | - | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
161 | - | let newMoneySpent = (moneySpent + (_quoteAssetStep * 2)) | |
162 | - | updatePosition(_asset, newLongSize, newShortSize, newAvgSpread, newMoneySpent) | |
150 | + | let assetShortNormAfter = -(getIntegerValue(futuresMarket, positionFullKey)) | |
151 | + | if ((assetShortNormAfter == assetShortNormAfter)) | |
152 | + | then { | |
153 | + | let assetShortNorm = (assetShortNormAfter - assetShortNormBefore) | |
154 | + | let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm) | |
155 | + | let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact)) | |
156 | + | let minSpread = minIncreaseSpread() | |
157 | + | if ((spreadFact > minSpread)) | |
158 | + | then { | |
159 | + | let $t061986268 = getPosition(_asset) | |
160 | + | let longSize = $t061986268._1 | |
161 | + | let shortSize = $t061986268._2 | |
162 | + | let avgSpread = $t061986268._3 | |
163 | + | let moneySpent = $t061986268._4 | |
164 | + | let newLongSize = (longSize + assetBoughtNorm) | |
165 | + | let newShortSize = (shortSize + assetShortNorm) | |
166 | + | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
167 | + | let newMoneySpent = (moneySpent + (_quoteAssetStep * 2)) | |
168 | + | updatePosition(_asset, newLongSize, newShortSize, newAvgSpread, newMoneySpent) | |
169 | + | } | |
170 | + | else { | |
171 | + | let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)] | |
172 | + | throw(("Invalid spread: " + makeString(data, ","))) | |
173 | + | } | |
174 | + | } | |
175 | + | else throw("Strict value is not equal to itself.") | |
163 | 176 | } | |
164 | - | else { | |
165 | - | let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)] | |
166 | - | throw(("Invalid spread: " + makeString(data, ","))) | |
167 | - | } | |
177 | + | else throw("Strict value is not equal to itself.") | |
168 | 178 | } | |
169 | 179 | else throw("Strict value is not equal to itself.") | |
170 | 180 | } | |
171 | 181 | else throw("Strict value is not equal to itself.") | |
172 | 182 | } | |
173 | 183 | else throw("Strict value is not equal to itself.") | |
174 | 184 | } | |
175 | 185 | else throw("Strict value is not equal to itself.") | |
176 | 186 | } | |
177 | 187 | ||
178 | 188 | ||
179 | 189 | ||
180 | 190 | @Callable(i) | |
181 | 191 | func closePosition (_asset) = { | |
182 | 192 | let quoteAsset = getQuoteAsset() | |
183 | 193 | let quoteAssetStr = toBase58String(quoteAsset) | |
184 | 194 | let spotMarket = getSpotMarket(_asset) | |
185 | - | let $ | |
186 | - | let longSize = $ | |
187 | - | let shortSize = $ | |
188 | - | let avgSpread = $ | |
189 | - | let moneySpent = $ | |
195 | + | let $t072407310 = getPosition(_asset) | |
196 | + | let longSize = $t072407310._1 | |
197 | + | let shortSize = $t072407310._2 | |
198 | + | let avgSpread = $t072407310._3 | |
199 | + | let moneySpent = $t072407310._4 | |
190 | 200 | let quoteAssetBefore = getAssetBalance(quoteAssetStr) | |
191 | 201 | if ((quoteAssetBefore == quoteAssetBefore)) | |
192 | 202 | then { | |
193 | 203 | let sellSpot = invoke(spotMarket, "swap", [0, quoteAssetStr, toString(this)], [AttachedPayment(getAssetId(_asset), deNormalize(longSize, _asset))]) | |
194 | 204 | if ((sellSpot == sellSpot)) | |
195 | 205 | then { | |
196 | 206 | let quoteAssetAfter = getAssetBalance(quoteAssetStr) | |
197 | 207 | if ((quoteAssetAfter == quoteAssetAfter)) | |
198 | 208 | then { | |
199 | 209 | let assetSoldFor = (quoteAssetAfter - quoteAssetBefore) | |
200 | 210 | let assetSoldForNorm = normalize(assetSoldFor, quoteAssetStr) | |
201 | 211 | let sellPriceNormFact = divd(assetSoldForNorm, longSize) | |
202 | 212 | let futuresMarket = getFuturesMarket(_asset) | |
203 | 213 | let quoteAssetBefore2 = getAssetBalance(quoteAssetStr) | |
204 | 214 | if ((quoteAssetBefore2 == quoteAssetBefore2)) | |
205 | 215 | then { | |
206 | 216 | let closeShortFutures = invoke(futuresMarket, "closePosition", [shortSize, DIR_SHORT, 0, false, ""], nil) | |
207 | 217 | if ((closeShortFutures == closeShortFutures)) | |
208 | 218 | then { | |
209 | 219 | let quoteAssetAfter2 = getAssetBalance(quoteAssetStr) | |
210 | 220 | if ((quoteAssetAfter2 == quoteAssetAfter2)) | |
211 | 221 | then { | |
212 | 222 | let shortClosedFor = (quoteAssetAfter2 - quoteAssetBefore2) | |
213 | 223 | let shortPriceNormFact = divd(shortClosedFor, shortSize) | |
214 | 224 | let moneyGot = (shortClosedFor + assetSoldFor) | |
215 | 225 | if ((moneyGot > moneySpent)) | |
216 | 226 | then deletePosition(_asset) | |
217 | 227 | else { | |
218 | 228 | let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(moneyGot), toString(moneySpent)] | |
219 | 229 | throw(("Invalid spread for close: " + makeString(data, ","))) | |
220 | 230 | } | |
221 | 231 | } | |
222 | 232 | else throw("Strict value is not equal to itself.") | |
223 | 233 | } | |
224 | 234 | else throw("Strict value is not equal to itself.") | |
225 | 235 | } | |
226 | 236 | else throw("Strict value is not equal to itself.") | |
227 | 237 | } | |
228 | 238 | else throw("Strict value is not equal to itself.") | |
229 | 239 | } | |
230 | 240 | else throw("Strict value is not equal to itself.") | |
231 | 241 | } | |
232 | 242 | else throw("Strict value is not equal to itself.") | |
233 | 243 | } | |
234 | 244 | ||
235 | 245 |
github/deemru/w8io/3ef1775 40.49 ms ◑