tx · 4ys7oSUFgxcDsjzHNdXzfrNnDbnBGK1A2dCeLeeYqxfb

3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT:  -0.01000000 Waves

2023.05.28 13:12 [3663218] smart account 3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT > SELF 0.00000000 Waves

{ "type": 13, "id": "4ys7oSUFgxcDsjzHNdXzfrNnDbnBGK1A2dCeLeeYqxfb", "fee": 1000000, "feeAssetId": null, "timestamp": 1685268763781, "version": 2, "chainId": 87, "sender": "3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT", "senderPublicKey": "7kuQGHmvhzQW3ERxGyMrxfq3LuxHSJ6UdBZcuy498sf6", "proofs": [ "4U4Su4wA8oJpYURJ6krJPyFxpUE6fvKTcjT9esYGDuLaJmkvvn8z24jEzX3Jx5Ro5PAU1ZAKKsBQJjU5yYfSM6S1" ], "script": "base64:BgIfCAISBAoCCAgSAwoBARIFCgMICAgSBAoCCAESAwoBCB0ADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQAB2tfYWRtaW4CB2tfYWRtaW4ABmtfc3RlcAIGa19zdGVwAAxrX3F1b3RlQXNzZXQCDGtfcXVvdGVBc3NldAAMa19zcG90TWFya2V0AgxrX3Nwb3RNYXJrZXQAD2tfZnV0dXJlc01hcmtldAIPa19mdXR1cmVzTWFya2V0ABNrX21pbkluY3JlYXNlU3ByZWFkAhNrX21pbkluY3JlYXNlU3ByZWFkAA5rX3Bvc2l0aW9uTG9uZwIOa19wb3NpdGlvbkxvbmcAD2tfcG9zaXRpb25TaG9ydAIPa19wb3NpdGlvblNob3J0ABBrX3Bvc2l0aW9uU3ByZWFkAhBrX3Bvc2l0aW9uU3ByZWFkAA9rX3Bvc2l0aW9uTW9uZXkCD2tfcG9zaXRpb25Nb25leQAOa19wb3NpdGlvblNpemUCDmtfcG9zaXRpb25TaXplAAxERUNJTUFMX1VOSVQJAGgCAAEJAGgCCQBoAgkAaAIJAGgCCQBoAgAKAAoACgAKAAoACgEEZGl2ZAICX3gCX3kJAG4EBQJfeAUMREVDSU1BTF9VTklUBQJfeQUISEFMRkVWRU4BBG11bGQCAl94Al95CQBuBAUCX3gFAl95BQxERUNJTUFMX1VOSVQFCEhBTEZFVkVOAAlESVJfU0hPUlQAAgEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEMYWRtaW5BZGRyZXNzAAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUHa19hZG1pbgENZ2V0UXVvdGVBc3NldAAJANkEAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUMa19xdW90ZUFzc2V0AQ1nZXRTcG90TWFya2V0AQZfYXNzZXQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFDGtfc3BvdE1hcmtldAUGX2Fzc2V0ARBnZXRGdXR1cmVzTWFya2V0AQZfYXNzZXQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFD2tfZnV0dXJlc01hcmtldAUGX2Fzc2V0ARFtaW5JbmNyZWFzZVNwcmVhZAAJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMFE2tfbWluSW5jcmVhc2VTcHJlYWQBC2dldFBvc2l0aW9uAQZfYXNzZXQECGxvbmdTaXplCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQAAAMJAAACBQhsb25nU2l6ZQAACQCWCgQAAAAAAAAAAAkAlgoEBQhsb25nU2l6ZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFD2tfcG9zaXRpb25Nb25leQUGX2Fzc2V0AAABD2dldEFzc2V0QmFsYW5jZQEGX2Fzc2V0AwkAAAIFBl9hc3NldAIFV0FWRVMICQDvBwEFBHRoaXMHcmVndWxhcgkA8AcCBQR0aGlzCQDZBAEFBl9hc3NldAEKZ2V0QXNzZXRJZAEGX2Fzc2V0AwkAAAIFBl9hc3NldAIFV0FWRVMFBHVuaXQJANkEAQUGX2Fzc2V0AQlub3JtYWxpemUCB19hbW91bnQGX2Fzc2V0BAhkZWNpbWFscwMJAAACBQZfYXNzZXQCBVdBVkVTAAgICQEFdmFsdWUBCQDsBwEJANkEAQUGX2Fzc2V0CGRlY2ltYWxzAwkAAAIFCGRlY2ltYWxzAAgJAGkCBQdfYW1vdW50AGQDCQAAAgUIZGVjaW1hbHMABgUHX2Ftb3VudAkAAgECGkludmFsaWQgZGVjaW1hbHMgZm9yIGFzc2V0AQtkZU5vcm1hbGl6ZQIHX2Ftb3VudAZfYXNzZXQECGRlY2ltYWxzAwkAAAIFBl9hc3NldAIFV0FWRVMACAgJAQV2YWx1ZQEJAOwHAQkA2QQBBQZfYXNzZXQIZGVjaW1hbHMDCQAAAgUIZGVjaW1hbHMACAkAaAIFB19hbW91bnQAZAMJAAACBQhkZWNpbWFscwAGBQdfYW1vdW50CQACAQIaSW52YWxpZCBkZWNpbWFscyBmb3IgYXNzZXQBDnVwZGF0ZVBvc2l0aW9uBQZfYXNzZXQMX25ld0xvbmdTaXplDV9uZXdTaG9ydFNpemUNX25ld0F2Z1NwcmVhZA5fbmV3TW9uZXlTcGVudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvbkxvbmcFBl9hc3NldAUMX25ld0xvbmdTaXplCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAUNX25ld1Nob3J0U2l6ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUQa19wb3NpdGlvblNwcmVhZAUGX2Fzc2V0BQ1fbmV3QXZnU3ByZWFkCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uTW9uZXkFBl9hc3NldAUOX25ld01vbmV5U3BlbnQFA25pbAEOZGVsZXRlUG9zaXRpb24BBl9hc3NldAkAzAgCCQELRGVsZXRlRW50cnkBCQEOdG9Db21wb3NpdGVLZXkCBQ5rX3Bvc2l0aW9uTG9uZwUGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFD2tfcG9zaXRpb25TaG9ydAUGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAkAzAgCCQELRGVsZXRlRW50cnkBCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uTW9uZXkFBl9hc3NldAUDbmlsBQFpAQppbml0aWFsaXplAgZfYWRtaW4LX3F1b3RlQXNzZXQDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhlJbnZhbGlkIGluaXRpYWxpemUgcGFyYW1zCQDMCAIJAQtTdHJpbmdFbnRyeQIFB2tfYWRtaW4FBl9hZG1pbgkAzAgCCQELU3RyaW5nRW50cnkCBQxrX3F1b3RlQXNzZXQFC19xdW90ZUFzc2V0BQNuaWwBaQEOY2hhbmdlU2V0dGluZ3MBEl9taW5JbmNyZWFzZVNwcmVhZAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAh1JbnZhbGlkIGNoYW5nZVNldHRpbmdzIHBhcmFtcwkAzAgCCQEMSW50ZWdlckVudHJ5AgUTa19taW5JbmNyZWFzZVNwcmVhZAUSX21pbkluY3JlYXNlU3ByZWFkBQNuaWwBaQEJYWRkTWFya2V0AwZfYXNzZXQLX3Nwb3RNYXJrZXQOX2Z1dHVyZXNNYXJrZXQDCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MACQACAQIYSW52YWxpZCBhZGRNYXJrZXQgcGFyYW1zCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFDGtfc3BvdE1hcmtldAUGX2Fzc2V0BQtfc3BvdE1hcmtldAkAzAgCCQELU3RyaW5nRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ9rX2Z1dHVyZXNNYXJrZXQFBl9hc3NldAUOX2Z1dHVyZXNNYXJrZXQFA25pbAFpARBpbmNyZWFzZVBvc2l0aW9uAgZfYXNzZXQPX3F1b3RlQXNzZXRTdGVwBApxdW90ZUFzc2V0CQENZ2V0UXVvdGVBc3NldAAECnNwb3RNYXJrZXQJAQ1nZXRTcG90TWFya2V0AQUGX2Fzc2V0BAthc3NldEJlZm9yZQkBD2dldEFzc2V0QmFsYW5jZQEFBl9hc3NldAMJAAACBQthc3NldEJlZm9yZQULYXNzZXRCZWZvcmUEB2J1eVNwb3QJAPwHBAUKc3BvdE1hcmtldAIEc3dhcAkAzAgCAAAJAMwIAgUGX2Fzc2V0CQDMCAIJAKUIAQUEdGhpcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQpxdW90ZUFzc2V0BQ9fcXVvdGVBc3NldFN0ZXAFA25pbAMJAAACBQdidXlTcG90BQdidXlTcG90BAphc3NldEFmdGVyCQEPZ2V0QXNzZXRCYWxhbmNlAQUGX2Fzc2V0AwkAAAIFCmFzc2V0QWZ0ZXIFCmFzc2V0QWZ0ZXIEC2Fzc2V0Qm91Z2h0CQBlAgUKYXNzZXRBZnRlcgULYXNzZXRCZWZvcmUED2Fzc2V0Qm91Z2h0Tm9ybQkBCW5vcm1hbGl6ZQIFC2Fzc2V0Qm91Z2h0BQZfYXNzZXQEEGJ1eVByaWNlTm9ybUZhY3QJAQRkaXZkAgUPX3F1b3RlQXNzZXRTdGVwBQ9hc3NldEJvdWdodE5vcm0EDWZ1dHVyZXNNYXJrZXQJARBnZXRGdXR1cmVzTWFya2V0AQUGX2Fzc2V0BAxzaG9ydEZ1dHVyZXMJAPwHBAUNZnV0dXJlc01hcmtldAIQaW5jcmVhc2VQb3NpdGlvbgkAzAgCBQlESVJfU0hPUlQJAMwIAgUMREVDSU1BTF9VTklUCQDMCAIAAAkAzAgCAgAJAMwIAgIABQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCnF1b3RlQXNzZXQFD19xdW90ZUFzc2V0U3RlcAUDbmlsAwkAAAIFDHNob3J0RnV0dXJlcwUMc2hvcnRGdXR1cmVzBAtwb3NpdGlvbktleQkArAICCQCsAgIJAKUIAQUEdGhpcwIBXwkApAMBBQlESVJfU0hPUlQED3Bvc2l0aW9uRnVsbEtleQkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvblNpemUFC3Bvc2l0aW9uS2V5BA5hc3NldFNob3J0Tm9ybQkBAS0BCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ1mdXR1cmVzTWFya2V0BQ9wb3NpdGlvbkZ1bGxLZXkEEnNob3J0UHJpY2VOb3JtRmFjdAkBBGRpdmQCBQ9fcXVvdGVBc3NldFN0ZXAFDmFzc2V0U2hvcnROb3JtBApzcHJlYWRGYWN0CQBlAgUMREVDSU1BTF9VTklUCQEEZGl2ZAIFEGJ1eVByaWNlTm9ybUZhY3QFEnNob3J0UHJpY2VOb3JtRmFjdAQJbWluU3ByZWFkCQERbWluSW5jcmVhc2VTcHJlYWQAAwkAZgIFCnNwcmVhZEZhY3QFCW1pblNwcmVhZAQLJHQwNjAzMDYxMDAJAQtnZXRQb3NpdGlvbgEFBl9hc3NldAQIbG9uZ1NpemUIBQskdDA2MDMwNjEwMAJfMQQJc2hvcnRTaXplCAULJHQwNjAzMDYxMDACXzIECWF2Z1NwcmVhZAgFCyR0MDYwMzA2MTAwAl8zBAptb25leVNwZW50CAULJHQwNjAzMDYxMDACXzQEC25ld0xvbmdTaXplCQBkAgUIbG9uZ1NpemUFD2Fzc2V0Qm91Z2h0Tm9ybQQMbmV3U2hvcnRTaXplCQBkAgUJc2hvcnRTaXplBQ5hc3NldFNob3J0Tm9ybQQMbmV3QXZnU3ByZWFkCQEEZGl2ZAIJAGQCCQEEbXVsZAIFCWF2Z1NwcmVhZAkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUJAQRtdWxkAgUKc3ByZWFkRmFjdAkAZAIFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0JAGQCCQBkAgkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0EDW5ld01vbmV5U3BlbnQJAGQCBQptb25leVNwZW50CQBoAgUPX3F1b3RlQXNzZXRTdGVwAAIJAQ51cGRhdGVQb3NpdGlvbgUFBl9hc3NldAULbmV3TG9uZ1NpemUFDG5ld1Nob3J0U2l6ZQUMbmV3QXZnU3ByZWFkBQ1uZXdNb25leVNwZW50BARkYXRhCQDMCAIJAKQDAQUPYXNzZXRCb3VnaHROb3JtCQDMCAIJAKQDAQUQYnV5UHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDmFzc2V0U2hvcnROb3JtCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCW1pblNwcmVhZAUDbmlsCQACAQkArAICAhBJbnZhbGlkIHNwcmVhZDogCQC5CQIFBGRhdGECASwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENY2xvc2VQb3NpdGlvbgEGX2Fzc2V0BApxdW90ZUFzc2V0CQENZ2V0UXVvdGVBc3NldAAEDXF1b3RlQXNzZXRTdHIJANgEAQUKcXVvdGVBc3NldAQKc3BvdE1hcmtldAkBDWdldFNwb3RNYXJrZXQBBQZfYXNzZXQECyR0MDcwNzI3MTQyCQELZ2V0UG9zaXRpb24BBQZfYXNzZXQECGxvbmdTaXplCAULJHQwNzA3MjcxNDICXzEECXNob3J0U2l6ZQgFCyR0MDcwNzI3MTQyAl8yBAlhdmdTcHJlYWQIBQskdDA3MDcyNzE0MgJfMwQKbW9uZXlTcGVudAgFCyR0MDcwNzI3MTQyAl80BBBxdW90ZUFzc2V0QmVmb3JlCQEPZ2V0QXNzZXRCYWxhbmNlAQUNcXVvdGVBc3NldFN0cgMJAAACBRBxdW90ZUFzc2V0QmVmb3JlBRBxdW90ZUFzc2V0QmVmb3JlBAhzZWxsU3BvdAkA/AcEBQpzcG90TWFya2V0AgRzd2FwCQDMCAIAAAkAzAgCBQ1xdW90ZUFzc2V0U3RyCQDMCAIJAKUIAQUEdGhpcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEKZ2V0QXNzZXRJZAEFBl9hc3NldAkBC2RlTm9ybWFsaXplAgUIbG9uZ1NpemUFBl9hc3NldAUDbmlsAwkAAAIFCHNlbGxTcG90BQhzZWxsU3BvdAQPcXVvdGVBc3NldEFmdGVyCQEPZ2V0QXNzZXRCYWxhbmNlAQUNcXVvdGVBc3NldFN0cgMJAAACBQ9xdW90ZUFzc2V0QWZ0ZXIFD3F1b3RlQXNzZXRBZnRlcgQMYXNzZXRTb2xkRm9yCQBlAgUPcXVvdGVBc3NldEFmdGVyBRBxdW90ZUFzc2V0QmVmb3JlBBBhc3NldFNvbGRGb3JOb3JtCQEJbm9ybWFsaXplAgUMYXNzZXRTb2xkRm9yBQ1xdW90ZUFzc2V0U3RyBBFzZWxsUHJpY2VOb3JtRmFjdAkBBGRpdmQCBRBhc3NldFNvbGRGb3JOb3JtBQhsb25nU2l6ZQQNZnV0dXJlc01hcmtldAkBEGdldEZ1dHVyZXNNYXJrZXQBBQZfYXNzZXQEEXF1b3RlQXNzZXRCZWZvcmUyCQEPZ2V0QXNzZXRCYWxhbmNlAQUNcXVvdGVBc3NldFN0cgMJAAACBRFxdW90ZUFzc2V0QmVmb3JlMgURcXVvdGVBc3NldEJlZm9yZTIEEWNsb3NlU2hvcnRGdXR1cmVzCQD8BwQFDWZ1dHVyZXNNYXJrZXQCDWNsb3NlUG9zaXRpb24JAMwIAgUJc2hvcnRTaXplCQDMCAIFCURJUl9TSE9SVAkAzAgCAAAJAMwIAgcJAMwIAgIABQNuaWwFA25pbAMJAAACBRFjbG9zZVNob3J0RnV0dXJlcwURY2xvc2VTaG9ydEZ1dHVyZXMEEHF1b3RlQXNzZXRBZnRlcjIJAQ9nZXRBc3NldEJhbGFuY2UBBQ1xdW90ZUFzc2V0U3RyAwkAAAIFEHF1b3RlQXNzZXRBZnRlcjIFEHF1b3RlQXNzZXRBZnRlcjIEDnNob3J0Q2xvc2VkRm9yCQBlAgUQcXVvdGVBc3NldEFmdGVyMgURcXVvdGVBc3NldEJlZm9yZTIEEnNob3J0UHJpY2VOb3JtRmFjdAkBBGRpdmQCBQ5zaG9ydENsb3NlZEZvcgUJc2hvcnRTaXplBAhtb25leUdvdAkAZAIFDnNob3J0Q2xvc2VkRm9yBQxhc3NldFNvbGRGb3IDCQBmAgUIbW9uZXlHb3QFCm1vbmV5U3BlbnQJAQ5kZWxldGVQb3NpdGlvbgEFBl9hc3NldAQEZGF0YQkAzAgCCQCkAwEFEGFzc2V0U29sZEZvck5vcm0JAMwIAgkApAMBBRFzZWxsUHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDnNob3J0Q2xvc2VkRm9yCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUIbW9uZXlHb3QJAMwIAgkApAMBBQptb25leVNwZW50BQNuaWwJAAIBCQCsAgICGkludmFsaWQgc3ByZWFkIGZvciBjbG9zZTogCQC5CQIFBGRhdGECASwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4AQs9jCw==", "height": 3663218, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 435qVExo6v5rMJvrWBdSraNkoEGDYTuuaxcybCjD6kdf Next: 3rYKZE4t4NBdYai78q2yPzKoePBRbGnGYdU4z74m5jwD Diff:
OldNewDifferences
215215 if ((moneyGot > moneySpent))
216216 then deletePosition(_asset)
217217 else {
218- let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact)]
218+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(moneyGot), toString(moneySpent)]
219219 throw(("Invalid spread for close: " + makeString(data, ",")))
220220 }
221221 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let k_initialized = "k_initialized"
55
66 let k_admin = "k_admin"
77
88 let k_step = "k_step"
99
1010 let k_quoteAsset = "k_quoteAsset"
1111
1212 let k_spotMarket = "k_spotMarket"
1313
1414 let k_futuresMarket = "k_futuresMarket"
1515
1616 let k_minIncreaseSpread = "k_minIncreaseSpread"
1717
1818 let k_positionLong = "k_positionLong"
1919
2020 let k_positionShort = "k_positionShort"
2121
2222 let k_positionSpread = "k_positionSpread"
2323
2424 let k_positionMoney = "k_positionMoney"
2525
2626 let k_positionSize = "k_positionSize"
2727
2828 let DECIMAL_UNIT = (1 * (((((10 * 10) * 10) * 10) * 10) * 10))
2929
3030 func divd (_x,_y) = fraction(_x, DECIMAL_UNIT, _y, HALFEVEN)
3131
3232
3333 func muld (_x,_y) = fraction(_x, _y, DECIMAL_UNIT, HALFEVEN)
3434
3535
3636 let DIR_SHORT = 2
3737
3838 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
3939
4040
4141 func adminAddress () = addressFromStringValue(getStringValue(this, k_admin))
4242
4343
4444 func getQuoteAsset () = fromBase58String(getStringValue(this, k_quoteAsset))
4545
4646
4747 func getSpotMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_spotMarket, _asset)))
4848
4949
5050 func getFuturesMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_futuresMarket, _asset)))
5151
5252
5353 func minIncreaseSpread () = getIntegerValue(this, k_minIncreaseSpread)
5454
5555
5656 func getPosition (_asset) = {
5757 let longSize = valueOrElse(getInteger(this, toCompositeKey(k_positionLong, _asset)), 0)
5858 if ((longSize == 0))
5959 then $Tuple4(0, 0, 0, 0)
6060 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))
6161 }
6262
6363
6464 func getAssetBalance (_asset) = if ((_asset == "WAVES"))
6565 then wavesBalance(this).regular
6666 else assetBalance(this, fromBase58String(_asset))
6767
6868
6969 func getAssetId (_asset) = if ((_asset == "WAVES"))
7070 then unit
7171 else fromBase58String(_asset)
7272
7373
7474 func normalize (_amount,_asset) = {
7575 let decimals = if ((_asset == "WAVES"))
7676 then 8
7777 else value(assetInfo(fromBase58String(_asset))).decimals
7878 if ((decimals == 8))
7979 then (_amount / 100)
8080 else if ((decimals == 6))
8181 then _amount
8282 else throw("Invalid decimals for asset")
8383 }
8484
8585
8686 func deNormalize (_amount,_asset) = {
8787 let decimals = if ((_asset == "WAVES"))
8888 then 8
8989 else value(assetInfo(fromBase58String(_asset))).decimals
9090 if ((decimals == 8))
9191 then (_amount * 100)
9292 else if ((decimals == 6))
9393 then _amount
9494 else throw("Invalid decimals for asset")
9595 }
9696
9797
9898 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)]
9999
100100
101101 func deletePosition (_asset) = [DeleteEntry(toCompositeKey(k_positionLong, _asset)), DeleteEntry(toCompositeKey(k_positionShort, _asset)), DeleteEntry(toCompositeKey(k_positionSpread, _asset)), DeleteEntry(toCompositeKey(k_positionMoney, _asset))]
102102
103103
104104 @Callable(i)
105105 func initialize (_admin,_quoteAsset) = if ((i.caller != this))
106106 then throw("Invalid initialize params")
107107 else [StringEntry(k_admin, _admin), StringEntry(k_quoteAsset, _quoteAsset)]
108108
109109
110110
111111 @Callable(i)
112112 func changeSettings (_minIncreaseSpread) = if ((i.caller != adminAddress()))
113113 then throw("Invalid changeSettings params")
114114 else [IntegerEntry(k_minIncreaseSpread, _minIncreaseSpread)]
115115
116116
117117
118118 @Callable(i)
119119 func addMarket (_asset,_spotMarket,_futuresMarket) = if ((i.caller != adminAddress()))
120120 then throw("Invalid addMarket params")
121121 else [StringEntry(toCompositeKey(k_spotMarket, _asset), _spotMarket), StringEntry(toCompositeKey(k_futuresMarket, _asset), _futuresMarket)]
122122
123123
124124
125125 @Callable(i)
126126 func increasePosition (_asset,_quoteAssetStep) = {
127127 let quoteAsset = getQuoteAsset()
128128 let spotMarket = getSpotMarket(_asset)
129129 let assetBefore = getAssetBalance(_asset)
130130 if ((assetBefore == assetBefore))
131131 then {
132132 let buySpot = invoke(spotMarket, "swap", [0, _asset, toString(this)], [AttachedPayment(quoteAsset, _quoteAssetStep)])
133133 if ((buySpot == buySpot))
134134 then {
135135 let assetAfter = getAssetBalance(_asset)
136136 if ((assetAfter == assetAfter))
137137 then {
138138 let assetBought = (assetAfter - assetBefore)
139139 let assetBoughtNorm = normalize(assetBought, _asset)
140140 let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm)
141141 let futuresMarket = getFuturesMarket(_asset)
142142 let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)])
143143 if ((shortFutures == shortFutures))
144144 then {
145145 let positionKey = ((toString(this) + "_") + toString(DIR_SHORT))
146146 let positionFullKey = toCompositeKey(k_positionSize, positionKey)
147147 let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey))
148148 let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm)
149149 let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact))
150150 let minSpread = minIncreaseSpread()
151151 if ((spreadFact > minSpread))
152152 then {
153153 let $t060306100 = getPosition(_asset)
154154 let longSize = $t060306100._1
155155 let shortSize = $t060306100._2
156156 let avgSpread = $t060306100._3
157157 let moneySpent = $t060306100._4
158158 let newLongSize = (longSize + assetBoughtNorm)
159159 let newShortSize = (shortSize + assetShortNorm)
160160 let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm))
161161 let newMoneySpent = (moneySpent + (_quoteAssetStep * 2))
162162 updatePosition(_asset, newLongSize, newShortSize, newAvgSpread, newMoneySpent)
163163 }
164164 else {
165165 let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)]
166166 throw(("Invalid spread: " + makeString(data, ",")))
167167 }
168168 }
169169 else throw("Strict value is not equal to itself.")
170170 }
171171 else throw("Strict value is not equal to itself.")
172172 }
173173 else throw("Strict value is not equal to itself.")
174174 }
175175 else throw("Strict value is not equal to itself.")
176176 }
177177
178178
179179
180180 @Callable(i)
181181 func closePosition (_asset) = {
182182 let quoteAsset = getQuoteAsset()
183183 let quoteAssetStr = toBase58String(quoteAsset)
184184 let spotMarket = getSpotMarket(_asset)
185185 let $t070727142 = getPosition(_asset)
186186 let longSize = $t070727142._1
187187 let shortSize = $t070727142._2
188188 let avgSpread = $t070727142._3
189189 let moneySpent = $t070727142._4
190190 let quoteAssetBefore = getAssetBalance(quoteAssetStr)
191191 if ((quoteAssetBefore == quoteAssetBefore))
192192 then {
193193 let sellSpot = invoke(spotMarket, "swap", [0, quoteAssetStr, toString(this)], [AttachedPayment(getAssetId(_asset), deNormalize(longSize, _asset))])
194194 if ((sellSpot == sellSpot))
195195 then {
196196 let quoteAssetAfter = getAssetBalance(quoteAssetStr)
197197 if ((quoteAssetAfter == quoteAssetAfter))
198198 then {
199199 let assetSoldFor = (quoteAssetAfter - quoteAssetBefore)
200200 let assetSoldForNorm = normalize(assetSoldFor, quoteAssetStr)
201201 let sellPriceNormFact = divd(assetSoldForNorm, longSize)
202202 let futuresMarket = getFuturesMarket(_asset)
203203 let quoteAssetBefore2 = getAssetBalance(quoteAssetStr)
204204 if ((quoteAssetBefore2 == quoteAssetBefore2))
205205 then {
206206 let closeShortFutures = invoke(futuresMarket, "closePosition", [shortSize, DIR_SHORT, 0, false, ""], nil)
207207 if ((closeShortFutures == closeShortFutures))
208208 then {
209209 let quoteAssetAfter2 = getAssetBalance(quoteAssetStr)
210210 if ((quoteAssetAfter2 == quoteAssetAfter2))
211211 then {
212212 let shortClosedFor = (quoteAssetAfter2 - quoteAssetBefore2)
213213 let shortPriceNormFact = divd(shortClosedFor, shortSize)
214214 let moneyGot = (shortClosedFor + assetSoldFor)
215215 if ((moneyGot > moneySpent))
216216 then deletePosition(_asset)
217217 else {
218- let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact)]
218+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(moneyGot), toString(moneySpent)]
219219 throw(("Invalid spread for close: " + makeString(data, ",")))
220220 }
221221 }
222222 else throw("Strict value is not equal to itself.")
223223 }
224224 else throw("Strict value is not equal to itself.")
225225 }
226226 else throw("Strict value is not equal to itself.")
227227 }
228228 else throw("Strict value is not equal to itself.")
229229 }
230230 else throw("Strict value is not equal to itself.")
231231 }
232232 else throw("Strict value is not equal to itself.")
233233 }
234234
235235

github/deemru/w8io/6500d08 
34.82 ms