tx · HJNSTA4LU1KkwcJ1w4NDXyHRXeF3apNJWUKFMUAyw25e 3MrASWFH3k8Tkfq2eoMDH6vZWy2dywFQNen: -0.03400000 Waves 2022.11.10 12:43 [2310887] smart account 3MrASWFH3k8Tkfq2eoMDH6vZWy2dywFQNen > SELF 0.00000000 Waves
{ "type": 13, "id": "HJNSTA4LU1KkwcJ1w4NDXyHRXeF3apNJWUKFMUAyw25e", "fee": 3400000, "feeAssetId": null, "timestamp": 1668073464775, "version": 2, "chainId": 84, "sender": "3MrASWFH3k8Tkfq2eoMDH6vZWy2dywFQNen", "senderPublicKey": "9JqU7LHuYERXD76iWBYPkx8qsJ5kNWc8UjTncwigr2BS", "proofs": [ "2xChMAmpyJxjRXvJ4Fbfgixr31pisH7X4inDhdMCiba9fZkkt3xsuDvrEuRyn1Qhqwv5sotV8GXUNib4jJQnvsbD" ], "script": "base64:BgIgCAISBAoCCAgSAwoBCBIECgIICBIECgIICBIFCgMICAEfABJrX2Fzc2V0X2NvbGxhdGVyYWwCEmtfYXNzZXRfY29sbGF0ZXJhbAAga190cmFkZXJfbWFya2V0X2Fzc2V0X2NvbGxhdGVyYWwCIGtfdHJhZGVyX21hcmtldF9hc3NldF9jb2xsYXRlcmFsABFrX3doaXRlbGlzdF9hc3NldAIRa193aGl0ZWxpc3RfYXNzZXQADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQAFGtfY29vcmRpbmF0b3JBZGRyZXNzAhRrX2Nvb3JkaW5hdG9yQWRkcmVzcwASa19nb3Zlcm5hbmNlX2Fzc2V0AgtrX2dvdl9hc3NldAANa19xdW90ZV9hc3NldAINa19xdW90ZV9hc3NldAASa19hZG1pbl9wdWJsaWNfa2V5AhJrX2FkbWluX3B1YmxpY19rZXkAEWtfbWFuYWdlcl9hZGRyZXNzAhFrX21hbmFnZXJfYWRkcmVzcwAFa19hbW0CBWtfYW1tABNrX2luc3VyYW5jZV9hZGRyZXNzAhNrX2luc3VyYW5jZV9hZGRyZXNzABJrX2V4Y2hhbmdlX2FkZHJlc3MCEmtfZXhjaGFuZ2VfYWRkcmVzcwEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwELY29vcmRpbmF0b3IACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCE0Nvb3JkaW5hdG9yIG5vdCBzZXQBDmFkbWluUHVibGljS2V5AAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABRJrX2FkbWluX3B1YmxpY19rZXkBD2dvdmVybmFuY2VBc3NldAAJANkEAQkBEUBleHRyTmF0aXZlKDEwNTMpAgkBC2Nvb3JkaW5hdG9yAAUSa19nb3Zlcm5hbmNlX2Fzc2V0AQpxdW90ZUFzc2V0AAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABQ1rX3F1b3RlX2Fzc2V0AQ5tYW5hZ2VyQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABRFrX21hbmFnZXJfYWRkcmVzcwIPTWFuYWdlciBub3Qgc2V0AQtpc1doaXRlbGlzdAEIX2FkZHJlc3MJAQt2YWx1ZU9yRWxzZQIJAJsIAgkBC2Nvb3JkaW5hdG9yAAkBDnRvQ29tcG9zaXRlS2V5AgUFa19hbW0FCF9hZGRyZXNzBwEQaXNXaGl0ZWxpc3RBc3NldAEIX2Fzc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgURa193aGl0ZWxpc3RfYXNzZXQFCF9hc3NldElkBwEQaW5zdXJhbmNlQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABRNrX2luc3VyYW5jZV9hZGRyZXNzAhFJbnN1cmFuY2Ugbm90IHNldAELc3dhcEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEmtfZXhjaGFuZ2VfYWRkcmVzcwIPTm8gc3dhcCBhZGRyZXNzAhRJbnZhbGlkIHN3YXAgYWRkcmVzcwAMREVDSU1BTF9VTklUCQBoAgABCQBoAgkAaAIJAGgCCQBoAgkAaAIJAGgCCQBoAgAKAAoACgAKAAoACgAKAAoACERVUkFUSU9OCQBoAgkAaAIAPAA8ABgACk5PX0FERFJFU1MCAAAJTk9fU1RBS0VSAAABEHVzZG5Gcm9tRGVjaW1hbHMBB19hbW91bnQJAGkCBQdfYW1vdW50AGQBDnVzZG5Ub0RlY2ltYWxzAQdfYW1vdW50CQBoAgUHX2Ftb3VudABkAQtpbml0aWFsaXplZAAJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwUNa19pbml0aWFsaXplZAcBHmdldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldEtleQMEX2FtbQhfYXNzZXRJZAdfdHJhZGVyCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBSBrX3RyYWRlcl9tYXJrZXRfYXNzZXRfY29sbGF0ZXJhbAIBXwUEX2FtbQIBXwUIX2Fzc2V0SWQCAV8FB190cmFkZXIBG2dldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldAMEX2FtbQhfYXNzZXRJZAdfdHJhZGVyBANrZXkJAR5nZXRCb3Jyb3dlZEJ5VHJhZGVySW5NYXJrZXRLZXkDBQRfYW1tBQhfYXNzZXRJZAUHX3RyYWRlcgkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBQNrZXkAAAUBaQEKaW5pdGlhbGl6ZQIMX2Nvb3JkaW5hdG9yCl93aGl0ZWxpc3QDCQELaW5pdGlhbGl6ZWQACQACAQITQWxyZWFkeSBpbml0aWFsaXplZAQPaW5pdGlhbEFzc2V0SWRzCQC1CQIFCl93aGl0ZWxpc3QCASwKAQtkb1doaXRlbGlzdAIEX2FjYwhfYXNzZXRJZAkAzQgCBQRfYWNjCQEMQm9vbGVhbkVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgURa193aGl0ZWxpc3RfYXNzZXQFCF9hc3NldElkBgkAzggCCgACJGwFD2luaXRpYWxBc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQELZG9XaGl0ZWxpc3QCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwUMX2Nvb3JkaW5hdG9yCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBBmJvcnJvdwEHX3RyYWRlcgQGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQHYXNzZXRJZAkA2AQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAIQSW52YWxpZCBhc3NldCBpZAQDYW1tCQClCAEIBQFpBmNhbGxlcgMDCQEBIQEJAQtpc1doaXRlbGlzdAEFA2FtbQYJAQEhAQkBEGlzV2hpdGVsaXN0QXNzZXQBBQdhc3NldElkCQACAQIZSW52YWxpZCBib3Jyb3cgcGFyYW1ldGVycwQRd2l0aGRyYXdJbnN1cmFuY2UJAPwHBAkBEGluc3VyYW5jZUFkZHJlc3MAAgh3aXRoZHJhdwkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFEXdpdGhkcmF3SW5zdXJhbmNlBRF3aXRoZHJhd0luc3VyYW5jZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFBmFtb3VudAkBCnF1b3RlQXNzZXQACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEeZ2V0Qm9ycm93ZWRCeVRyYWRlckluTWFya2V0S2V5AwUDYW1tBQdhc3NldElkBQdfdHJhZGVyCQBkAgkBG2dldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldAMFA2FtbQUHYXNzZXRJZAUHX3RyYWRlcgUGYW1vdW50BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEFcmVwYXkCB190cmFkZXIIX2Fzc2V0SWQEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQEA2FtbQkApQgBCAUBaQZjYWxsZXIDAwkBASEBCQELaXNXaGl0ZWxpc3QBBQNhbW0GCQEBIQEJARBpc1doaXRlbGlzdEFzc2V0AQUIX2Fzc2V0SWQJAAIBAhhJbnZhbGlkIHJlcGF5IHBhcmFtZXRlcnMEEXdpdGhkcmF3SW5zdXJhbmNlCQD8BwQJARBpbnN1cmFuY2VBZGRyZXNzAAIHZGVwb3NpdAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEKcXVvdGVBc3NldAAFBmFtb3VudAUDbmlsAwkAAAIFEXdpdGhkcmF3SW5zdXJhbmNlBRF3aXRoZHJhd0luc3VyYW5jZQQHbmV3RGVidAkAZQIJARtnZXRCb3Jyb3dlZEJ5VHJhZGVySW5NYXJrZXQDBQNhbW0FCF9hc3NldElkBQdfdHJhZGVyBQZhbW91bnQJAM4IAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFBmFtb3VudAkA2QQBBQhfYXNzZXRJZAUDbmlsAwkAZgIFB25ld0RlYnQAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBHmdldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldEtleQMFA2FtbQUIX2Fzc2V0SWQFB190cmFkZXIFB25ld0RlYnQFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBCQEeZ2V0Qm9ycm93ZWRCeVRyYWRlckluTWFya2V0S2V5AwUDYW1tBQhfYXNzZXRJZAUHX3RyYWRlcgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBGHJlYWxpemVQYXJ0aWFsbHlBbmRDbG9zZQIHX3RyYWRlcghfYXNzZXRJZAQGYW1vdW50AwkAZgIJAJADAQgFAWkIcGF5bWVudHMAAAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQAAAQDYW1tCQClCAEIBQFpBmNhbGxlcgQEZGVidAkBG2dldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldAMFA2FtbQUIX2Fzc2V0SWQFB190cmFkZXIEBnRvU2VsbAkAZQIFBGRlYnQFBmFtb3VudAQLc2FuaXR5Q2hlY2sDCQBnAgAABQZ0b1NlbGwJAAIBAhFVc2UgcmVwYXkgaW5zdGVhZAUDbmlsAwkAAAIFC3Nhbml0eUNoZWNrBQtzYW5pdHlDaGVjawMDCQEBIQEJAQtpc1doaXRlbGlzdAEFA2FtbQYJAQEhAQkBEGlzV2hpdGVsaXN0QXNzZXQBBQhfYXNzZXRJZAkAAgECK0ludmFsaWQgcmVhbGl6ZVBhcnRpYWxseUFuZENsb3NlIHBhcmFtZXRlcnMEDGFtb3VudEJlZm9yZQkA8AcCBQR0aGlzCQEKcXVvdGVBc3NldAADCQAAAgUMYW1vdW50QmVmb3JlBQxhbW91bnRCZWZvcmUEBmRvU3dhcAkA/AcECQELc3dhcEFkZHJlc3MAAgRzd2FwCQDMCAIJANgEAQkBCnF1b3RlQXNzZXQACQDMCAIAAAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFCF9hc3NldElkBQZ0b1NlbGwFA25pbAMJAAACBQZkb1N3YXAFBmRvU3dhcAQLYW1vdW50QWZ0ZXIJAPAHAgUEdGhpcwkBCnF1b3RlQXNzZXQAAwkAAAIFC2Ftb3VudEFmdGVyBQthbW91bnRBZnRlcgQNc29sZEZvckFtb3VudAkAZQIFC2Ftb3VudEFmdGVyBQxhbW91bnRCZWZvcmUDCQAAAgUNc29sZEZvckFtb3VudAUNc29sZEZvckFtb3VudAQRd2l0aGRyYXdJbnN1cmFuY2UJAPwHBAkBEGluc3VyYW5jZUFkZHJlc3MAAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQpxdW90ZUFzc2V0AAkAZAIFBmFtb3VudAUNc29sZEZvckFtb3VudAUDbmlsAwkAAAIFEXdpdGhkcmF3SW5zdXJhbmNlBRF3aXRoZHJhd0luc3VyYW5jZQQJdG9HZXRCYWNrCQBlAgUEZGVidAUGdG9TZWxsAwkAZgIFCXRvR2V0QmFjawAACQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgkAZQIFBGRlYnQFBnRvU2VsbAkA2QQBBQhfYXNzZXRJZAUDbmlsCQDOCAIFA25pbAkAzAgCCQELRGVsZXRlRW50cnkBCQEeZ2V0Qm9ycm93ZWRCeVRyYWRlckluTWFya2V0S2V5AwUDYW1tBQhfYXNzZXRJZAUHX3RyYWRlcgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEHJlYWxpemVQYXJ0aWFsbHkDB190cmFkZXIIX2Fzc2V0SWQHX3RvU2VsbAQDYW1tCQClCAEIBQFpBmNhbGxlcgQEZGVidAkBG2dldEJvcnJvd2VkQnlUcmFkZXJJbk1hcmtldAMFA2FtbQUIX2Fzc2V0SWQFB190cmFkZXIEC3Nhbml0eUNoZWNrAwMJAGcCAAAFB190b1NlbGwGCQBmAgUHX3RvU2VsbAUEZGVidAkAAgECK0ludmFsaWQgcmVhbGl6ZVBhcnRpYWxseUFuZENsb3NlIHBhcmFtZXRlcnMFA25pbAMJAAACBQtzYW5pdHlDaGVjawULc2FuaXR5Q2hlY2sDAwkBASEBCQELaXNXaGl0ZWxpc3QBBQNhbW0GCQEBIQEJARBpc1doaXRlbGlzdEFzc2V0AQUIX2Fzc2V0SWQJAAIBAitJbnZhbGlkIHJlYWxpemVQYXJ0aWFsbHlBbmRDbG9zZSBwYXJhbWV0ZXJzBAxhbW91bnRCZWZvcmUJAPAHAgUEdGhpcwkBCnF1b3RlQXNzZXQAAwkAAAIFDGFtb3VudEJlZm9yZQUMYW1vdW50QmVmb3JlBAZkb1N3YXAJAPwHBAkBC3N3YXBBZGRyZXNzAAIEc3dhcAkAzAgCCQDYBAEJAQpxdW90ZUFzc2V0AAkAzAgCAAAFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQhfYXNzZXRJZAUHX3RvU2VsbAUDbmlsAwkAAAIFBmRvU3dhcAUGZG9Td2FwBAthbW91bnRBZnRlcgkA8AcCBQR0aGlzCQEKcXVvdGVBc3NldAADCQAAAgULYW1vdW50QWZ0ZXIFC2Ftb3VudEFmdGVyBA1zb2xkRm9yQW1vdW50CQBlAgULYW1vdW50QWZ0ZXIFDGFtb3VudEJlZm9yZQMJAAACBQ1zb2xkRm9yQW1vdW50BQ1zb2xkRm9yQW1vdW50BBF3aXRoZHJhd0luc3VyYW5jZQkA/AcECQEQaW5zdXJhbmNlQWRkcmVzcwACB2RlcG9zaXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBCnF1b3RlQXNzZXQABQ1zb2xkRm9yQW1vdW50BQNuaWwDCQAAAgURd2l0aGRyYXdJbnN1cmFuY2UFEXdpdGhkcmF3SW5zdXJhbmNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEeZ2V0Qm9ycm93ZWRCeVRyYWRlckluTWFya2V0S2V5AwUDYW1tBQhfYXNzZXRJZAUHX3RyYWRlcgkAZQIJARtnZXRCb3Jyb3dlZEJ5VHJhZGVySW5NYXJrZXQDBQNhbW0FCF9hc3NldElkBQdfdHJhZGVyBQdfdG9TZWxsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACQEOYWRtaW5QdWJsaWNLZXkAaxX5PQ==", "height": 2310887, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: HjFAsPEx8miJGpwHGm8oeru6Szzvk5yT5u4TifqfCTqK Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let k_asset_collateral = "k_asset_collateral" | |
5 | + | ||
6 | + | let k_trader_market_asset_collateral = "k_trader_market_asset_collateral" | |
7 | + | ||
8 | + | let k_whitelist_asset = "k_whitelist_asset" | |
9 | + | ||
10 | + | let k_initialized = "k_initialized" | |
11 | + | ||
12 | + | let k_coordinatorAddress = "k_coordinatorAddress" | |
13 | + | ||
14 | + | let k_governance_asset = "k_gov_asset" | |
15 | + | ||
16 | + | let k_quote_asset = "k_quote_asset" | |
17 | + | ||
18 | + | let k_admin_public_key = "k_admin_public_key" | |
19 | + | ||
20 | + | let k_manager_address = "k_manager_address" | |
21 | + | ||
22 | + | let k_amm = "k_amm" | |
23 | + | ||
24 | + | let k_insurance_address = "k_insurance_address" | |
25 | + | ||
26 | + | let k_exchange_address = "k_exchange_address" | |
27 | + | ||
28 | + | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
29 | + | ||
30 | + | ||
31 | + | func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set") | |
32 | + | ||
33 | + | ||
34 | + | func adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key)) | |
35 | + | ||
36 | + | ||
37 | + | func governanceAsset () = fromBase58String(getStringValue(coordinator(), k_governance_asset)) | |
38 | + | ||
39 | + | ||
40 | + | func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset)) | |
41 | + | ||
42 | + | ||
43 | + | func managerAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_manager_address)), "Manager not set") | |
44 | + | ||
45 | + | ||
46 | + | func isWhitelist (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false) | |
47 | + | ||
48 | + | ||
49 | + | func isWhitelistAsset (_assetId) = valueOrElse(getBoolean(this, toCompositeKey(k_whitelist_asset, _assetId)), false) | |
50 | + | ||
51 | + | ||
52 | + | func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set") | |
53 | + | ||
54 | + | ||
55 | + | func swapAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_exchange_address), "No swap address")), "Invalid swap address") | |
56 | + | ||
57 | + | ||
58 | + | let DECIMAL_UNIT = (1 * (((((((10 * 10) * 10) * 10) * 10) * 10) * 10) * 10)) | |
59 | + | ||
60 | + | let DURATION = ((60 * 60) * 24) | |
61 | + | ||
62 | + | let NO_ADDRESS = "" | |
63 | + | ||
64 | + | let NO_STAKER = 0 | |
65 | + | ||
66 | + | func usdnFromDecimals (_amount) = (_amount / 100) | |
67 | + | ||
68 | + | ||
69 | + | func usdnToDecimals (_amount) = (_amount * 100) | |
70 | + | ||
71 | + | ||
72 | + | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
73 | + | ||
74 | + | ||
75 | + | func getBorrowedByTraderInMarketKey (_amm,_assetId,_trader) = ((((((k_trader_market_asset_collateral + "_") + _amm) + "_") + _assetId) + "_") + _trader) | |
76 | + | ||
77 | + | ||
78 | + | func getBorrowedByTraderInMarket (_amm,_assetId,_trader) = { | |
79 | + | let key = getBorrowedByTraderInMarketKey(_amm, _assetId, _trader) | |
80 | + | valueOrElse(getInteger(this, key), 0) | |
81 | + | } | |
82 | + | ||
83 | + | ||
84 | + | @Callable(i) | |
85 | + | func initialize (_coordinator,_whitelist) = if (initialized()) | |
86 | + | then throw("Already initialized") | |
87 | + | else { | |
88 | + | let initialAssetIds = split(_whitelist, ",") | |
89 | + | func doWhitelist (_acc,_assetId) = (_acc :+ BooleanEntry(toCompositeKey(k_whitelist_asset, _assetId), true)) | |
90 | + | ||
91 | + | ({ | |
92 | + | let $l = initialAssetIds | |
93 | + | let $s = size($l) | |
94 | + | let $acc0 = nil | |
95 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
96 | + | then $a | |
97 | + | else doWhitelist($a, $l[$i]) | |
98 | + | ||
99 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
100 | + | then $a | |
101 | + | else throw("List size exceeds 20") | |
102 | + | ||
103 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
104 | + | } ++ [StringEntry(k_coordinatorAddress, _coordinator), BooleanEntry(k_initialized, true)]) | |
105 | + | } | |
106 | + | ||
107 | + | ||
108 | + | ||
109 | + | @Callable(i) | |
110 | + | func borrow (_trader) = { | |
111 | + | let amount = i.payments[0].amount | |
112 | + | let assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "Invalid asset id")) | |
113 | + | let amm = toString(i.caller) | |
114 | + | if (if (!(isWhitelist(amm))) | |
115 | + | then true | |
116 | + | else !(isWhitelistAsset(assetId))) | |
117 | + | then throw("Invalid borrow parameters") | |
118 | + | else { | |
119 | + | let withdrawInsurance = invoke(insuranceAddress(), "withdraw", [amount], nil) | |
120 | + | if ((withdrawInsurance == withdrawInsurance)) | |
121 | + | then [ScriptTransfer(i.caller, amount, quoteAsset()), IntegerEntry(getBorrowedByTraderInMarketKey(amm, assetId, _trader), (getBorrowedByTraderInMarket(amm, assetId, _trader) + amount))] | |
122 | + | else throw("Strict value is not equal to itself.") | |
123 | + | } | |
124 | + | } | |
125 | + | ||
126 | + | ||
127 | + | ||
128 | + | @Callable(i) | |
129 | + | func repay (_trader,_assetId) = { | |
130 | + | let amount = i.payments[0].amount | |
131 | + | let amm = toString(i.caller) | |
132 | + | if (if (!(isWhitelist(amm))) | |
133 | + | then true | |
134 | + | else !(isWhitelistAsset(_assetId))) | |
135 | + | then throw("Invalid repay parameters") | |
136 | + | else { | |
137 | + | let withdrawInsurance = invoke(insuranceAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), amount)]) | |
138 | + | if ((withdrawInsurance == withdrawInsurance)) | |
139 | + | then { | |
140 | + | let newDebt = (getBorrowedByTraderInMarket(amm, _assetId, _trader) - amount) | |
141 | + | ([ScriptTransfer(i.caller, amount, fromBase58String(_assetId))] ++ (if ((newDebt > 0)) | |
142 | + | then [IntegerEntry(getBorrowedByTraderInMarketKey(amm, _assetId, _trader), newDebt)] | |
143 | + | else [DeleteEntry(getBorrowedByTraderInMarketKey(amm, _assetId, _trader))])) | |
144 | + | } | |
145 | + | else throw("Strict value is not equal to itself.") | |
146 | + | } | |
147 | + | } | |
148 | + | ||
149 | + | ||
150 | + | ||
151 | + | @Callable(i) | |
152 | + | func realizePartiallyAndClose (_trader,_assetId) = { | |
153 | + | let amount = if ((size(i.payments) > 0)) | |
154 | + | then i.payments[0].amount | |
155 | + | else 0 | |
156 | + | let amm = toString(i.caller) | |
157 | + | let debt = getBorrowedByTraderInMarket(amm, _assetId, _trader) | |
158 | + | let toSell = (debt - amount) | |
159 | + | let sanityCheck = if ((0 >= toSell)) | |
160 | + | then throw("Use repay instead") | |
161 | + | else nil | |
162 | + | if ((sanityCheck == sanityCheck)) | |
163 | + | then if (if (!(isWhitelist(amm))) | |
164 | + | then true | |
165 | + | else !(isWhitelistAsset(_assetId))) | |
166 | + | then throw("Invalid realizePartiallyAndClose parameters") | |
167 | + | else { | |
168 | + | let amountBefore = assetBalance(this, quoteAsset()) | |
169 | + | if ((amountBefore == amountBefore)) | |
170 | + | then { | |
171 | + | let doSwap = invoke(swapAddress(), "swap", [toBase58String(quoteAsset()), 0], [AttachedPayment(fromBase58String(_assetId), toSell)]) | |
172 | + | if ((doSwap == doSwap)) | |
173 | + | then { | |
174 | + | let amountAfter = assetBalance(this, quoteAsset()) | |
175 | + | if ((amountAfter == amountAfter)) | |
176 | + | then { | |
177 | + | let soldForAmount = (amountAfter - amountBefore) | |
178 | + | if ((soldForAmount == soldForAmount)) | |
179 | + | then { | |
180 | + | let withdrawInsurance = invoke(insuranceAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), (amount + soldForAmount))]) | |
181 | + | if ((withdrawInsurance == withdrawInsurance)) | |
182 | + | then { | |
183 | + | let toGetBack = (debt - toSell) | |
184 | + | if ((toGetBack > 0)) | |
185 | + | then [ScriptTransfer(i.caller, (debt - toSell), fromBase58String(_assetId))] | |
186 | + | else (nil ++ [DeleteEntry(getBorrowedByTraderInMarketKey(amm, _assetId, _trader))]) | |
187 | + | } | |
188 | + | else throw("Strict value is not equal to itself.") | |
189 | + | } | |
190 | + | else throw("Strict value is not equal to itself.") | |
191 | + | } | |
192 | + | else throw("Strict value is not equal to itself.") | |
193 | + | } | |
194 | + | else throw("Strict value is not equal to itself.") | |
195 | + | } | |
196 | + | else throw("Strict value is not equal to itself.") | |
197 | + | } | |
198 | + | else throw("Strict value is not equal to itself.") | |
199 | + | } | |
200 | + | ||
201 | + | ||
202 | + | ||
203 | + | @Callable(i) | |
204 | + | func realizePartially (_trader,_assetId,_toSell) = { | |
205 | + | let amm = toString(i.caller) | |
206 | + | let debt = getBorrowedByTraderInMarket(amm, _assetId, _trader) | |
207 | + | let sanityCheck = if (if ((0 >= _toSell)) | |
208 | + | then true | |
209 | + | else (_toSell > debt)) | |
210 | + | then throw("Invalid realizePartiallyAndClose parameters") | |
211 | + | else nil | |
212 | + | if ((sanityCheck == sanityCheck)) | |
213 | + | then if (if (!(isWhitelist(amm))) | |
214 | + | then true | |
215 | + | else !(isWhitelistAsset(_assetId))) | |
216 | + | then throw("Invalid realizePartiallyAndClose parameters") | |
217 | + | else { | |
218 | + | let amountBefore = assetBalance(this, quoteAsset()) | |
219 | + | if ((amountBefore == amountBefore)) | |
220 | + | then { | |
221 | + | let doSwap = invoke(swapAddress(), "swap", [toBase58String(quoteAsset()), 0], [AttachedPayment(fromBase58String(_assetId), _toSell)]) | |
222 | + | if ((doSwap == doSwap)) | |
223 | + | then { | |
224 | + | let amountAfter = assetBalance(this, quoteAsset()) | |
225 | + | if ((amountAfter == amountAfter)) | |
226 | + | then { | |
227 | + | let soldForAmount = (amountAfter - amountBefore) | |
228 | + | if ((soldForAmount == soldForAmount)) | |
229 | + | then { | |
230 | + | let withdrawInsurance = invoke(insuranceAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), soldForAmount)]) | |
231 | + | if ((withdrawInsurance == withdrawInsurance)) | |
232 | + | then [IntegerEntry(getBorrowedByTraderInMarketKey(amm, _assetId, _trader), (getBorrowedByTraderInMarket(amm, _assetId, _trader) - _toSell))] | |
233 | + | else throw("Strict value is not equal to itself.") | |
234 | + | } | |
235 | + | else throw("Strict value is not equal to itself.") | |
236 | + | } | |
237 | + | else throw("Strict value is not equal to itself.") | |
238 | + | } | |
239 | + | else throw("Strict value is not equal to itself.") | |
240 | + | } | |
241 | + | else throw("Strict value is not equal to itself.") | |
242 | + | } | |
243 | + | else throw("Strict value is not equal to itself.") | |
244 | + | } | |
245 | + | ||
246 | + | ||
247 | + | @Verifier(tx) | |
248 | + | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey()) | |
249 | + |
github/deemru/w8io/169f3d6 21.09 ms ◑