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:
Old | New | Differences | |
---|---|---|---|
64 | 64 | else assetBalance(this, fromBase58String(_asset)) | |
65 | 65 | ||
66 | 66 | ||
67 | + | func getAssetId (_asset) = if ((_asset == "WAVES")) | |
68 | + | then unit | |
69 | + | else fromBase58String(_asset) | |
70 | + | ||
71 | + | ||
67 | 72 | func normalize (_amount,_asset) = { | |
68 | 73 | let decimals = if ((_asset == "WAVES")) | |
69 | 74 | then 8 | |
76 | 81 | } | |
77 | 82 | ||
78 | 83 | ||
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 | + | ||
79 | 96 | 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))] | |
80 | 100 | ||
81 | 101 | ||
82 | 102 | @Callable(i) | |
128 | 148 | let minSpread = minIncreaseSpread() | |
129 | 149 | if ((spreadFact > minSpread)) | |
130 | 150 | then { | |
131 | - | let $ | |
132 | - | let longSize = $ | |
133 | - | let shortSize = $ | |
134 | - | let avgSpread = $ | |
151 | + | let $t057445802 = getPosition(_asset) | |
152 | + | let longSize = $t057445802._1 | |
153 | + | let shortSize = $t057445802._2 | |
154 | + | let avgSpread = $t057445802._3 | |
135 | 155 | let newLongSize = (longSize + assetBoughtNorm) | |
136 | 156 | let newShortSize = (shortSize + assetShortNorm) | |
137 | 157 | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
152 | 172 | } | |
153 | 173 | ||
154 | 174 | ||
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 | + |
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_positionSize = "k_positionSize" | |
25 | 25 | ||
26 | 26 | let DECIMAL_UNIT = (1 * (((((10 * 10) * 10) * 10) * 10) * 10)) | |
27 | 27 | ||
28 | 28 | func divd (_x,_y) = fraction(_x, DECIMAL_UNIT, _y, HALFEVEN) | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | func muld (_x,_y) = fraction(_x, _y, DECIMAL_UNIT, HALFEVEN) | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | let DIR_SHORT = 2 | |
35 | 35 | ||
36 | 36 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
37 | 37 | ||
38 | 38 | ||
39 | 39 | func adminAddress () = addressFromStringValue(getStringValue(this, k_admin)) | |
40 | 40 | ||
41 | 41 | ||
42 | 42 | func getQuoteAsset () = fromBase58String(getStringValue(this, k_quoteAsset)) | |
43 | 43 | ||
44 | 44 | ||
45 | 45 | func getSpotMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_spotMarket, _asset))) | |
46 | 46 | ||
47 | 47 | ||
48 | 48 | func getFuturesMarket (_asset) = addressFromStringValue(getStringValue(this, toCompositeKey(k_futuresMarket, _asset))) | |
49 | 49 | ||
50 | 50 | ||
51 | 51 | func minIncreaseSpread () = getIntegerValue(this, k_minIncreaseSpread) | |
52 | 52 | ||
53 | 53 | ||
54 | 54 | func getPosition (_asset) = { | |
55 | 55 | let longSize = valueOrElse(getInteger(this, toCompositeKey(k_positionLong, _asset)), 0) | |
56 | 56 | if ((longSize == 0)) | |
57 | 57 | then $Tuple3(0, 0, 0) | |
58 | 58 | else $Tuple3(longSize, valueOrElse(getInteger(this, toCompositeKey(k_positionShort, _asset)), 0), valueOrElse(getInteger(this, toCompositeKey(k_positionSpread, _asset)), 0)) | |
59 | 59 | } | |
60 | 60 | ||
61 | 61 | ||
62 | 62 | func getAssetBalance (_asset) = if ((_asset == "WAVES")) | |
63 | 63 | then wavesBalance(this).regular | |
64 | 64 | else assetBalance(this, fromBase58String(_asset)) | |
65 | 65 | ||
66 | 66 | ||
67 | + | func getAssetId (_asset) = if ((_asset == "WAVES")) | |
68 | + | then unit | |
69 | + | else fromBase58String(_asset) | |
70 | + | ||
71 | + | ||
67 | 72 | func normalize (_amount,_asset) = { | |
68 | 73 | let decimals = if ((_asset == "WAVES")) | |
69 | 74 | then 8 | |
70 | 75 | else value(assetInfo(fromBase58String(_asset))).decimals | |
71 | 76 | if ((decimals == 8)) | |
72 | 77 | then (_amount / 100) | |
73 | 78 | else if ((decimals == 6)) | |
74 | 79 | then _amount | |
75 | 80 | else throw("Invalid decimals for asset") | |
76 | 81 | } | |
77 | 82 | ||
78 | 83 | ||
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 | + | ||
79 | 96 | 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))] | |
80 | 100 | ||
81 | 101 | ||
82 | 102 | @Callable(i) | |
83 | 103 | func initialize (_admin,_quoteAsset) = if ((i.caller != this)) | |
84 | 104 | then throw("Invalid initialize params") | |
85 | 105 | else [StringEntry(k_admin, _admin), StringEntry(k_quoteAsset, _quoteAsset)] | |
86 | 106 | ||
87 | 107 | ||
88 | 108 | ||
89 | 109 | @Callable(i) | |
90 | 110 | func changeSettings (_minIncreaseSpread) = if ((i.caller != adminAddress())) | |
91 | 111 | then throw("Invalid changeSettings params") | |
92 | 112 | else [IntegerEntry(k_minIncreaseSpread, _minIncreaseSpread)] | |
93 | 113 | ||
94 | 114 | ||
95 | 115 | ||
96 | 116 | @Callable(i) | |
97 | 117 | func addMarket (_asset,_spotMarket,_futuresMarket) = if ((i.caller != adminAddress())) | |
98 | 118 | then throw("Invalid addMarket params") | |
99 | 119 | else [StringEntry(toCompositeKey(k_spotMarket, _asset), _spotMarket), StringEntry(toCompositeKey(k_futuresMarket, _asset), _futuresMarket)] | |
100 | 120 | ||
101 | 121 | ||
102 | 122 | ||
103 | 123 | @Callable(i) | |
104 | 124 | func increasePosition (_asset,_quoteAssetStep) = { | |
105 | 125 | let quoteAsset = getQuoteAsset() | |
106 | 126 | let spotMarket = getSpotMarket(_asset) | |
107 | 127 | let assetBefore = getAssetBalance(_asset) | |
108 | 128 | if ((assetBefore == assetBefore)) | |
109 | 129 | then { | |
110 | 130 | let buySpot = invoke(spotMarket, "swap", [0, _asset, toString(this)], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
111 | 131 | if ((buySpot == buySpot)) | |
112 | 132 | then { | |
113 | 133 | let assetAfter = getAssetBalance(_asset) | |
114 | 134 | if ((assetAfter == assetAfter)) | |
115 | 135 | then { | |
116 | 136 | let assetBought = (assetAfter - assetBefore) | |
117 | 137 | let assetBoughtNorm = normalize(assetBought, _asset) | |
118 | 138 | let buyPriceNormFact = divd(_quoteAssetStep, assetBoughtNorm) | |
119 | 139 | let futuresMarket = getFuturesMarket(_asset) | |
120 | 140 | let shortFutures = invoke(futuresMarket, "increasePosition", [DIR_SHORT, DECIMAL_UNIT, 0, "", ""], [AttachedPayment(quoteAsset, _quoteAssetStep)]) | |
121 | 141 | if ((shortFutures == shortFutures)) | |
122 | 142 | then { | |
123 | 143 | let positionKey = ((toString(this) + "_") + toString(DIR_SHORT)) | |
124 | 144 | let positionFullKey = toCompositeKey(k_positionSize, positionKey) | |
125 | 145 | let assetShortNorm = -(getIntegerValue(futuresMarket, positionFullKey)) | |
126 | 146 | let shortPriceNormFact = divd(_quoteAssetStep, assetShortNorm) | |
127 | 147 | let spreadFact = (DECIMAL_UNIT - divd(buyPriceNormFact, shortPriceNormFact)) | |
128 | 148 | let minSpread = minIncreaseSpread() | |
129 | 149 | if ((spreadFact > minSpread)) | |
130 | 150 | then { | |
131 | - | let $ | |
132 | - | let longSize = $ | |
133 | - | let shortSize = $ | |
134 | - | let avgSpread = $ | |
151 | + | let $t057445802 = getPosition(_asset) | |
152 | + | let longSize = $t057445802._1 | |
153 | + | let shortSize = $t057445802._2 | |
154 | + | let avgSpread = $t057445802._3 | |
135 | 155 | let newLongSize = (longSize + assetBoughtNorm) | |
136 | 156 | let newShortSize = (shortSize + assetShortNorm) | |
137 | 157 | let newAvgSpread = divd((muld(avgSpread, (longSize + shortSize)) + muld(spreadFact, (assetBoughtNorm + assetShortNorm))), (((longSize + shortSize) + assetBoughtNorm) + assetShortNorm)) | |
138 | 158 | updatePosition(_asset, newLongSize, newShortSize, newAvgSpread) | |
139 | 159 | } | |
140 | 160 | else { | |
141 | 161 | let data = [toString(assetBoughtNorm), toString(buyPriceNormFact), toString(assetShortNorm), toString(shortPriceNormFact), toString(spreadFact), toString(minSpread)] | |
142 | 162 | throw(("Invalid spread: " + makeString(data, ","))) | |
143 | 163 | } | |
144 | 164 | } | |
145 | 165 | else throw("Strict value is not equal to itself.") | |
146 | 166 | } | |
147 | 167 | else throw("Strict value is not equal to itself.") | |
148 | 168 | } | |
149 | 169 | else throw("Strict value is not equal to itself.") | |
150 | 170 | } | |
151 | 171 | else throw("Strict value is not equal to itself.") | |
152 | 172 | } | |
153 | 173 | ||
154 | 174 | ||
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 ◑