tx · CT38S7wUUk2m8hxerk8xRbP7aC5HfhfDSxKEaQMMsLPu
3NCkVR5gTgfosVUNRTsUHc6kXdhh2V3betH: -0.03700000 Waves
2023.03.03 23:06 [2474335] smart account 3NCkVR5gTgfosVUNRTsUHc6kXdhh2V3betH > SELF 0.00000000 Waves
{
"type": 13,
"id": "CT38S7wUUk2m8hxerk8xRbP7aC5HfhfDSxKEaQMMsLPu",
"fee": 3700000,
"feeAssetId": null,
"timestamp": 1677874016522,
"version": 2,
"chainId": 84,
"sender": "3NCkVR5gTgfosVUNRTsUHc6kXdhh2V3betH",
"senderPublicKey": "3mgJJUcUNFHYP2pNkbkfB2C8D4gSEKEGisFByu2i6xoM",
"proofs": [
"3VzgDWxxG2GubqMjLNdFuyZ3NcDtMWEgVuMMAtzKaw4HeHkRyse5DqBJn57H2uctdYo9VFTqbCFGRBwT4PKQBgQ"
],
"script": "base64:BgIqCAISBQoDCAgIEgASABIECgIICBIECgIIARIAEgMKAQgSAwoBCBIDCgEIFgAHa19mdW5kcwIHa19mdW5kcwAXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MCF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzABRrX2Nvb3JkaW5hdG9yQWRkcmVzcwIUa19jb29yZGluYXRvckFkZHJlc3MAEGtfb3JkZXJzX2FkZHJlc3MCEGtfb3JkZXJzX2FkZHJlc3MAD2tfdmF1bHRfYWRkcmVzcwIPa192YXVsdF9hZGRyZXNzAAVrX2FtbQIFa19hbW0AD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQACGtfcGF1c2VkAghrX3BhdXNlZAEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEJYmFsYW5jZU9mAQhfYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAAAAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCG0Nvb3JkaW5hdG9yIG5vdCBzZXQgTWFuYWdlcgIbQ29vcmRpbmF0b3IgYWRkcmVzcyBpbnZhbGlkAQx2YXVsdEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfdmF1bHRfYWRkcmVzcwIVVmF1bHQgYWRkcmVzcyBub3Qgc2V0AhVWYXVsdCBhZGRyZXNzIGludmFsaWQBDW9yZGVyc0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEGtfb3JkZXJzX2FkZHJlc3MCFk9yZGVycyBhZGRyZXNzIG5vdCBzZXQCFk9yZGVycyBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAQZwYXVzZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFCGtfcGF1c2VkBwETYXNzZXRNYW5hZ2VyQWRkcmVzcwEIX2Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQCsAgICG05vIGFzc2V0IG1hbmFnZXIgZm9yIHRva2VuIAUIX2Fzc2V0SWQJAKwCAgIoSW52YWxpZCBhc3NldCBtYW5hZ2VyIGFkZHJlc3MgZm9yIHRva2VuIAUIX2Fzc2V0SWQBC2lzV2hpdGVsaXN0AQhfYWRkcmVzcwMDCQAAAgUIX2FkZHJlc3MJAKUIAQkBDnN0YWtpbmdBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQEMdmF1bHRBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQENb3JkZXJzQWRkcmVzcwABC3VwZGF0ZUZ1bmRzAghfYXNzZXRJZAZfdmFsdWUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFB2tfZnVuZHMFCF9hc3NldElkBQZfdmFsdWUFA25pbAkBaQEKaW5pdGlhbGl6ZQMMX2Nvb3JkaW5hdG9yDV9xdW90ZUFzc2V0SWQSX3F1b3RlQXNzZXRNYW5hZ2VyAwMJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhRVbmFibGUgdG8gaW5pdGlhbGl6ZQkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwkApQgBCQERQGV4dHJOYXRpdmUoMTA2MikBBQxfY29vcmRpbmF0b3IJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFDV9xdW90ZUFzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUSX3F1b3RlQXNzZXRNYW5hZ2VyCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBB3VucGF1c2UAAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECFkludmFsaWQgdW5wYXVzZSBwYXJhbXMJAMwIAgkBDEJvb2xlYW5FbnRyeQIFCGtfcGF1c2VkBwUDbmlsAWkBBXBhdXNlAAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhRJbnZhbGlkIHBhdXNlIHBhcmFtcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUIa19wYXVzZWQGBQNuaWwBaQEPYWRkQXNzZXRNYW5hZ2VyAghfYXNzZXRJZA1fdmF1bHRBZGRyZXNzAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MABgkBCWlzRGVmaW5lZAEJAKIIAQkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQACAQIcSW52YWxpZCBhZGRUb2tlblZhdWx0IHBhcmFtcwkAzAgCCQELU3RyaW5nRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBRdrX2Fzc2V0X21hbmFnZXJfYWRkcmVzcwUIX2Fzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUNX3ZhdWx0QWRkcmVzcwUDbmlsAWkBCHdpdGhkcmF3AghfYXNzZXRJZAdfYW1vdW50AwMDAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgYJAQEhAQkBC2luaXRpYWxpemVkAAYJAQZwYXVzZWQABgkAZgIFB19hbW91bnQJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAkAAgEJAKwCAgkArAICCQCsAgICIkludmFsaWQgd2l0aGRyYXcgcGFyYW1zIChtYW5hZ2VyKSAJAKQDAQUHX2Ftb3VudAIDID4gCQCkAwEJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAQHdW5zdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgh3aXRoZHJhdwkAzAgCBQhfYXNzZXRJZAkAzAgCBQdfYW1vdW50BQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlBBNjdXJyZW50QXNzZXRCYWxhbmNlCQBlAgkBCWJhbGFuY2VPZgEFCF9hc3NldElkBQdfYW1vdW50CQDOCAIJAQt1cGRhdGVGdW5kcwIFCF9hc3NldElkBRNjdXJyZW50QXNzZXRCYWxhbmNlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUHX2Ftb3VudAkA2QQBBQhfYXNzZXRJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB2RlcG9zaXQABAdfYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQIX2Fzc2V0SWQJANgEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQCCk5vIGFzc2V0SWQDAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAcGCQEGcGF1c2VkAAYJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIEludmFsaWQgZGVwb3NpdCBwYXJhbXMgKG1hbmFnZXIpBAVzdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUHX2Ftb3VudAUDbmlsAwkAAAIFBXN0YWtlBQVzdGFrZQQTY3VycmVudEFzc2V0QmFsYW5jZQkAZAIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUHX2Ftb3VudAkBC3VwZGF0ZUZ1bmRzAgUIX2Fzc2V0SWQFE2N1cnJlbnRBc3NldEJhbGFuY2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELY2xhaW1Qcm9maXQBCF9hc3NldElkAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDHZhdWx0QWRkcmVzcwAJAAIBAiRJbnZhbGlkIGNsYWltUHJvZml0IHBhcmFtcyAobWFuYWdlcikEE2RvQ2xhaW1Qcm9maXRSZXN1bHQJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAILY2xhaW1Qcm9maXQJAMwIAgUIX2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFE2RvQ2xhaW1Qcm9maXRSZXN1bHQFE2RvQ2xhaW1Qcm9maXRSZXN1bHQEBnByb2ZpdAQHJG1hdGNoMAUTZG9DbGFpbVByb2ZpdFJlc3VsdAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAh9JbnZhbGlkIGNsYWltUHJvZml0IHJlc3VsdCB0eXBlCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQZwcm9maXQJANkEAQUIX2Fzc2V0SWQFA25pbAUGcHJvZml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEHZpZXdfY2xhaW1Qcm9maXQBCF9hc3NldElkAwkBASEBCQELaW5pdGlhbGl6ZWQACQACAQIpSW52YWxpZCB2aWV3X2NsYWltUHJvZml0IHBhcmFtcyAobWFuYWdlcikEE2RvQ2xhaW1Qcm9maXRSZXN1bHQJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAILY2xhaW1Qcm9maXQJAMwIAgUIX2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFE2RvQ2xhaW1Qcm9maXRSZXN1bHQFE2RvQ2xhaW1Qcm9maXRSZXN1bHQEBnByb2ZpdAQHJG1hdGNoMAUTZG9DbGFpbVByb2ZpdFJlc3VsdAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAh9JbnZhbGlkIGNsYWltUHJvZml0IHJlc3VsdCB0eXBlCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCkAwEJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAIBLAkApAMBCQBkAgkBCWJhbGFuY2VPZgEFCF9hc3NldElkBQZwcm9maXQCASwJAKQDAQUGcHJvZml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB21pZ3JhdGUBCF9hc3NldElkBAdfYW1vdW50CQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQDAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAGCQEBIQEJAQZwYXVzZWQACQACAQIgSW52YWxpZCBtaWdyYXRlIHBhcmFtcyAobWFuYWdlcikEB3Vuc3Rha2UJAPwHBAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzAg9rX3ZpcmVzX2FkZHJlc3MCF05vIGxlZ2FjeSB2aXJlcyBhZGRyZXNzAhxJbnZhbGlkIGxlZ2FjeSB2aXJlcyBhZGRyZXNzAgh3aXRoZHJhdwkAzAgCBQhfYXNzZXRJZAkAzAgCBQdfYW1vdW50BQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlBAVzdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUIX2Fzc2V0SWQFB19hbW91bnQFA25pbAMJAAACBQVzdGFrZQUFc3Rha2UJAMwIAgkBC0RlbGV0ZUVudHJ5AQIPa192aXJlc19hZGRyZXNzCQDMCAIJAQtEZWxldGVFbnRyeQECDWtfdmlyZXNfdmF1bHQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAEDmNvb3JkaW5hdG9yU3RyCQCdCAIFBHRoaXMFFGtfY29vcmRpbmF0b3JBZGRyZXNzAwkBCWlzRGVmaW5lZAEFDmNvb3JkaW5hdG9yU3RyBAVhZG1pbgkAnQgCCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBBQ5jb29yZGluYXRvclN0cgUPa19hZG1pbl9hZGRyZXNzAwkBCWlzRGVmaW5lZAEFBWFkbWluCQELdmFsdWVPckVsc2UCCQCbCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFBWFkbWluCQCsAgIJAKwCAgkArAICAgdzdGF0dXNfCQClCAEFBHRoaXMCAV8JANgEAQgFAnR4AmlkBwkAAgECLnVuYWJsZSB0byB2ZXJpZnk6IGFkbWluIG5vdCBzZXQgaW4gY29vcmRpbmF0b3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXl9/W95",
"height": 2474335,
"applicationStatus": "succeeded",
"spentComplexity": 0
}
View: original | compacted
Prev: 4qa9sF5Ct77GhVPnmvKGw1FueY37QqMAoFcgMEcdessd
Next: yUBx7abeS1ib8eAcFauLQAwhagmUwdorVgsVpeu9nKL
Diff:
Old | New | | Differences |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let a = "k_funds" |
---|
5 | 5 | | |
---|
6 | | - | let b = "k_vires_address" |
---|
| 6 | + | let b = "k_asset_manager_address" |
---|
7 | 7 | | |
---|
8 | | - | let c = "k_vires_vault" |
---|
| 8 | + | let c = "k_coordinatorAddress" |
---|
9 | 9 | | |
---|
10 | | - | let d = "k_asset_claimed_profit" |
---|
| 10 | + | let d = "k_orders_address" |
---|
11 | 11 | | |
---|
12 | | - | let e = "k_coordinatorAddress" |
---|
| 12 | + | let e = "k_vault_address" |
---|
13 | 13 | | |
---|
14 | | - | let f = "k_orders_address" |
---|
| 14 | + | let f = "k_amm" |
---|
15 | 15 | | |
---|
16 | | - | let g = "k_vault_address" |
---|
| 16 | + | let g = "k_admin_address" |
---|
17 | 17 | | |
---|
18 | | - | let h = "k_amm" |
---|
| 18 | + | let h = "k_staking_address" |
---|
19 | 19 | | |
---|
20 | | - | let i = "k_admin_address" |
---|
| 20 | + | let i = "k_initialized" |
---|
21 | 21 | | |
---|
22 | | - | let j = "k_quote_asset" |
---|
| 22 | + | let j = "k_paused" |
---|
23 | 23 | | |
---|
24 | | - | let k = "k_quote_staking" |
---|
25 | | - | |
---|
26 | | - | let l = "k_staking_address" |
---|
27 | | - | |
---|
28 | | - | let m = "k_initialized" |
---|
29 | | - | |
---|
30 | | - | func n (o,p) = ((o + "_") + p) |
---|
| 24 | + | func k (l,m) = ((l + "_") + m) |
---|
31 | 25 | | |
---|
32 | 26 | | |
---|
33 | | - | func q (r) = valueOrElse(getInteger(this, n(a, r)), 0) |
---|
| 27 | + | func n (o) = valueOrElse(getInteger(this, k(a, o)), 0) |
---|
34 | 28 | | |
---|
35 | 29 | | |
---|
36 | | - | func s () = valueOrErrorMessage(addressFromString(getStringValue(this, e)), "Coordinator not set") |
---|
| 30 | + | func p () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, c), "Coordinator not set Manager")), "Coordinator address invalid") |
---|
37 | 31 | | |
---|
38 | 32 | | |
---|
39 | | - | func t () = valueOrErrorMessage(addressFromString(getStringValue(s(), g)), "Vault not set") |
---|
| 33 | + | func q () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), e), "Vault address not set")), "Vault address invalid") |
---|
40 | 34 | | |
---|
41 | 35 | | |
---|
42 | | - | func u () = valueOrErrorMessage(addressFromString(getStringValue(s(), f)), "Orders not set") |
---|
| 36 | + | func r () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), d), "Orders address not set")), "Orders address invalid") |
---|
43 | 37 | | |
---|
44 | 38 | | |
---|
45 | | - | func v () = valueOrElse(getBoolean(this, m), false) |
---|
| 39 | + | func s () = addressFromString(valueOrErrorMessage(getString(p(), g), "Admin address not set")) |
---|
46 | 40 | | |
---|
47 | 41 | | |
---|
48 | | - | func w () = addressFromString(getStringValue(s(), i)) |
---|
| 42 | + | func t () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), h), "Staking address not set")), "Staking address invalid") |
---|
49 | 43 | | |
---|
50 | 44 | | |
---|
51 | | - | func x () = fromBase58String(getStringValue(s(), j)) |
---|
| 45 | + | func u () = valueOrElse(getBoolean(this, i), false) |
---|
52 | 46 | | |
---|
53 | 47 | | |
---|
54 | | - | func y () = valueOrErrorMessage(addressFromString(getStringValue(s(), l)), "Staking not set") |
---|
| 48 | + | func v () = valueOrElse(getBoolean(this, j), false) |
---|
55 | 49 | | |
---|
56 | 50 | | |
---|
57 | | - | func z () = valueOrErrorMessage(addressFromString(getStringValue(this, b)), "Vires not set") |
---|
| 51 | + | func w (o) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k(b, o)), ("No asset manager for token " + o))), ("Invalid asset manager address for token " + o)) |
---|
58 | 52 | | |
---|
59 | 53 | | |
---|
60 | | - | func A (r) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, n(c, r)), ("No vault for token " + r))), ("Invalid address for token " + r)) |
---|
| 54 | + | func x (m) = if (if ((m == toString(t()))) |
---|
| 55 | + | then true |
---|
| 56 | + | else (m == toString(q()))) |
---|
| 57 | + | then true |
---|
| 58 | + | else (m == toString(r())) |
---|
61 | 59 | | |
---|
62 | 60 | | |
---|
63 | | - | func B (p) = if (if ((p == toString(y()))) |
---|
64 | | - | then true |
---|
65 | | - | else (p == toString(t()))) |
---|
66 | | - | then true |
---|
67 | | - | else (p == toString(u())) |
---|
| 61 | + | func y (o,z) = [IntegerEntry(k(a, o), z)] |
---|
68 | 62 | | |
---|
69 | 63 | | |
---|
70 | | - | func C (r,D) = [IntegerEntry(n(a, r), D)] |
---|
71 | | - | |
---|
72 | | - | |
---|
73 | | - | @Callable(E) |
---|
74 | | - | func initialize (F,G,H,I) = if (if (v()) |
---|
| 64 | + | @Callable(A) |
---|
| 65 | + | func initialize (B,C,D) = if (if (u()) |
---|
75 | 66 | | then true |
---|
76 | | - | else (E.caller != this)) |
---|
| 67 | + | else (A.caller != this)) |
---|
77 | 68 | | then throw("Unable to initialize") |
---|
78 | | - | else [StringEntry(e, toString(addressFromStringValue(F))), StringEntry(b, toString(addressFromStringValue(G))), StringEntry(n(c, H), toString(addressFromStringValue(I))), BooleanEntry(m, true)] |
---|
| 69 | + | else [StringEntry(c, toString(addressFromStringValue(B))), StringEntry(k(b, C), toString(addressFromStringValue(D))), BooleanEntry(i, true)] |
---|
79 | 70 | | |
---|
80 | 71 | | |
---|
81 | 72 | | |
---|
82 | | - | @Callable(E) |
---|
83 | | - | func addTokenVault (r,J) = if (if (!(v())) |
---|
84 | | - | then true |
---|
85 | | - | else (E.caller != w())) |
---|
86 | | - | then throw("Invalid addTokenVault params") |
---|
87 | | - | else [StringEntry(n(c, r), toString(addressFromStringValue(J)))] |
---|
| 73 | + | @Callable(A) |
---|
| 74 | + | func unpause () = if ((A.caller != s())) |
---|
| 75 | + | then throw("Invalid unpause params") |
---|
| 76 | + | else [BooleanEntry(j, false)] |
---|
88 | 77 | | |
---|
89 | 78 | | |
---|
90 | 79 | | |
---|
91 | | - | @Callable(E) |
---|
92 | | - | func withdraw (r,K) = if (if (if (!(B(toString(E.caller)))) |
---|
| 80 | + | @Callable(A) |
---|
| 81 | + | func pause () = if ((A.caller != s())) |
---|
| 82 | + | then throw("Invalid pause params") |
---|
| 83 | + | else [BooleanEntry(j, true)] |
---|
| 84 | + | |
---|
| 85 | + | |
---|
| 86 | + | |
---|
| 87 | + | @Callable(A) |
---|
| 88 | + | func addAssetManager (o,E) = if (if (if (!(u())) |
---|
93 | 89 | | then true |
---|
94 | | - | else !(v())) |
---|
| 90 | + | else (A.caller != s())) |
---|
95 | 91 | | then true |
---|
96 | | - | else (K > q(r))) |
---|
97 | | - | then throw(((("Invalid withdraw params (manager) " + toString(K)) + " > ") + toString(q(r)))) |
---|
| 92 | + | else isDefined(getString(k(b, o)))) |
---|
| 93 | + | then throw("Invalid addTokenVault params") |
---|
| 94 | + | else [StringEntry(k(b, o), toString(addressFromStringValue(E)))] |
---|
| 95 | + | |
---|
| 96 | + | |
---|
| 97 | + | |
---|
| 98 | + | @Callable(A) |
---|
| 99 | + | func withdraw (o,F) = if (if (if (if (!(x(toString(A.caller)))) |
---|
| 100 | + | then true |
---|
| 101 | + | else !(u())) |
---|
| 102 | + | then true |
---|
| 103 | + | else v()) |
---|
| 104 | + | then true |
---|
| 105 | + | else (F > n(o))) |
---|
| 106 | + | then throw(((("Invalid withdraw params (manager) " + toString(F)) + " > ") + toString(n(o)))) |
---|
98 | 107 | | else { |
---|
99 | | - | let L = invoke(z(), "withdraw", [r, K], nil) |
---|
100 | | - | if ((L == L)) |
---|
| 108 | + | let G = invoke(w(o), "withdraw", [o, F], nil) |
---|
| 109 | + | if ((G == G)) |
---|
101 | 110 | | then { |
---|
102 | | - | let M = (q(r) - K) |
---|
103 | | - | (C(r, M) ++ [ScriptTransfer(E.caller, K, fromBase58String(r))]) |
---|
| 111 | + | let H = (n(o) - F) |
---|
| 112 | + | (y(o, H) ++ [ScriptTransfer(A.caller, F, fromBase58String(o))]) |
---|
104 | 113 | | } |
---|
105 | 114 | | else throw("Strict value is not equal to itself.") |
---|
106 | 115 | | } |
---|
107 | 116 | | |
---|
108 | 117 | | |
---|
109 | 118 | | |
---|
110 | | - | @Callable(E) |
---|
| 119 | + | @Callable(A) |
---|
111 | 120 | | func deposit () = { |
---|
112 | | - | let K = E.payments[0].amount |
---|
113 | | - | let r = toBase58String(valueOrErrorMessage(E.payments[0].assetId, "No assetId")) |
---|
114 | | - | if (if (if ((E.payments[0].assetId != x())) |
---|
| 121 | + | let F = A.payments[0].amount |
---|
| 122 | + | let o = toBase58String(valueOrErrorMessage(A.payments[0].assetId, "No assetId")) |
---|
| 123 | + | if (if (if (if (!(u())) |
---|
115 | 124 | | then true |
---|
116 | | - | else !(v())) |
---|
| 125 | + | else if (!(x(toString(A.caller)))) |
---|
| 126 | + | then (A.caller != s()) |
---|
| 127 | + | else false) |
---|
117 | 128 | | then true |
---|
118 | | - | else if (!(B(toString(E.caller)))) |
---|
119 | | - | then (E.caller != w()) |
---|
120 | | - | else false) |
---|
| 129 | + | else v()) |
---|
| 130 | + | then true |
---|
| 131 | + | else (size(A.payments) != 1)) |
---|
121 | 132 | | then throw("Invalid deposit params (manager)") |
---|
122 | 133 | | else { |
---|
123 | | - | let N = A(r) |
---|
124 | | - | let O = invoke(z(), "deposit", [toString(N), false], [AttachedPayment(E.payments[0].assetId, K)]) |
---|
125 | | - | if ((O == O)) |
---|
| 134 | + | let I = invoke(w(o), "deposit", nil, [AttachedPayment(A.payments[0].assetId, F)]) |
---|
| 135 | + | if ((I == I)) |
---|
126 | 136 | | then { |
---|
127 | | - | let M = (q(r) + K) |
---|
128 | | - | C(r, M) |
---|
| 137 | + | let H = (n(o) + F) |
---|
| 138 | + | y(o, H) |
---|
129 | 139 | | } |
---|
130 | 140 | | else throw("Strict value is not equal to itself.") |
---|
131 | 141 | | } |
---|
|
133 | 143 | | |
---|
134 | 144 | | |
---|
135 | 145 | | |
---|
136 | | - | @Callable(E) |
---|
137 | | - | func claimProfit (r) = if (if (if ((fromBase58String(r) != x())) |
---|
| 146 | + | @Callable(A) |
---|
| 147 | + | func claimProfit (o) = if (if (!(u())) |
---|
138 | 148 | | then true |
---|
139 | | - | else !(v())) |
---|
140 | | - | then true |
---|
141 | | - | else (E.caller != t())) |
---|
142 | | - | then throw("Invalid claimProfit params") |
---|
| 149 | + | else (A.caller != q())) |
---|
| 150 | + | then throw("Invalid claimProfit params (manager)") |
---|
143 | 151 | | else { |
---|
144 | | - | let P = invoke(A(r), "getCurrentTotals", [toString(this)], nil) |
---|
145 | | - | if ((P == P)) |
---|
| 152 | + | let J = invoke(w(o), "claimProfit", [o], nil) |
---|
| 153 | + | if ((J == J)) |
---|
146 | 154 | | then { |
---|
147 | | - | let M = { |
---|
148 | | - | let Q = P |
---|
149 | | - | if ($isInstanceOf(Q, "(Int, Int, Int, Int)")) |
---|
| 155 | + | let K = { |
---|
| 156 | + | let L = J |
---|
| 157 | + | if ($isInstanceOf(L, "Int")) |
---|
150 | 158 | | then { |
---|
151 | | - | let R = Q |
---|
152 | | - | R._3 |
---|
| 159 | + | let M = L |
---|
| 160 | + | M |
---|
153 | 161 | | } |
---|
154 | | - | else throw("Invalid currentAmount type") |
---|
| 162 | + | else throw("Invalid claimProfit result type") |
---|
155 | 163 | | } |
---|
156 | | - | let S = (M - q(r)) |
---|
157 | | - | let L = invoke(z(), "withdraw", [r, S], nil) |
---|
158 | | - | if ((L == L)) |
---|
159 | | - | then $Tuple2([ScriptTransfer(E.caller, S, fromBase58String(r))], S) |
---|
160 | | - | else throw("Strict value is not equal to itself.") |
---|
| 164 | + | $Tuple2([ScriptTransfer(A.caller, K, fromBase58String(o))], K) |
---|
161 | 165 | | } |
---|
162 | 166 | | else throw("Strict value is not equal to itself.") |
---|
163 | 167 | | } |
---|
164 | 168 | | |
---|
165 | 169 | | |
---|
166 | 170 | | |
---|
167 | | - | @Callable(E) |
---|
168 | | - | func view_claimProfit (r) = if (if ((fromBase58String(r) != x())) |
---|
169 | | - | then true |
---|
170 | | - | else !(v())) |
---|
171 | | - | then throw("Invalid view_claimProfit params") |
---|
| 171 | + | @Callable(A) |
---|
| 172 | + | func view_claimProfit (o) = if (!(u())) |
---|
| 173 | + | then throw("Invalid view_claimProfit params (manager)") |
---|
172 | 174 | | else { |
---|
173 | | - | let P = invoke(A(r), "getCurrentTotals", [toString(this)], nil) |
---|
174 | | - | if ((P == P)) |
---|
| 175 | + | let J = invoke(w(o), "claimProfit", [o], nil) |
---|
| 176 | + | if ((J == J)) |
---|
175 | 177 | | then { |
---|
176 | | - | let M = { |
---|
177 | | - | let Q = P |
---|
178 | | - | if ($isInstanceOf(Q, "(Int, Int, Int, Int)")) |
---|
| 178 | + | let K = { |
---|
| 179 | + | let L = J |
---|
| 180 | + | if ($isInstanceOf(L, "Int")) |
---|
179 | 181 | | then { |
---|
180 | | - | let R = Q |
---|
181 | | - | R._3 |
---|
| 182 | + | let M = L |
---|
| 183 | + | M |
---|
182 | 184 | | } |
---|
183 | | - | else throw("Invalid currentAmount type") |
---|
| 185 | + | else throw("Invalid claimProfit result type") |
---|
184 | 186 | | } |
---|
185 | | - | let S = (M - q(r)) |
---|
186 | | - | throw(((((toString(q(r)) + ",") + toString(M)) + ",") + toString(S))) |
---|
| 187 | + | throw(((((toString(n(o)) + ",") + toString((n(o) + K))) + ",") + toString(K))) |
---|
187 | 188 | | } |
---|
188 | 189 | | else throw("Strict value is not equal to itself.") |
---|
189 | 190 | | } |
---|
190 | 191 | | |
---|
191 | 192 | | |
---|
192 | | - | @Verifier(T) |
---|
193 | | - | func U () = { |
---|
194 | | - | let V = getString(this, e) |
---|
195 | | - | if (isDefined(V)) |
---|
| 193 | + | |
---|
| 194 | + | @Callable(A) |
---|
| 195 | + | func migrate (o) = { |
---|
| 196 | + | let F = n(o) |
---|
| 197 | + | if (if (if (!(u())) |
---|
| 198 | + | then true |
---|
| 199 | + | else (A.caller != s())) |
---|
| 200 | + | then true |
---|
| 201 | + | else !(v())) |
---|
| 202 | + | then throw("Invalid migrate params (manager)") |
---|
| 203 | + | else { |
---|
| 204 | + | let G = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [o, F], nil) |
---|
| 205 | + | if ((G == G)) |
---|
| 206 | + | then { |
---|
| 207 | + | let I = invoke(w(o), "deposit", nil, [AttachedPayment(fromBase58String(o), F)]) |
---|
| 208 | + | if ((I == I)) |
---|
| 209 | + | then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")] |
---|
| 210 | + | else throw("Strict value is not equal to itself.") |
---|
| 211 | + | } |
---|
| 212 | + | else throw("Strict value is not equal to itself.") |
---|
| 213 | + | } |
---|
| 214 | + | } |
---|
| 215 | + | |
---|
| 216 | + | |
---|
| 217 | + | @Verifier(N) |
---|
| 218 | + | func O () = { |
---|
| 219 | + | let P = getString(this, c) |
---|
| 220 | + | if (isDefined(P)) |
---|
196 | 221 | | then { |
---|
197 | | - | let W = getString(addressFromStringValue(value(V)), i) |
---|
198 | | - | if (isDefined(W)) |
---|
199 | | - | then valueOrElse(getBoolean(addressFromStringValue(value(W)), ((("status_" + toString(this)) + "_") + toBase58String(T.id))), false) |
---|
| 222 | + | let Q = getString(addressFromStringValue(value(P)), g) |
---|
| 223 | + | if (isDefined(Q)) |
---|
| 224 | + | then valueOrElse(getBoolean(addressFromStringValue(value(Q)), ((("status_" + toString(this)) + "_") + toBase58String(N.id))), false) |
---|
200 | 225 | | else throw("unable to verify: admin not set in coordinator") |
---|
201 | 226 | | } |
---|
202 | | - | else sigVerify(T.bodyBytes, T.proofs[0], T.senderPublicKey) |
---|
| 227 | + | else sigVerify(N.bodyBytes, N.proofs[0], N.senderPublicKey) |
---|
203 | 228 | | } |
---|
204 | 229 | | |
---|
Full:
Old | New | | Differences |
---|
1 | 1 | | {-# STDLIB_VERSION 6 #-} |
---|
2 | 2 | | {-# SCRIPT_TYPE ACCOUNT #-} |
---|
3 | 3 | | {-# CONTENT_TYPE DAPP #-} |
---|
4 | 4 | | let a = "k_funds" |
---|
5 | 5 | | |
---|
6 | | - | let b = "k_vires_address" |
---|
| 6 | + | let b = "k_asset_manager_address" |
---|
7 | 7 | | |
---|
8 | | - | let c = "k_vires_vault" |
---|
| 8 | + | let c = "k_coordinatorAddress" |
---|
9 | 9 | | |
---|
10 | | - | let d = "k_asset_claimed_profit" |
---|
| 10 | + | let d = "k_orders_address" |
---|
11 | 11 | | |
---|
12 | | - | let e = "k_coordinatorAddress" |
---|
| 12 | + | let e = "k_vault_address" |
---|
13 | 13 | | |
---|
14 | | - | let f = "k_orders_address" |
---|
| 14 | + | let f = "k_amm" |
---|
15 | 15 | | |
---|
16 | | - | let g = "k_vault_address" |
---|
| 16 | + | let g = "k_admin_address" |
---|
17 | 17 | | |
---|
18 | | - | let h = "k_amm" |
---|
| 18 | + | let h = "k_staking_address" |
---|
19 | 19 | | |
---|
20 | | - | let i = "k_admin_address" |
---|
| 20 | + | let i = "k_initialized" |
---|
21 | 21 | | |
---|
22 | | - | let j = "k_quote_asset" |
---|
| 22 | + | let j = "k_paused" |
---|
23 | 23 | | |
---|
24 | | - | let k = "k_quote_staking" |
---|
25 | | - | |
---|
26 | | - | let l = "k_staking_address" |
---|
27 | | - | |
---|
28 | | - | let m = "k_initialized" |
---|
29 | | - | |
---|
30 | | - | func n (o,p) = ((o + "_") + p) |
---|
| 24 | + | func k (l,m) = ((l + "_") + m) |
---|
31 | 25 | | |
---|
32 | 26 | | |
---|
33 | | - | func q (r) = valueOrElse(getInteger(this, n(a, r)), 0) |
---|
| 27 | + | func n (o) = valueOrElse(getInteger(this, k(a, o)), 0) |
---|
34 | 28 | | |
---|
35 | 29 | | |
---|
36 | | - | func s () = valueOrErrorMessage(addressFromString(getStringValue(this, e)), "Coordinator not set") |
---|
| 30 | + | func p () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, c), "Coordinator not set Manager")), "Coordinator address invalid") |
---|
37 | 31 | | |
---|
38 | 32 | | |
---|
39 | | - | func t () = valueOrErrorMessage(addressFromString(getStringValue(s(), g)), "Vault not set") |
---|
| 33 | + | func q () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), e), "Vault address not set")), "Vault address invalid") |
---|
40 | 34 | | |
---|
41 | 35 | | |
---|
42 | | - | func u () = valueOrErrorMessage(addressFromString(getStringValue(s(), f)), "Orders not set") |
---|
| 36 | + | func r () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), d), "Orders address not set")), "Orders address invalid") |
---|
43 | 37 | | |
---|
44 | 38 | | |
---|
45 | | - | func v () = valueOrElse(getBoolean(this, m), false) |
---|
| 39 | + | func s () = addressFromString(valueOrErrorMessage(getString(p(), g), "Admin address not set")) |
---|
46 | 40 | | |
---|
47 | 41 | | |
---|
48 | | - | func w () = addressFromString(getStringValue(s(), i)) |
---|
| 42 | + | func t () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(p(), h), "Staking address not set")), "Staking address invalid") |
---|
49 | 43 | | |
---|
50 | 44 | | |
---|
51 | | - | func x () = fromBase58String(getStringValue(s(), j)) |
---|
| 45 | + | func u () = valueOrElse(getBoolean(this, i), false) |
---|
52 | 46 | | |
---|
53 | 47 | | |
---|
54 | | - | func y () = valueOrErrorMessage(addressFromString(getStringValue(s(), l)), "Staking not set") |
---|
| 48 | + | func v () = valueOrElse(getBoolean(this, j), false) |
---|
55 | 49 | | |
---|
56 | 50 | | |
---|
57 | | - | func z () = valueOrErrorMessage(addressFromString(getStringValue(this, b)), "Vires not set") |
---|
| 51 | + | func w (o) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k(b, o)), ("No asset manager for token " + o))), ("Invalid asset manager address for token " + o)) |
---|
58 | 52 | | |
---|
59 | 53 | | |
---|
60 | | - | func A (r) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, n(c, r)), ("No vault for token " + r))), ("Invalid address for token " + r)) |
---|
| 54 | + | func x (m) = if (if ((m == toString(t()))) |
---|
| 55 | + | then true |
---|
| 56 | + | else (m == toString(q()))) |
---|
| 57 | + | then true |
---|
| 58 | + | else (m == toString(r())) |
---|
61 | 59 | | |
---|
62 | 60 | | |
---|
63 | | - | func B (p) = if (if ((p == toString(y()))) |
---|
64 | | - | then true |
---|
65 | | - | else (p == toString(t()))) |
---|
66 | | - | then true |
---|
67 | | - | else (p == toString(u())) |
---|
| 61 | + | func y (o,z) = [IntegerEntry(k(a, o), z)] |
---|
68 | 62 | | |
---|
69 | 63 | | |
---|
70 | | - | func C (r,D) = [IntegerEntry(n(a, r), D)] |
---|
71 | | - | |
---|
72 | | - | |
---|
73 | | - | @Callable(E) |
---|
74 | | - | func initialize (F,G,H,I) = if (if (v()) |
---|
| 64 | + | @Callable(A) |
---|
| 65 | + | func initialize (B,C,D) = if (if (u()) |
---|
75 | 66 | | then true |
---|
76 | | - | else (E.caller != this)) |
---|
| 67 | + | else (A.caller != this)) |
---|
77 | 68 | | then throw("Unable to initialize") |
---|
78 | | - | else [StringEntry(e, toString(addressFromStringValue(F))), StringEntry(b, toString(addressFromStringValue(G))), StringEntry(n(c, H), toString(addressFromStringValue(I))), BooleanEntry(m, true)] |
---|
| 69 | + | else [StringEntry(c, toString(addressFromStringValue(B))), StringEntry(k(b, C), toString(addressFromStringValue(D))), BooleanEntry(i, true)] |
---|
79 | 70 | | |
---|
80 | 71 | | |
---|
81 | 72 | | |
---|
82 | | - | @Callable(E) |
---|
83 | | - | func addTokenVault (r,J) = if (if (!(v())) |
---|
84 | | - | then true |
---|
85 | | - | else (E.caller != w())) |
---|
86 | | - | then throw("Invalid addTokenVault params") |
---|
87 | | - | else [StringEntry(n(c, r), toString(addressFromStringValue(J)))] |
---|
| 73 | + | @Callable(A) |
---|
| 74 | + | func unpause () = if ((A.caller != s())) |
---|
| 75 | + | then throw("Invalid unpause params") |
---|
| 76 | + | else [BooleanEntry(j, false)] |
---|
88 | 77 | | |
---|
89 | 78 | | |
---|
90 | 79 | | |
---|
91 | | - | @Callable(E) |
---|
92 | | - | func withdraw (r,K) = if (if (if (!(B(toString(E.caller)))) |
---|
| 80 | + | @Callable(A) |
---|
| 81 | + | func pause () = if ((A.caller != s())) |
---|
| 82 | + | then throw("Invalid pause params") |
---|
| 83 | + | else [BooleanEntry(j, true)] |
---|
| 84 | + | |
---|
| 85 | + | |
---|
| 86 | + | |
---|
| 87 | + | @Callable(A) |
---|
| 88 | + | func addAssetManager (o,E) = if (if (if (!(u())) |
---|
93 | 89 | | then true |
---|
94 | | - | else !(v())) |
---|
| 90 | + | else (A.caller != s())) |
---|
95 | 91 | | then true |
---|
96 | | - | else (K > q(r))) |
---|
97 | | - | then throw(((("Invalid withdraw params (manager) " + toString(K)) + " > ") + toString(q(r)))) |
---|
| 92 | + | else isDefined(getString(k(b, o)))) |
---|
| 93 | + | then throw("Invalid addTokenVault params") |
---|
| 94 | + | else [StringEntry(k(b, o), toString(addressFromStringValue(E)))] |
---|
| 95 | + | |
---|
| 96 | + | |
---|
| 97 | + | |
---|
| 98 | + | @Callable(A) |
---|
| 99 | + | func withdraw (o,F) = if (if (if (if (!(x(toString(A.caller)))) |
---|
| 100 | + | then true |
---|
| 101 | + | else !(u())) |
---|
| 102 | + | then true |
---|
| 103 | + | else v()) |
---|
| 104 | + | then true |
---|
| 105 | + | else (F > n(o))) |
---|
| 106 | + | then throw(((("Invalid withdraw params (manager) " + toString(F)) + " > ") + toString(n(o)))) |
---|
98 | 107 | | else { |
---|
99 | | - | let L = invoke(z(), "withdraw", [r, K], nil) |
---|
100 | | - | if ((L == L)) |
---|
| 108 | + | let G = invoke(w(o), "withdraw", [o, F], nil) |
---|
| 109 | + | if ((G == G)) |
---|
101 | 110 | | then { |
---|
102 | | - | let M = (q(r) - K) |
---|
103 | | - | (C(r, M) ++ [ScriptTransfer(E.caller, K, fromBase58String(r))]) |
---|
| 111 | + | let H = (n(o) - F) |
---|
| 112 | + | (y(o, H) ++ [ScriptTransfer(A.caller, F, fromBase58String(o))]) |
---|
104 | 113 | | } |
---|
105 | 114 | | else throw("Strict value is not equal to itself.") |
---|
106 | 115 | | } |
---|
107 | 116 | | |
---|
108 | 117 | | |
---|
109 | 118 | | |
---|
110 | | - | @Callable(E) |
---|
| 119 | + | @Callable(A) |
---|
111 | 120 | | func deposit () = { |
---|
112 | | - | let K = E.payments[0].amount |
---|
113 | | - | let r = toBase58String(valueOrErrorMessage(E.payments[0].assetId, "No assetId")) |
---|
114 | | - | if (if (if ((E.payments[0].assetId != x())) |
---|
| 121 | + | let F = A.payments[0].amount |
---|
| 122 | + | let o = toBase58String(valueOrErrorMessage(A.payments[0].assetId, "No assetId")) |
---|
| 123 | + | if (if (if (if (!(u())) |
---|
115 | 124 | | then true |
---|
116 | | - | else !(v())) |
---|
| 125 | + | else if (!(x(toString(A.caller)))) |
---|
| 126 | + | then (A.caller != s()) |
---|
| 127 | + | else false) |
---|
117 | 128 | | then true |
---|
118 | | - | else if (!(B(toString(E.caller)))) |
---|
119 | | - | then (E.caller != w()) |
---|
120 | | - | else false) |
---|
| 129 | + | else v()) |
---|
| 130 | + | then true |
---|
| 131 | + | else (size(A.payments) != 1)) |
---|
121 | 132 | | then throw("Invalid deposit params (manager)") |
---|
122 | 133 | | else { |
---|
123 | | - | let N = A(r) |
---|
124 | | - | let O = invoke(z(), "deposit", [toString(N), false], [AttachedPayment(E.payments[0].assetId, K)]) |
---|
125 | | - | if ((O == O)) |
---|
| 134 | + | let I = invoke(w(o), "deposit", nil, [AttachedPayment(A.payments[0].assetId, F)]) |
---|
| 135 | + | if ((I == I)) |
---|
126 | 136 | | then { |
---|
127 | | - | let M = (q(r) + K) |
---|
128 | | - | C(r, M) |
---|
| 137 | + | let H = (n(o) + F) |
---|
| 138 | + | y(o, H) |
---|
129 | 139 | | } |
---|
130 | 140 | | else throw("Strict value is not equal to itself.") |
---|
131 | 141 | | } |
---|
132 | 142 | | } |
---|
133 | 143 | | |
---|
134 | 144 | | |
---|
135 | 145 | | |
---|
136 | | - | @Callable(E) |
---|
137 | | - | func claimProfit (r) = if (if (if ((fromBase58String(r) != x())) |
---|
| 146 | + | @Callable(A) |
---|
| 147 | + | func claimProfit (o) = if (if (!(u())) |
---|
138 | 148 | | then true |
---|
139 | | - | else !(v())) |
---|
140 | | - | then true |
---|
141 | | - | else (E.caller != t())) |
---|
142 | | - | then throw("Invalid claimProfit params") |
---|
| 149 | + | else (A.caller != q())) |
---|
| 150 | + | then throw("Invalid claimProfit params (manager)") |
---|
143 | 151 | | else { |
---|
144 | | - | let P = invoke(A(r), "getCurrentTotals", [toString(this)], nil) |
---|
145 | | - | if ((P == P)) |
---|
| 152 | + | let J = invoke(w(o), "claimProfit", [o], nil) |
---|
| 153 | + | if ((J == J)) |
---|
146 | 154 | | then { |
---|
147 | | - | let M = { |
---|
148 | | - | let Q = P |
---|
149 | | - | if ($isInstanceOf(Q, "(Int, Int, Int, Int)")) |
---|
| 155 | + | let K = { |
---|
| 156 | + | let L = J |
---|
| 157 | + | if ($isInstanceOf(L, "Int")) |
---|
150 | 158 | | then { |
---|
151 | | - | let R = Q |
---|
152 | | - | R._3 |
---|
| 159 | + | let M = L |
---|
| 160 | + | M |
---|
153 | 161 | | } |
---|
154 | | - | else throw("Invalid currentAmount type") |
---|
| 162 | + | else throw("Invalid claimProfit result type") |
---|
155 | 163 | | } |
---|
156 | | - | let S = (M - q(r)) |
---|
157 | | - | let L = invoke(z(), "withdraw", [r, S], nil) |
---|
158 | | - | if ((L == L)) |
---|
159 | | - | then $Tuple2([ScriptTransfer(E.caller, S, fromBase58String(r))], S) |
---|
160 | | - | else throw("Strict value is not equal to itself.") |
---|
| 164 | + | $Tuple2([ScriptTransfer(A.caller, K, fromBase58String(o))], K) |
---|
161 | 165 | | } |
---|
162 | 166 | | else throw("Strict value is not equal to itself.") |
---|
163 | 167 | | } |
---|
164 | 168 | | |
---|
165 | 169 | | |
---|
166 | 170 | | |
---|
167 | | - | @Callable(E) |
---|
168 | | - | func view_claimProfit (r) = if (if ((fromBase58String(r) != x())) |
---|
169 | | - | then true |
---|
170 | | - | else !(v())) |
---|
171 | | - | then throw("Invalid view_claimProfit params") |
---|
| 171 | + | @Callable(A) |
---|
| 172 | + | func view_claimProfit (o) = if (!(u())) |
---|
| 173 | + | then throw("Invalid view_claimProfit params (manager)") |
---|
172 | 174 | | else { |
---|
173 | | - | let P = invoke(A(r), "getCurrentTotals", [toString(this)], nil) |
---|
174 | | - | if ((P == P)) |
---|
| 175 | + | let J = invoke(w(o), "claimProfit", [o], nil) |
---|
| 176 | + | if ((J == J)) |
---|
175 | 177 | | then { |
---|
176 | | - | let M = { |
---|
177 | | - | let Q = P |
---|
178 | | - | if ($isInstanceOf(Q, "(Int, Int, Int, Int)")) |
---|
| 178 | + | let K = { |
---|
| 179 | + | let L = J |
---|
| 180 | + | if ($isInstanceOf(L, "Int")) |
---|
179 | 181 | | then { |
---|
180 | | - | let R = Q |
---|
181 | | - | R._3 |
---|
| 182 | + | let M = L |
---|
| 183 | + | M |
---|
182 | 184 | | } |
---|
183 | | - | else throw("Invalid currentAmount type") |
---|
| 185 | + | else throw("Invalid claimProfit result type") |
---|
184 | 186 | | } |
---|
185 | | - | let S = (M - q(r)) |
---|
186 | | - | throw(((((toString(q(r)) + ",") + toString(M)) + ",") + toString(S))) |
---|
| 187 | + | throw(((((toString(n(o)) + ",") + toString((n(o) + K))) + ",") + toString(K))) |
---|
187 | 188 | | } |
---|
188 | 189 | | else throw("Strict value is not equal to itself.") |
---|
189 | 190 | | } |
---|
190 | 191 | | |
---|
191 | 192 | | |
---|
192 | | - | @Verifier(T) |
---|
193 | | - | func U () = { |
---|
194 | | - | let V = getString(this, e) |
---|
195 | | - | if (isDefined(V)) |
---|
| 193 | + | |
---|
| 194 | + | @Callable(A) |
---|
| 195 | + | func migrate (o) = { |
---|
| 196 | + | let F = n(o) |
---|
| 197 | + | if (if (if (!(u())) |
---|
| 198 | + | then true |
---|
| 199 | + | else (A.caller != s())) |
---|
| 200 | + | then true |
---|
| 201 | + | else !(v())) |
---|
| 202 | + | then throw("Invalid migrate params (manager)") |
---|
| 203 | + | else { |
---|
| 204 | + | let G = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [o, F], nil) |
---|
| 205 | + | if ((G == G)) |
---|
| 206 | + | then { |
---|
| 207 | + | let I = invoke(w(o), "deposit", nil, [AttachedPayment(fromBase58String(o), F)]) |
---|
| 208 | + | if ((I == I)) |
---|
| 209 | + | then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")] |
---|
| 210 | + | else throw("Strict value is not equal to itself.") |
---|
| 211 | + | } |
---|
| 212 | + | else throw("Strict value is not equal to itself.") |
---|
| 213 | + | } |
---|
| 214 | + | } |
---|
| 215 | + | |
---|
| 216 | + | |
---|
| 217 | + | @Verifier(N) |
---|
| 218 | + | func O () = { |
---|
| 219 | + | let P = getString(this, c) |
---|
| 220 | + | if (isDefined(P)) |
---|
196 | 221 | | then { |
---|
197 | | - | let W = getString(addressFromStringValue(value(V)), i) |
---|
198 | | - | if (isDefined(W)) |
---|
199 | | - | then valueOrElse(getBoolean(addressFromStringValue(value(W)), ((("status_" + toString(this)) + "_") + toBase58String(T.id))), false) |
---|
| 222 | + | let Q = getString(addressFromStringValue(value(P)), g) |
---|
| 223 | + | if (isDefined(Q)) |
---|
| 224 | + | then valueOrElse(getBoolean(addressFromStringValue(value(Q)), ((("status_" + toString(this)) + "_") + toBase58String(N.id))), false) |
---|
200 | 225 | | else throw("unable to verify: admin not set in coordinator") |
---|
201 | 226 | | } |
---|
202 | | - | else sigVerify(T.bodyBytes, T.proofs[0], T.senderPublicKey) |
---|
| 227 | + | else sigVerify(N.bodyBytes, N.proofs[0], N.senderPublicKey) |
---|
203 | 228 | | } |
---|
204 | 229 | | |
---|