tx · 4PPDzhWH9E1T3Bhwmg6inSGe2BqMt1ssvJqPgTWkQ4vz

3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT:  -0.01000000 Waves

2023.05.28 12:48 [3663192] smart account 3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT > SELF 0.00000000 Waves

{ "type": 13, "id": "4PPDzhWH9E1T3Bhwmg6inSGe2BqMt1ssvJqPgTWkQ4vz", "fee": 1000000, "feeAssetId": null, "timestamp": 1685267390327, "version": 2, "chainId": 87, "sender": "3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT", "senderPublicKey": "7kuQGHmvhzQW3ERxGyMrxfq3LuxHSJ6UdBZcuy498sf6", "proofs": [ "55m4Q8TJU1bRxncfRGoxMDecPMjKnLKg3GqTDsLg3wy8Nwgerrq9quSMCS4HSJ8LwKrKZsrEV9gXLCRy33QTJKNR" ], "script": "base64:BgIfCAISBAoCCAgSAwoBARIFCgMICAgSBAoCCAESAwoBCBwADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQAB2tfYWRtaW4CB2tfYWRtaW4ABmtfc3RlcAIGa19zdGVwAAxrX3F1b3RlQXNzZXQCDGtfcXVvdGVBc3NldAAMa19zcG90TWFya2V0AgxrX3Nwb3RNYXJrZXQAD2tfZnV0dXJlc01hcmtldAIPa19mdXR1cmVzTWFya2V0ABNrX21pbkluY3JlYXNlU3ByZWFkAhNrX21pbkluY3JlYXNlU3ByZWFkAA5rX3Bvc2l0aW9uTG9uZwIOa19wb3NpdGlvbkxvbmcAD2tfcG9zaXRpb25TaG9ydAIPa19wb3NpdGlvblNob3J0ABBrX3Bvc2l0aW9uU3ByZWFkAhBrX3Bvc2l0aW9uU3ByZWFkAA5rX3Bvc2l0aW9uU2l6ZQIOa19wb3NpdGlvblNpemUADERFQ0lNQUxfVU5JVAkAaAIAAQkAaAIJAGgCCQBoAgkAaAIJAGgCAAoACgAKAAoACgAKAQRkaXZkAgJfeAJfeQkAbgQFAl94BQxERUNJTUFMX1VOSVQFAl95BQhIQUxGRVZFTgEEbXVsZAICX3gCX3kJAG4EBQJfeAUCX3kFDERFQ0lNQUxfVU5JVAUISEFMRkVWRU4ACURJUl9TSE9SVAACAQ50b0NvbXBvc2l0ZUtleQIEX2tleQhfYWRkcmVzcwkArAICCQCsAgIFBF9rZXkCAV8FCF9hZGRyZXNzAQxhZG1pbkFkZHJlc3MACQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQdrX2FkbWluAQ1nZXRRdW90ZUFzc2V0AAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQxrX3F1b3RlQXNzZXQBDWdldFNwb3RNYXJrZXQBBl9hc3NldAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUMa19zcG90TWFya2V0BQZfYXNzZXQBEGdldEZ1dHVyZXNNYXJrZXQBBl9hc3NldAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUPa19mdXR1cmVzTWFya2V0BQZfYXNzZXQBEW1pbkluY3JlYXNlU3ByZWFkAAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUTa19taW5JbmNyZWFzZVNwcmVhZAELZ2V0UG9zaXRpb24BBl9hc3NldAQIbG9uZ1NpemUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvbkxvbmcFBl9hc3NldAAAAwkAAAIFCGxvbmdTaXplAAAJAJUKAwAAAAAAAAkAlQoDBQhsb25nU2l6ZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAAAAQ9nZXRBc3NldEJhbGFuY2UBBl9hc3NldAMJAAACBQZfYXNzZXQCBVdBVkVTCAkA7wcBBQR0aGlzB3JlZ3VsYXIJAPAHAgUEdGhpcwkA2QQBBQZfYXNzZXQBCmdldEFzc2V0SWQBBl9hc3NldAMJAAACBQZfYXNzZXQCBVdBVkVTBQR1bml0CQDZBAEFBl9hc3NldAEJbm9ybWFsaXplAgdfYW1vdW50Bl9hc3NldAQIZGVjaW1hbHMDCQAAAgUGX2Fzc2V0AgVXQVZFUwAICAkBBXZhbHVlAQkA7AcBCQDZBAEFBl9hc3NldAhkZWNpbWFscwMJAAACBQhkZWNpbWFscwAICQBpAgUHX2Ftb3VudABkAwkAAAIFCGRlY2ltYWxzAAYFB19hbW91bnQJAAIBAhpJbnZhbGlkIGRlY2ltYWxzIGZvciBhc3NldAELZGVOb3JtYWxpemUCB19hbW91bnQGX2Fzc2V0BAhkZWNpbWFscwMJAAACBQZfYXNzZXQCBVdBVkVTAAgICQEFdmFsdWUBCQDsBwEJANkEAQUGX2Fzc2V0CGRlY2ltYWxzAwkAAAIFCGRlY2ltYWxzAAgJAGgCBQdfYW1vdW50AGQDCQAAAgUIZGVjaW1hbHMABgUHX2Ftb3VudAkAAgECGkludmFsaWQgZGVjaW1hbHMgZm9yIGFzc2V0AQ51cGRhdGVQb3NpdGlvbgQGX2Fzc2V0DF9uZXdMb25nU2l6ZQ1fbmV3U2hvcnRTaXplDV9uZXdBdmdTcHJlYWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQFDF9uZXdMb25nU2l6ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUPa19wb3NpdGlvblNob3J0BQZfYXNzZXQFDV9uZXdTaG9ydFNpemUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAUNX25ld0F2Z1NwcmVhZAUDbmlsAQ5kZWxldGVQb3NpdGlvbgEGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDnRvQ29tcG9zaXRlS2V5AgUPa19wb3NpdGlvblNob3J0BQZfYXNzZXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDnRvQ29tcG9zaXRlS2V5AgUQa19wb3NpdGlvblNwcmVhZAUGX2Fzc2V0BQNuaWwFAWkBCmluaXRpYWxpemUCBl9hZG1pbgtfcXVvdGVBc3NldAMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECGUludmFsaWQgaW5pdGlhbGl6ZSBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgUHa19hZG1pbgUGX2FkbWluCQDMCAIJAQtTdHJpbmdFbnRyeQIFDGtfcXVvdGVBc3NldAULX3F1b3RlQXNzZXQFA25pbAFpAQ5jaGFuZ2VTZXR0aW5ncwESX21pbkluY3JlYXNlU3ByZWFkAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECHUludmFsaWQgY2hhbmdlU2V0dGluZ3MgcGFyYW1zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNrX21pbkluY3JlYXNlU3ByZWFkBRJfbWluSW5jcmVhc2VTcHJlYWQFA25pbAFpAQlhZGRNYXJrZXQDBl9hc3NldAtfc3BvdE1hcmtldA5fZnV0dXJlc01hcmtldAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhhJbnZhbGlkIGFkZE1hcmtldCBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUMa19zcG90TWFya2V0BQZfYXNzZXQFC19zcG90TWFya2V0CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFD2tfZnV0dXJlc01hcmtldAUGX2Fzc2V0BQ5fZnV0dXJlc01hcmtldAUDbmlsAWkBEGluY3JlYXNlUG9zaXRpb24CBl9hc3NldA9fcXVvdGVBc3NldFN0ZXAECnF1b3RlQXNzZXQJAQ1nZXRRdW90ZUFzc2V0AAQKc3BvdE1hcmtldAkBDWdldFNwb3RNYXJrZXQBBQZfYXNzZXQEC2Fzc2V0QmVmb3JlCQEPZ2V0QXNzZXRCYWxhbmNlAQUGX2Fzc2V0AwkAAAIFC2Fzc2V0QmVmb3JlBQthc3NldEJlZm9yZQQHYnV5U3BvdAkA/AcEBQpzcG90TWFya2V0AgRzd2FwCQDMCAIAAAkAzAgCBQZfYXNzZXQJAMwIAgkApQgBBQR0aGlzBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCnF1b3RlQXNzZXQFD19xdW90ZUFzc2V0U3RlcAUDbmlsAwkAAAIFB2J1eVNwb3QFB2J1eVNwb3QECmFzc2V0QWZ0ZXIJAQ9nZXRBc3NldEJhbGFuY2UBBQZfYXNzZXQDCQAAAgUKYXNzZXRBZnRlcgUKYXNzZXRBZnRlcgQLYXNzZXRCb3VnaHQJAGUCBQphc3NldEFmdGVyBQthc3NldEJlZm9yZQQPYXNzZXRCb3VnaHROb3JtCQEJbm9ybWFsaXplAgULYXNzZXRCb3VnaHQFBl9hc3NldAQQYnV5UHJpY2VOb3JtRmFjdAkBBGRpdmQCBQ9fcXVvdGVBc3NldFN0ZXAFD2Fzc2V0Qm91Z2h0Tm9ybQQNZnV0dXJlc01hcmtldAkBEGdldEZ1dHVyZXNNYXJrZXQBBQZfYXNzZXQEDHNob3J0RnV0dXJlcwkA/AcEBQ1mdXR1cmVzTWFya2V0AhBpbmNyZWFzZVBvc2l0aW9uCQDMCAIFCURJUl9TSE9SVAkAzAgCBQxERUNJTUFMX1VOSVQJAMwIAgAACQDMCAICAAkAzAgCAgAFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUKcXVvdGVBc3NldAUPX3F1b3RlQXNzZXRTdGVwBQNuaWwDCQAAAgUMc2hvcnRGdXR1cmVzBQxzaG9ydEZ1dHVyZXMEC3Bvc2l0aW9uS2V5CQCsAgIJAKwCAgkApQgBBQR0aGlzAgFfCQCkAwEFCURJUl9TSE9SVAQPcG9zaXRpb25GdWxsS2V5CQEOdG9Db21wb3NpdGVLZXkCBQ5rX3Bvc2l0aW9uU2l6ZQULcG9zaXRpb25LZXkEDmFzc2V0U2hvcnROb3JtCQEBLQEJARFAZXh0ck5hdGl2ZSgxMDUwKQIFDWZ1dHVyZXNNYXJrZXQFD3Bvc2l0aW9uRnVsbEtleQQSc2hvcnRQcmljZU5vcm1GYWN0CQEEZGl2ZAIFD19xdW90ZUFzc2V0U3RlcAUOYXNzZXRTaG9ydE5vcm0ECnNwcmVhZEZhY3QJAGUCBQxERUNJTUFMX1VOSVQJAQRkaXZkAgUQYnV5UHJpY2VOb3JtRmFjdAUSc2hvcnRQcmljZU5vcm1GYWN0BAltaW5TcHJlYWQJARFtaW5JbmNyZWFzZVNwcmVhZAADCQBmAgUKc3ByZWFkRmFjdAUJbWluU3ByZWFkBAskdDA1NzQ0NTgwMgkBC2dldFBvc2l0aW9uAQUGX2Fzc2V0BAhsb25nU2l6ZQgFCyR0MDU3NDQ1ODAyAl8xBAlzaG9ydFNpemUIBQskdDA1NzQ0NTgwMgJfMgQJYXZnU3ByZWFkCAULJHQwNTc0NDU4MDICXzMEC25ld0xvbmdTaXplCQBkAgUIbG9uZ1NpemUFD2Fzc2V0Qm91Z2h0Tm9ybQQMbmV3U2hvcnRTaXplCQBkAgUJc2hvcnRTaXplBQ5hc3NldFNob3J0Tm9ybQQMbmV3QXZnU3ByZWFkCQEEZGl2ZAIJAGQCCQEEbXVsZAIFCWF2Z1NwcmVhZAkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUJAQRtdWxkAgUKc3ByZWFkRmFjdAkAZAIFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0JAGQCCQBkAgkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0JAQ51cGRhdGVQb3NpdGlvbgQFBl9hc3NldAULbmV3TG9uZ1NpemUFDG5ld1Nob3J0U2l6ZQUMbmV3QXZnU3ByZWFkBARkYXRhCQDMCAIJAKQDAQUPYXNzZXRCb3VnaHROb3JtCQDMCAIJAKQDAQUQYnV5UHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDmFzc2V0U2hvcnROb3JtCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCW1pblNwcmVhZAUDbmlsCQACAQkArAICAhBJbnZhbGlkIHNwcmVhZDogCQC5CQIFBGRhdGECASwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENY2xvc2VQb3NpdGlvbgEGX2Fzc2V0BApxdW90ZUFzc2V0CQENZ2V0UXVvdGVBc3NldAAEDXF1b3RlQXNzZXRTdHIJANgEAQUKcXVvdGVBc3NldAQKc3BvdE1hcmtldAkBDWdldFNwb3RNYXJrZXQBBQZfYXNzZXQECyR0MDY2OTg2NzU2CQELZ2V0UG9zaXRpb24BBQZfYXNzZXQECGxvbmdTaXplCAULJHQwNjY5ODY3NTYCXzEECXNob3J0U2l6ZQgFCyR0MDY2OTg2NzU2Al8yBAlhdmdTcHJlYWQIBQskdDA2Njk4Njc1NgJfMwQQcXVvdGVBc3NldEJlZm9yZQkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgUQcXVvdGVBc3NldEJlZm9yZQUQcXVvdGVBc3NldEJlZm9yZQQIc2VsbFNwb3QJAPwHBAUKc3BvdE1hcmtldAIEc3dhcAkAzAgCAAAJAMwIAgUNcXVvdGVBc3NldFN0cgkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBCmdldEFzc2V0SWQBBQZfYXNzZXQJAQtkZU5vcm1hbGl6ZQIFCGxvbmdTaXplBQZfYXNzZXQFA25pbAMJAAACBQhzZWxsU3BvdAUIc2VsbFNwb3QED3F1b3RlQXNzZXRBZnRlcgkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgUPcXVvdGVBc3NldEFmdGVyBQ9xdW90ZUFzc2V0QWZ0ZXIEDGFzc2V0U29sZEZvcgkAZQIFD3F1b3RlQXNzZXRBZnRlcgUQcXVvdGVBc3NldEJlZm9yZQQQYXNzZXRTb2xkRm9yTm9ybQkBCW5vcm1hbGl6ZQIFDGFzc2V0U29sZEZvcgUNcXVvdGVBc3NldFN0cgQRc2VsbFByaWNlTm9ybUZhY3QJAQRkaXZkAgUQYXNzZXRTb2xkRm9yTm9ybQUIbG9uZ1NpemUEDWZ1dHVyZXNNYXJrZXQJARBnZXRGdXR1cmVzTWFya2V0AQUGX2Fzc2V0BBFxdW90ZUFzc2V0QmVmb3JlMgkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgURcXVvdGVBc3NldEJlZm9yZTIFEXF1b3RlQXNzZXRCZWZvcmUyBBFjbG9zZVNob3J0RnV0dXJlcwkA/AcEBQ1mdXR1cmVzTWFya2V0Ag1jbG9zZVBvc2l0aW9uCQDMCAIFCXNob3J0U2l6ZQkAzAgCBQlESVJfU0hPUlQJAMwIAgAACQDMCAIHCQDMCAICAAUDbmlsBQNuaWwDCQAAAgURY2xvc2VTaG9ydEZ1dHVyZXMFEWNsb3NlU2hvcnRGdXR1cmVzBBBxdW90ZUFzc2V0QWZ0ZXIyCQEPZ2V0QXNzZXRCYWxhbmNlAQUNcXVvdGVBc3NldFN0cgMJAAACBRBxdW90ZUFzc2V0QWZ0ZXIyBRBxdW90ZUFzc2V0QWZ0ZXIyBA5zaG9ydENsb3NlZEZvcgkAZQIFEHF1b3RlQXNzZXRBZnRlcjIFEXF1b3RlQXNzZXRCZWZvcmUyBBJzaG9ydFByaWNlTm9ybUZhY3QJAQRkaXZkAgUOc2hvcnRDbG9zZWRGb3IFCXNob3J0U2l6ZQQKc3ByZWFkRmFjdAkAZQIFDERFQ0lNQUxfVU5JVAkBBGRpdmQCBRJzaG9ydFByaWNlTm9ybUZhY3QFEXNlbGxQcmljZU5vcm1GYWN0AwkAZgIFCWF2Z1NwcmVhZAUKc3ByZWFkRmFjdAQEZGF0YQkAzAgCCQCkAwEFEGFzc2V0U29sZEZvck5vcm0JAMwIAgkApAMBBRFzZWxsUHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDnNob3J0Q2xvc2VkRm9yCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCWF2Z1NwcmVhZAUDbmlsCQACAQkArAICAhhWYWxpZCBzcHJlYWQgZm9yIGNsb3NlOiAJALkJAgUEZGF0YQIBLAQEZGF0YQkAzAgCCQCkAwEFEGFzc2V0U29sZEZvck5vcm0JAMwIAgkApAMBBRFzZWxsUHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDnNob3J0Q2xvc2VkRm9yCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCWF2Z1NwcmVhZAUDbmlsCQACAQkArAICAhpJbnZhbGlkIHNwcmVhZCBmb3IgY2xvc2U6IAkAuQkCBQRkYXRhAgEsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAOpXCcc=", "height": 3663192, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HWaQBoLmTu614A7oUU8JajGSxUS7ktEZEoG2bhmJL616 Next: 435qVExo6v5rMJvrWBdSraNkoEGDYTuuaxcybCjD6kdf Diff:
OldNewDifferences
208208 let shortPriceNormFact = divd(shortClosedFor, shortSize)
209209 let spreadFact = (DECIMAL_UNIT - divd(shortPriceNormFact, sellPriceNormFact))
210210 if ((avgSpread > spreadFact))
211- then deletePosition(_asset)
211+ then {
212+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
213+ throw(("Valid spread for close: " + makeString(data, ",")))
214+ }
212215 else {
213216 let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
214217 throw(("Invalid spread for close: " + makeString(data, ",")))
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_positionSize = "k_positionSize"
2525
2626 let DECIMAL_UNIT = (1 * (((((10 * 10) * 10) * 10) * 10) * 10))
2727
2828 func divd (_x,_y) = fraction(_x, DECIMAL_UNIT, _y, HALFEVEN)
2929
3030
3131 func muld (_x,_y) = fraction(_x, _y, DECIMAL_UNIT, HALFEVEN)
3232
3333
3434 let DIR_SHORT = 2
3535
3636 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
3737
3838
3939 func adminAddress () = addressFromStringValue(getStringValue(this, k_admin))
4040
4141
4242 func getQuoteAsset () = fromBase58String(getStringValue(this, k_quoteAsset))
4343
4444
4545 func getSpotMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_spotMarket, _asset)))
4646
4747
4848 func getFuturesMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_futuresMarket, _asset)))
4949
5050
5151 func minIncreaseSpread () = getIntegerValue(this, k_minIncreaseSpread)
5252
5353
5454 func getPosition (_asset) = {
5555 let longSize = valueOrElse(getInteger(this, toCompositeKey(k_positionLong, _asset)), 0)
5656 if ((longSize == 0))
5757 then $Tuple3(0, 0, 0)
5858 else $Tuple3(longSize, valueOrElse(getInteger(this, toCompositeKey(k_positionShort, _asset)), 0), valueOrElse(getInteger(this, toCompositeKey(k_positionSpread, _asset)), 0))
5959 }
6060
6161
6262 func getAssetBalance (_asset) = if ((_asset == "WAVES"))
6363 then wavesBalance(this).regular
6464 else assetBalance(this, fromBase58String(_asset))
6565
6666
6767 func getAssetId (_asset) = if ((_asset == "WAVES"))
6868 then unit
6969 else fromBase58String(_asset)
7070
7171
7272 func normalize (_amount,_asset) = {
7373 let decimals = if ((_asset == "WAVES"))
7474 then 8
7575 else value(assetInfo(fromBase58String(_asset))).decimals
7676 if ((decimals == 8))
7777 then (_amount / 100)
7878 else if ((decimals == 6))
7979 then _amount
8080 else throw("Invalid decimals for asset")
8181 }
8282
8383
8484 func deNormalize (_amount,_asset) = {
8585 let decimals = if ((_asset == "WAVES"))
8686 then 8
8787 else value(assetInfo(fromBase58String(_asset))).decimals
8888 if ((decimals == 8))
8989 then (_amount * 100)
9090 else if ((decimals == 6))
9191 then _amount
9292 else throw("Invalid decimals for asset")
9393 }
9494
9595
9696 func updatePosition (_asset,_newLongSize,_newShortSize,_newAvgSpread) = [IntegerEntry(toCompositeKey(k_positionLong, _asset), _newLongSize), IntegerEntry(toCompositeKey(k_positionShort, _asset), _newShortSize), IntegerEntry(toCompositeKey(k_positionSpread, _asset), _newAvgSpread)]
9797
9898
9999 func deletePosition (_asset) = [DeleteEntry(toCompositeKey(k_positionLong, _asset)), DeleteEntry(toCompositeKey(k_positionShort, _asset)), DeleteEntry(toCompositeKey(k_positionSpread, _asset))]
100100
101101
102102 @Callable(i)
103103 func initialize (_admin,_quoteAsset) = if ((i.caller != this))
104104 then throw("Invalid initialize params")
105105 else [StringEntry(k_admin, _admin), StringEntry(k_quoteAsset, _quoteAsset)]
106106
107107
108108
109109 @Callable(i)
110110 func changeSettings (_minIncreaseSpread) = if ((i.caller != adminAddress()))
111111 then throw("Invalid changeSettings params")
112112 else [IntegerEntry(k_minIncreaseSpread, _minIncreaseSpread)]
113113
114114
115115
116116 @Callable(i)
117117 func addMarket (_asset,_spotMarket,_futuresMarket) = if ((i.caller != adminAddress()))
118118 then throw("Invalid addMarket params")
119119 else [StringEntry(toCompositeKey(k_spotMarket, _asset), _spotMarket), StringEntry(toCompositeKey(k_futuresMarket, _asset), _futuresMarket)]
120120
121121
122122
123123 @Callable(i)
124124 func increasePosition (_asset,_quoteAssetStep) = {
125125 let quoteAsset = getQuoteAsset()
126126 let spotMarket = getSpotMarket(_asset)
127127 let assetBefore = getAssetBalance(_asset)
128128 if ((assetBefore == assetBefore))
129129 then {
130130 let buySpot = invoke(spotMarket, "swap", [0, _asset, toString(this)], [AttachedPayment(quoteAsset, _quoteAssetStep)])
131131 if ((buySpot == buySpot))
132132 then {
133133 let assetAfter = getAssetBalance(_asset)
134134 if ((assetAfter == assetAfter))
135135 then {
136136 let assetBought = (assetAfter - assetBefore)
137137 let assetBoughtNorm = normalize(assetBought, _asset)
138138 let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm)
139139 let futuresMarket = getFuturesMarket(_asset)
140140 let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)])
141141 if ((shortFutures == shortFutures))
142142 then {
143143 let positionKey = ((toString(this) + "_") + toString(DIR_SHORT))
144144 let positionFullKey = toCompositeKey(k_positionSize, positionKey)
145145 let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey))
146146 let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm)
147147 let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact))
148148 let minSpread = minIncreaseSpread()
149149 if ((spreadFact > minSpread))
150150 then {
151151 let $t057445802 = getPosition(_asset)
152152 let longSize = $t057445802._1
153153 let shortSize = $t057445802._2
154154 let avgSpread = $t057445802._3
155155 let newLongSize = (longSize + assetBoughtNorm)
156156 let newShortSize = (shortSize + assetShortNorm)
157157 let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm))
158158 updatePosition(_asset, newLongSize, newShortSize, newAvgSpread)
159159 }
160160 else {
161161 let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)]
162162 throw(("Invalid spread: " + makeString(data, ",")))
163163 }
164164 }
165165 else throw("Strict value is not equal to itself.")
166166 }
167167 else throw("Strict value is not equal to itself.")
168168 }
169169 else throw("Strict value is not equal to itself.")
170170 }
171171 else throw("Strict value is not equal to itself.")
172172 }
173173
174174
175175
176176 @Callable(i)
177177 func closePosition (_asset) = {
178178 let quoteAsset = getQuoteAsset()
179179 let quoteAssetStr = toBase58String(quoteAsset)
180180 let spotMarket = getSpotMarket(_asset)
181181 let $t066986756 = getPosition(_asset)
182182 let longSize = $t066986756._1
183183 let shortSize = $t066986756._2
184184 let avgSpread = $t066986756._3
185185 let quoteAssetBefore = getAssetBalance(quoteAssetStr)
186186 if ((quoteAssetBefore == quoteAssetBefore))
187187 then {
188188 let sellSpot = invoke(spotMarket, "swap", [0, quoteAssetStr, toString(this)], [AttachedPayment(getAssetId(_asset), deNormalize(longSize, _asset))])
189189 if ((sellSpot == sellSpot))
190190 then {
191191 let quoteAssetAfter = getAssetBalance(quoteAssetStr)
192192 if ((quoteAssetAfter == quoteAssetAfter))
193193 then {
194194 let assetSoldFor = (quoteAssetAfter - quoteAssetBefore)
195195 let assetSoldForNorm = normalize(assetSoldFor, quoteAssetStr)
196196 let sellPriceNormFact = divd(assetSoldForNorm, longSize)
197197 let futuresMarket = getFuturesMarket(_asset)
198198 let quoteAssetBefore2 = getAssetBalance(quoteAssetStr)
199199 if ((quoteAssetBefore2 == quoteAssetBefore2))
200200 then {
201201 let closeShortFutures = invoke(futuresMarket, "closePosition", [shortSize, DIR_SHORT, 0, false, ""], nil)
202202 if ((closeShortFutures == closeShortFutures))
203203 then {
204204 let quoteAssetAfter2 = getAssetBalance(quoteAssetStr)
205205 if ((quoteAssetAfter2 == quoteAssetAfter2))
206206 then {
207207 let shortClosedFor = (quoteAssetAfter2 - quoteAssetBefore2)
208208 let shortPriceNormFact = divd(shortClosedFor, shortSize)
209209 let spreadFact = (DECIMAL_UNIT - divd(shortPriceNormFact, sellPriceNormFact))
210210 if ((avgSpread > spreadFact))
211- then deletePosition(_asset)
211+ then {
212+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
213+ throw(("Valid spread for close: " + makeString(data, ",")))
214+ }
212215 else {
213216 let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
214217 throw(("Invalid spread for close: " + makeString(data, ",")))
215218 }
216219 }
217220 else throw("Strict value is not equal to itself.")
218221 }
219222 else throw("Strict value is not equal to itself.")
220223 }
221224 else throw("Strict value is not equal to itself.")
222225 }
223226 else throw("Strict value is not equal to itself.")
224227 }
225228 else throw("Strict value is not equal to itself.")
226229 }
227230 else throw("Strict value is not equal to itself.")
228231 }
229232
230233

github/deemru/w8io/6500d08 
45.80 ms