tx · 33LTp7GzK57XGqba9MPmw1NEukQCHKAQrEQ6ZoMj77pi

3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT:  -0.01000000 Waves

2023.05.28 12:40 [3663185] smart account 3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT > SELF 0.00000000 Waves

{ "type": 13, "id": "33LTp7GzK57XGqba9MPmw1NEukQCHKAQrEQ6ZoMj77pi", "fee": 1000000, "feeAssetId": null, "timestamp": 1685266870400, "version": 2, "chainId": 87, "sender": "3PPEo6YV7XpCFknum9FNVLQuCu3x7AogcJT", "senderPublicKey": "7kuQGHmvhzQW3ERxGyMrxfq3LuxHSJ6UdBZcuy498sf6", "proofs": [ "2ahFDb4qEAhhuPvysqgk2EHJsCeHw1XHLdJv6MfUp5zgigHKZXuQPKyf2j8J7ZY1XbGEdwzxt86dLiYDpuZf3pHa" ], "script": "base64:BgIfCAISBAoCCAgSAwoBARIFCgMICAgSBAoCCAESAwoBCBwADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQAB2tfYWRtaW4CB2tfYWRtaW4ABmtfc3RlcAIGa19zdGVwAAxrX3F1b3RlQXNzZXQCDGtfcXVvdGVBc3NldAAMa19zcG90TWFya2V0AgxrX3Nwb3RNYXJrZXQAD2tfZnV0dXJlc01hcmtldAIPa19mdXR1cmVzTWFya2V0ABNrX21pbkluY3JlYXNlU3ByZWFkAhNrX21pbkluY3JlYXNlU3ByZWFkAA5rX3Bvc2l0aW9uTG9uZwIOa19wb3NpdGlvbkxvbmcAD2tfcG9zaXRpb25TaG9ydAIPa19wb3NpdGlvblNob3J0ABBrX3Bvc2l0aW9uU3ByZWFkAhBrX3Bvc2l0aW9uU3ByZWFkAA5rX3Bvc2l0aW9uU2l6ZQIOa19wb3NpdGlvblNpemUADERFQ0lNQUxfVU5JVAkAaAIAAQkAaAIJAGgCCQBoAgkAaAIJAGgCAAoACgAKAAoACgAKAQRkaXZkAgJfeAJfeQkAbgQFAl94BQxERUNJTUFMX1VOSVQFAl95BQhIQUxGRVZFTgEEbXVsZAICX3gCX3kJAG4EBQJfeAUCX3kFDERFQ0lNQUxfVU5JVAUISEFMRkVWRU4ACURJUl9TSE9SVAACAQ50b0NvbXBvc2l0ZUtleQIEX2tleQhfYWRkcmVzcwkArAICCQCsAgIFBF9rZXkCAV8FCF9hZGRyZXNzAQxhZG1pbkFkZHJlc3MACQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQdrX2FkbWluAQ1nZXRRdW90ZUFzc2V0AAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQxrX3F1b3RlQXNzZXQBDWdldFNwb3RNYXJrZXQBBl9hc3NldAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUMa19zcG90TWFya2V0BQZfYXNzZXQBEGdldEZ1dHVyZXNNYXJrZXQBBl9hc3NldAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUPa19mdXR1cmVzTWFya2V0BQZfYXNzZXQBEW1pbkluY3JlYXNlU3ByZWFkAAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwUTa19taW5JbmNyZWFzZVNwcmVhZAELZ2V0UG9zaXRpb24BBl9hc3NldAQIbG9uZ1NpemUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUOa19wb3NpdGlvbkxvbmcFBl9hc3NldAAAAwkAAAIFCGxvbmdTaXplAAAJAJUKAwAAAAAAAAkAlQoDBQhsb25nU2l6ZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQ9rX3Bvc2l0aW9uU2hvcnQFBl9hc3NldAAACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAAAAQ9nZXRBc3NldEJhbGFuY2UBBl9hc3NldAMJAAACBQZfYXNzZXQCBVdBVkVTCAkA7wcBBQR0aGlzB3JlZ3VsYXIJAPAHAgUEdGhpcwkA2QQBBQZfYXNzZXQBCmdldEFzc2V0SWQBBl9hc3NldAMJAAACBQZfYXNzZXQCBVdBVkVTBQR1bml0CQDZBAEFBl9hc3NldAEJbm9ybWFsaXplAgdfYW1vdW50Bl9hc3NldAQIZGVjaW1hbHMDCQAAAgUGX2Fzc2V0AgVXQVZFUwAICAkBBXZhbHVlAQkA7AcBCQDZBAEFBl9hc3NldAhkZWNpbWFscwMJAAACBQhkZWNpbWFscwAICQBpAgUHX2Ftb3VudABkAwkAAAIFCGRlY2ltYWxzAAYFB19hbW91bnQJAAIBAhpJbnZhbGlkIGRlY2ltYWxzIGZvciBhc3NldAELZGVOb3JtYWxpemUCB19hbW91bnQGX2Fzc2V0BAhkZWNpbWFscwMJAAACBQZfYXNzZXQCBVdBVkVTAAgICQEFdmFsdWUBCQDsBwEJANkEAQUGX2Fzc2V0CGRlY2ltYWxzAwkAAAIFCGRlY2ltYWxzAAgJAGgCBQdfYW1vdW50AGQDCQAAAgUIZGVjaW1hbHMABgUHX2Ftb3VudAkAAgECGkludmFsaWQgZGVjaW1hbHMgZm9yIGFzc2V0AQ51cGRhdGVQb3NpdGlvbgQGX2Fzc2V0DF9uZXdMb25nU2l6ZQ1fbmV3U2hvcnRTaXplDV9uZXdBdmdTcHJlYWQJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQFDF9uZXdMb25nU2l6ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUPa19wb3NpdGlvblNob3J0BQZfYXNzZXQFDV9uZXdTaG9ydFNpemUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFEGtfcG9zaXRpb25TcHJlYWQFBl9hc3NldAUNX25ld0F2Z1NwcmVhZAUDbmlsAQ5kZWxldGVQb3NpdGlvbgEGX2Fzc2V0CQDMCAIJAQtEZWxldGVFbnRyeQEJAQ50b0NvbXBvc2l0ZUtleQIFDmtfcG9zaXRpb25Mb25nBQZfYXNzZXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDnRvQ29tcG9zaXRlS2V5AgUPa19wb3NpdGlvblNob3J0BQZfYXNzZXQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBDnRvQ29tcG9zaXRlS2V5AgUQa19wb3NpdGlvblNwcmVhZAUGX2Fzc2V0BQNuaWwFAWkBCmluaXRpYWxpemUCBl9hZG1pbgtfcXVvdGVBc3NldAMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECGUludmFsaWQgaW5pdGlhbGl6ZSBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgUHa19hZG1pbgUGX2FkbWluCQDMCAIJAQtTdHJpbmdFbnRyeQIFDGtfcXVvdGVBc3NldAULX3F1b3RlQXNzZXQFA25pbAFpAQ5jaGFuZ2VTZXR0aW5ncwESX21pbkluY3JlYXNlU3ByZWFkAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECHUludmFsaWQgY2hhbmdlU2V0dGluZ3MgcGFyYW1zCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRNrX21pbkluY3JlYXNlU3ByZWFkBRJfbWluSW5jcmVhc2VTcHJlYWQFA25pbAFpAQlhZGRNYXJrZXQDBl9hc3NldAtfc3BvdE1hcmtldA5fZnV0dXJlc01hcmtldAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhhJbnZhbGlkIGFkZE1hcmtldCBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUMa19zcG90TWFya2V0BQZfYXNzZXQFC19zcG90TWFya2V0CQDMCAIJAQtTdHJpbmdFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFD2tfZnV0dXJlc01hcmtldAUGX2Fzc2V0BQ5fZnV0dXJlc01hcmtldAUDbmlsAWkBEGluY3JlYXNlUG9zaXRpb24CBl9hc3NldA9fcXVvdGVBc3NldFN0ZXAECnF1b3RlQXNzZXQJAQ1nZXRRdW90ZUFzc2V0AAQKc3BvdE1hcmtldAkBDWdldFNwb3RNYXJrZXQBBQZfYXNzZXQEC2Fzc2V0QmVmb3JlCQEPZ2V0QXNzZXRCYWxhbmNlAQUGX2Fzc2V0AwkAAAIFC2Fzc2V0QmVmb3JlBQthc3NldEJlZm9yZQQHYnV5U3BvdAkA/AcEBQpzcG90TWFya2V0AgRzd2FwCQDMCAIAAAkAzAgCBQZfYXNzZXQJAMwIAgkApQgBBQR0aGlzBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCnF1b3RlQXNzZXQFD19xdW90ZUFzc2V0U3RlcAUDbmlsAwkAAAIFB2J1eVNwb3QFB2J1eVNwb3QECmFzc2V0QWZ0ZXIJAQ9nZXRBc3NldEJhbGFuY2UBBQZfYXNzZXQDCQAAAgUKYXNzZXRBZnRlcgUKYXNzZXRBZnRlcgQLYXNzZXRCb3VnaHQJAGUCBQphc3NldEFmdGVyBQthc3NldEJlZm9yZQQPYXNzZXRCb3VnaHROb3JtCQEJbm9ybWFsaXplAgULYXNzZXRCb3VnaHQFBl9hc3NldAQQYnV5UHJpY2VOb3JtRmFjdAkBBGRpdmQCBQ9fcXVvdGVBc3NldFN0ZXAFD2Fzc2V0Qm91Z2h0Tm9ybQQNZnV0dXJlc01hcmtldAkBEGdldEZ1dHVyZXNNYXJrZXQBBQZfYXNzZXQEDHNob3J0RnV0dXJlcwkA/AcEBQ1mdXR1cmVzTWFya2V0AhBpbmNyZWFzZVBvc2l0aW9uCQDMCAIFCURJUl9TSE9SVAkAzAgCBQxERUNJTUFMX1VOSVQJAMwIAgAACQDMCAICAAkAzAgCAgAFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUKcXVvdGVBc3NldAUPX3F1b3RlQXNzZXRTdGVwBQNuaWwDCQAAAgUMc2hvcnRGdXR1cmVzBQxzaG9ydEZ1dHVyZXMEC3Bvc2l0aW9uS2V5CQCsAgIJAKwCAgkApQgBBQR0aGlzAgFfCQCkAwEFCURJUl9TSE9SVAQPcG9zaXRpb25GdWxsS2V5CQEOdG9Db21wb3NpdGVLZXkCBQ5rX3Bvc2l0aW9uU2l6ZQULcG9zaXRpb25LZXkEDmFzc2V0U2hvcnROb3JtCQEBLQEJARFAZXh0ck5hdGl2ZSgxMDUwKQIFDWZ1dHVyZXNNYXJrZXQFD3Bvc2l0aW9uRnVsbEtleQQSc2hvcnRQcmljZU5vcm1GYWN0CQEEZGl2ZAIFD19xdW90ZUFzc2V0U3RlcAUOYXNzZXRTaG9ydE5vcm0ECnNwcmVhZEZhY3QJAGUCBQxERUNJTUFMX1VOSVQJAQRkaXZkAgUQYnV5UHJpY2VOb3JtRmFjdAUSc2hvcnRQcmljZU5vcm1GYWN0BAltaW5TcHJlYWQJARFtaW5JbmNyZWFzZVNwcmVhZAADCQBmAgUKc3ByZWFkRmFjdAUJbWluU3ByZWFkBAskdDA1NzQ0NTgwMgkBC2dldFBvc2l0aW9uAQUGX2Fzc2V0BAhsb25nU2l6ZQgFCyR0MDU3NDQ1ODAyAl8xBAlzaG9ydFNpemUIBQskdDA1NzQ0NTgwMgJfMgQJYXZnU3ByZWFkCAULJHQwNTc0NDU4MDICXzMEC25ld0xvbmdTaXplCQBkAgUIbG9uZ1NpemUFD2Fzc2V0Qm91Z2h0Tm9ybQQMbmV3U2hvcnRTaXplCQBkAgUJc2hvcnRTaXplBQ5hc3NldFNob3J0Tm9ybQQMbmV3QXZnU3ByZWFkCQEEZGl2ZAIJAGQCCQEEbXVsZAIFCWF2Z1NwcmVhZAkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUJAQRtdWxkAgUKc3ByZWFkRmFjdAkAZAIFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0JAGQCCQBkAgkAZAIFCGxvbmdTaXplBQlzaG9ydFNpemUFD2Fzc2V0Qm91Z2h0Tm9ybQUOYXNzZXRTaG9ydE5vcm0JAQ51cGRhdGVQb3NpdGlvbgQFBl9hc3NldAULbmV3TG9uZ1NpemUFDG5ld1Nob3J0U2l6ZQUMbmV3QXZnU3ByZWFkBARkYXRhCQDMCAIJAKQDAQUPYXNzZXRCb3VnaHROb3JtCQDMCAIJAKQDAQUQYnV5UHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDmFzc2V0U2hvcnROb3JtCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCW1pblNwcmVhZAUDbmlsCQACAQkArAICAhBJbnZhbGlkIHNwcmVhZDogCQC5CQIFBGRhdGECASwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENY2xvc2VQb3NpdGlvbgEGX2Fzc2V0BApxdW90ZUFzc2V0CQENZ2V0UXVvdGVBc3NldAAEDXF1b3RlQXNzZXRTdHIJANgEAQUKcXVvdGVBc3NldAQKc3BvdE1hcmtldAkBDWdldFNwb3RNYXJrZXQBBQZfYXNzZXQECyR0MDY2OTg2NzU2CQELZ2V0UG9zaXRpb24BBQZfYXNzZXQECGxvbmdTaXplCAULJHQwNjY5ODY3NTYCXzEECXNob3J0U2l6ZQgFCyR0MDY2OTg2NzU2Al8yBAlhdmdTcHJlYWQIBQskdDA2Njk4Njc1NgJfMwQQcXVvdGVBc3NldEJlZm9yZQkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgUQcXVvdGVBc3NldEJlZm9yZQUQcXVvdGVBc3NldEJlZm9yZQQIc2VsbFNwb3QJAPwHBAUKc3BvdE1hcmtldAIEc3dhcAkAzAgCAAAJAMwIAgUNcXVvdGVBc3NldFN0cgkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBCmdldEFzc2V0SWQBBQZfYXNzZXQJAQtkZU5vcm1hbGl6ZQIFCGxvbmdTaXplBQZfYXNzZXQFA25pbAMJAAACBQhzZWxsU3BvdAUIc2VsbFNwb3QED3F1b3RlQXNzZXRBZnRlcgkBD2dldEFzc2V0QmFsYW5jZQEFDXF1b3RlQXNzZXRTdHIDCQAAAgUPcXVvdGVBc3NldEFmdGVyBQ9xdW90ZUFzc2V0QWZ0ZXIEDGFzc2V0U29sZEZvcgkAZQIFD3F1b3RlQXNzZXRBZnRlcgUQcXVvdGVBc3NldEJlZm9yZQQQYXNzZXRTb2xkRm9yTm9ybQkBCW5vcm1hbGl6ZQIFDGFzc2V0U29sZEZvcgUGX2Fzc2V0BBFzZWxsUHJpY2VOb3JtRmFjdAkBBGRpdmQCBRBhc3NldFNvbGRGb3JOb3JtBQhsb25nU2l6ZQQNZnV0dXJlc01hcmtldAkBEGdldEZ1dHVyZXNNYXJrZXQBBQZfYXNzZXQEEXF1b3RlQXNzZXRCZWZvcmUyCQEPZ2V0QXNzZXRCYWxhbmNlAQUNcXVvdGVBc3NldFN0cgMJAAACBRFxdW90ZUFzc2V0QmVmb3JlMgURcXVvdGVBc3NldEJlZm9yZTIEEWNsb3NlU2hvcnRGdXR1cmVzCQD8BwQFDWZ1dHVyZXNNYXJrZXQCDWNsb3NlUG9zaXRpb24JAMwIAgUJc2hvcnRTaXplCQDMCAIFCURJUl9TSE9SVAkAzAgCAAAJAMwIAgcJAMwIAgIABQNuaWwFA25pbAMJAAACBRFjbG9zZVNob3J0RnV0dXJlcwURY2xvc2VTaG9ydEZ1dHVyZXMEEHF1b3RlQXNzZXRBZnRlcjIJAQ9nZXRBc3NldEJhbGFuY2UBBQ1xdW90ZUFzc2V0U3RyAwkAAAIFEHF1b3RlQXNzZXRBZnRlcjIFEHF1b3RlQXNzZXRBZnRlcjIEDnNob3J0Q2xvc2VkRm9yCQBlAgUQcXVvdGVBc3NldEFmdGVyMgURcXVvdGVBc3NldEJlZm9yZTIEEnNob3J0UHJpY2VOb3JtRmFjdAkBBGRpdmQCBQ5zaG9ydENsb3NlZEZvcgUJc2hvcnRTaXplBApzcHJlYWRGYWN0CQBlAgUMREVDSU1BTF9VTklUCQEEZGl2ZAIFEGFzc2V0U29sZEZvck5vcm0FEnNob3J0UHJpY2VOb3JtRmFjdAMJAGYCBQlhdmdTcHJlYWQFCnNwcmVhZEZhY3QJAQ5kZWxldGVQb3NpdGlvbgEFBl9hc3NldAQEZGF0YQkAzAgCCQCkAwEFEGFzc2V0U29sZEZvck5vcm0JAMwIAgkApAMBBRFzZWxsUHJpY2VOb3JtRmFjdAkAzAgCCQCkAwEFDnNob3J0Q2xvc2VkRm9yCQDMCAIJAKQDAQUSc2hvcnRQcmljZU5vcm1GYWN0CQDMCAIJAKQDAQUKc3ByZWFkRmFjdAkAzAgCCQCkAwEFCWF2Z1NwcmVhZAUDbmlsCQACAQkArAICAhpJbnZhbGlkIHNwcmVhZCBmb3IgY2xvc2U6IAkAuQkCBQRkYXRhAgEsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAOtoNvU=", "height": 3663185, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GgAtmJYCUJs8QnKqQBkWW5aRZBoK6aSk7qU541N6gHg3 Next: 67cDAe3hxhtdinuaL7gwvLMtN5jfpq1yqzRegMF4Qphh Diff:
OldNewDifferences
6464 else assetBalance(this, fromBase58String(_asset))
6565
6666
67+func getAssetId (_asset) = if ((_asset == "WAVES"))
68+ then unit
69+ else fromBase58String(_asset)
70+
71+
6772 func normalize (_amount,_asset) = {
6873 let decimals = if ((_asset == "WAVES"))
6974 then 8
7681 }
7782
7883
84+func deNormalize (_amount,_asset) = {
85+ let decimals = if ((_asset == "WAVES"))
86+ then 8
87+ else value(assetInfo(fromBase58String(_asset))).decimals
88+ if ((decimals == 8))
89+ then (_amount * 100)
90+ else if ((decimals == 6))
91+ then _amount
92+ else throw("Invalid decimals for asset")
93+ }
94+
95+
7996 func updatePosition (_asset,_newLongSize,_newShortSize,_newAvgSpread) = [IntegerEntry(toCompositeKey(k_positionLong, _asset), _newLongSize), IntegerEntry(toCompositeKey(k_positionShort, _asset), _newShortSize), IntegerEntry(toCompositeKey(k_positionSpread, _asset), _newAvgSpread)]
97+
98+
99+func deletePosition (_asset) = [DeleteEntry(toCompositeKey(k_positionLong, _asset)), DeleteEntry(toCompositeKey(k_positionShort, _asset)), DeleteEntry(toCompositeKey(k_positionSpread, _asset))]
80100
81101
82102 @Callable(i)
128148 let minSpread = minIncreaseSpread()
129149 if ((spreadFact > minSpread))
130150 then {
131- let $t050145072 = getPosition(_asset)
132- let longSize = $t050145072._1
133- let shortSize = $t050145072._2
134- let avgSpread = $t050145072._3
151+ let $t057445802 = getPosition(_asset)
152+ let longSize = $t057445802._1
153+ let shortSize = $t057445802._2
154+ let avgSpread = $t057445802._3
135155 let newLongSize = (longSize + assetBoughtNorm)
136156 let newShortSize = (shortSize + assetShortNorm)
137157 let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm))
152172 }
153173
154174
175+
176+@Callable(i)
177+func closePosition (_asset) = {
178+ let quoteAsset = getQuoteAsset()
179+ let quoteAssetStr = toBase58String(quoteAsset)
180+ let spotMarket = getSpotMarket(_asset)
181+ let $t066986756 = getPosition(_asset)
182+ let longSize = $t066986756._1
183+ let shortSize = $t066986756._2
184+ let avgSpread = $t066986756._3
185+ let quoteAssetBefore = getAssetBalance(quoteAssetStr)
186+ if ((quoteAssetBefore == quoteAssetBefore))
187+ then {
188+ let sellSpot = invoke(spotMarket, "swap", [0, quoteAssetStr, toString(this)], [AttachedPayment(getAssetId(_asset), deNormalize(longSize, _asset))])
189+ if ((sellSpot == sellSpot))
190+ then {
191+ let quoteAssetAfter = getAssetBalance(quoteAssetStr)
192+ if ((quoteAssetAfter == quoteAssetAfter))
193+ then {
194+ let assetSoldFor = (quoteAssetAfter - quoteAssetBefore)
195+ let assetSoldForNorm = normalize(assetSoldFor, _asset)
196+ let sellPriceNormFact = divd(assetSoldForNorm, longSize)
197+ let futuresMarket = getFuturesMarket(_asset)
198+ let quoteAssetBefore2 = getAssetBalance(quoteAssetStr)
199+ if ((quoteAssetBefore2 == quoteAssetBefore2))
200+ then {
201+ let closeShortFutures = invoke(futuresMarket, "closePosition", [shortSize, DIR_SHORT, 0, false, ""], nil)
202+ if ((closeShortFutures == closeShortFutures))
203+ then {
204+ let quoteAssetAfter2 = getAssetBalance(quoteAssetStr)
205+ if ((quoteAssetAfter2 == quoteAssetAfter2))
206+ then {
207+ let shortClosedFor = (quoteAssetAfter2 - quoteAssetBefore2)
208+ let shortPriceNormFact = divd(shortClosedFor, shortSize)
209+ let spreadFact = (DECIMAL_UNIT - divd(assetSoldForNorm, shortPriceNormFact))
210+ if ((avgSpread > spreadFact))
211+ then deletePosition(_asset)
212+ else {
213+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
214+ throw(("Invalid spread for close: " + makeString(data, ",")))
215+ }
216+ }
217+ else throw("Strict value is not equal to itself.")
218+ }
219+ else throw("Strict value is not equal to itself.")
220+ }
221+ else throw("Strict value is not equal to itself.")
222+ }
223+ else throw("Strict value is not equal to itself.")
224+ }
225+ else throw("Strict value is not equal to itself.")
226+ }
227+ else throw("Strict value is not equal to itself.")
228+ }
229+
230+
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
67+func getAssetId (_asset) = if ((_asset == "WAVES"))
68+ then unit
69+ else fromBase58String(_asset)
70+
71+
6772 func normalize (_amount,_asset) = {
6873 let decimals = if ((_asset == "WAVES"))
6974 then 8
7075 else value(assetInfo(fromBase58String(_asset))).decimals
7176 if ((decimals == 8))
7277 then (_amount / 100)
7378 else if ((decimals == 6))
7479 then _amount
7580 else throw("Invalid decimals for asset")
7681 }
7782
7883
84+func deNormalize (_amount,_asset) = {
85+ let decimals = if ((_asset == "WAVES"))
86+ then 8
87+ else value(assetInfo(fromBase58String(_asset))).decimals
88+ if ((decimals == 8))
89+ then (_amount * 100)
90+ else if ((decimals == 6))
91+ then _amount
92+ else throw("Invalid decimals for asset")
93+ }
94+
95+
7996 func updatePosition (_asset,_newLongSize,_newShortSize,_newAvgSpread) = [IntegerEntry(toCompositeKey(k_positionLong, _asset), _newLongSize), IntegerEntry(toCompositeKey(k_positionShort, _asset), _newShortSize), IntegerEntry(toCompositeKey(k_positionSpread, _asset), _newAvgSpread)]
97+
98+
99+func deletePosition (_asset) = [DeleteEntry(toCompositeKey(k_positionLong, _asset)), DeleteEntry(toCompositeKey(k_positionShort, _asset)), DeleteEntry(toCompositeKey(k_positionSpread, _asset))]
80100
81101
82102 @Callable(i)
83103 func initialize (_admin,_quoteAsset) = if ((i.caller != this))
84104 then throw("Invalid initialize params")
85105 else [StringEntry(k_admin, _admin), StringEntry(k_quoteAsset, _quoteAsset)]
86106
87107
88108
89109 @Callable(i)
90110 func changeSettings (_minIncreaseSpread) = if ((i.caller != adminAddress()))
91111 then throw("Invalid changeSettings params")
92112 else [IntegerEntry(k_minIncreaseSpread, _minIncreaseSpread)]
93113
94114
95115
96116 @Callable(i)
97117 func addMarket (_asset,_spotMarket,_futuresMarket) = if ((i.caller != adminAddress()))
98118 then throw("Invalid addMarket params")
99119 else [StringEntry(toCompositeKey(k_spotMarket, _asset), _spotMarket), StringEntry(toCompositeKey(k_futuresMarket, _asset), _futuresMarket)]
100120
101121
102122
103123 @Callable(i)
104124 func increasePosition (_asset,_quoteAssetStep) = {
105125 let quoteAsset = getQuoteAsset()
106126 let spotMarket = getSpotMarket(_asset)
107127 let assetBefore = getAssetBalance(_asset)
108128 if ((assetBefore == assetBefore))
109129 then {
110130 let buySpot = invoke(spotMarket, "swap", [0, _asset, toString(this)], [AttachedPayment(quoteAsset, _quoteAssetStep)])
111131 if ((buySpot == buySpot))
112132 then {
113133 let assetAfter = getAssetBalance(_asset)
114134 if ((assetAfter == assetAfter))
115135 then {
116136 let assetBought = (assetAfter - assetBefore)
117137 let assetBoughtNorm = normalize(assetBought, _asset)
118138 let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm)
119139 let futuresMarket = getFuturesMarket(_asset)
120140 let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)])
121141 if ((shortFutures == shortFutures))
122142 then {
123143 let positionKey = ((toString(this) + "_") + toString(DIR_SHORT))
124144 let positionFullKey = toCompositeKey(k_positionSize, positionKey)
125145 let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey))
126146 let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm)
127147 let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact))
128148 let minSpread = minIncreaseSpread()
129149 if ((spreadFact > minSpread))
130150 then {
131- let $t050145072 = getPosition(_asset)
132- let longSize = $t050145072._1
133- let shortSize = $t050145072._2
134- let avgSpread = $t050145072._3
151+ let $t057445802 = getPosition(_asset)
152+ let longSize = $t057445802._1
153+ let shortSize = $t057445802._2
154+ let avgSpread = $t057445802._3
135155 let newLongSize = (longSize + assetBoughtNorm)
136156 let newShortSize = (shortSize + assetShortNorm)
137157 let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm))
138158 updatePosition(_asset, newLongSize, newShortSize, newAvgSpread)
139159 }
140160 else {
141161 let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)]
142162 throw(("Invalid spread: " + makeString(data, ",")))
143163 }
144164 }
145165 else throw("Strict value is not equal to itself.")
146166 }
147167 else throw("Strict value is not equal to itself.")
148168 }
149169 else throw("Strict value is not equal to itself.")
150170 }
151171 else throw("Strict value is not equal to itself.")
152172 }
153173
154174
175+
176+@Callable(i)
177+func closePosition (_asset) = {
178+ let quoteAsset = getQuoteAsset()
179+ let quoteAssetStr = toBase58String(quoteAsset)
180+ let spotMarket = getSpotMarket(_asset)
181+ let $t066986756 = getPosition(_asset)
182+ let longSize = $t066986756._1
183+ let shortSize = $t066986756._2
184+ let avgSpread = $t066986756._3
185+ let quoteAssetBefore = getAssetBalance(quoteAssetStr)
186+ if ((quoteAssetBefore == quoteAssetBefore))
187+ then {
188+ let sellSpot = invoke(spotMarket, "swap", [0, quoteAssetStr, toString(this)], [AttachedPayment(getAssetId(_asset), deNormalize(longSize, _asset))])
189+ if ((sellSpot == sellSpot))
190+ then {
191+ let quoteAssetAfter = getAssetBalance(quoteAssetStr)
192+ if ((quoteAssetAfter == quoteAssetAfter))
193+ then {
194+ let assetSoldFor = (quoteAssetAfter - quoteAssetBefore)
195+ let assetSoldForNorm = normalize(assetSoldFor, _asset)
196+ let sellPriceNormFact = divd(assetSoldForNorm, longSize)
197+ let futuresMarket = getFuturesMarket(_asset)
198+ let quoteAssetBefore2 = getAssetBalance(quoteAssetStr)
199+ if ((quoteAssetBefore2 == quoteAssetBefore2))
200+ then {
201+ let closeShortFutures = invoke(futuresMarket, "closePosition", [shortSize, DIR_SHORT, 0, false, ""], nil)
202+ if ((closeShortFutures == closeShortFutures))
203+ then {
204+ let quoteAssetAfter2 = getAssetBalance(quoteAssetStr)
205+ if ((quoteAssetAfter2 == quoteAssetAfter2))
206+ then {
207+ let shortClosedFor = (quoteAssetAfter2 - quoteAssetBefore2)
208+ let shortPriceNormFact = divd(shortClosedFor, shortSize)
209+ let spreadFact = (DECIMAL_UNIT - divd(assetSoldForNorm, shortPriceNormFact))
210+ if ((avgSpread > spreadFact))
211+ then deletePosition(_asset)
212+ else {
213+ let data = [toString(assetSoldForNorm), toString(sellPriceNormFact), toString(shortClosedFor), toString(shortPriceNormFact), toString(spreadFact), toString(avgSpread)]
214+ throw(("Invalid spread for close: " + makeString(data, ",")))
215+ }
216+ }
217+ else throw("Strict value is not equal to itself.")
218+ }
219+ else throw("Strict value is not equal to itself.")
220+ }
221+ else throw("Strict value is not equal to itself.")
222+ }
223+ else throw("Strict value is not equal to itself.")
224+ }
225+ else throw("Strict value is not equal to itself.")
226+ }
227+ else throw("Strict value is not equal to itself.")
228+ }
229+
230+

github/deemru/w8io/3ef1775 
44.63 ms