tx · FjEgKDRm5gCK1njP3zjJho2Mzz9noPMHGRtMCqzbTPn6 3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1: -0.03700000 Waves 2023.04.17 20:01 [2538836] smart account 3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1 > SELF 0.00000000 Waves
{ "type": 13, "id": "FjEgKDRm5gCK1njP3zjJho2Mzz9noPMHGRtMCqzbTPn6", "fee": 3700000, "feeAssetId": null, "timestamp": 1681750932332, "version": 2, "chainId": 84, "sender": "3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1", "senderPublicKey": "CTp72rvnrsKt4McoAfMqWvCXKfQQyvcrLiM1ff8k77cK", "proofs": [ "eiNXC46nEWToc6CKYiUqua88ryr1Abo35aC3cf33m4CnQqmFsYEZgkPNdMavdHC8p1VcP5L3U1Y8HepxfFoYekY" ], "script": "base64:BgIqCAISBQoDCAgIEgASABIECgIICBIECgIIARIAEgMKAQgSAwoBCBIDCgEIFgAHa19mdW5kcwIHa19mdW5kcwAXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MCF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzABRrX2Nvb3JkaW5hdG9yQWRkcmVzcwIUa19jb29yZGluYXRvckFkZHJlc3MAEGtfb3JkZXJzX2FkZHJlc3MCEGtfb3JkZXJzX2FkZHJlc3MAD2tfdmF1bHRfYWRkcmVzcwIPa192YXVsdF9hZGRyZXNzAAVrX2FtbQIFa19hbW0AD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQACGtfcGF1c2VkAghrX3BhdXNlZAEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEJYmFsYW5jZU9mAQhfYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAAAAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCG0Nvb3JkaW5hdG9yIG5vdCBzZXQgTWFuYWdlcgIbQ29vcmRpbmF0b3IgYWRkcmVzcyBpbnZhbGlkAQx2YXVsdEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfdmF1bHRfYWRkcmVzcwIVVmF1bHQgYWRkcmVzcyBub3Qgc2V0AhVWYXVsdCBhZGRyZXNzIGludmFsaWQBDW9yZGVyc0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEGtfb3JkZXJzX2FkZHJlc3MCFk9yZGVycyBhZGRyZXNzIG5vdCBzZXQCFk9yZGVycyBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAQZwYXVzZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFCGtfcGF1c2VkBwETYXNzZXRNYW5hZ2VyQWRkcmVzcwEIX2Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQCsAgICG05vIGFzc2V0IG1hbmFnZXIgZm9yIHRva2VuIAUIX2Fzc2V0SWQJAKwCAgIoSW52YWxpZCBhc3NldCBtYW5hZ2VyIGFkZHJlc3MgZm9yIHRva2VuIAUIX2Fzc2V0SWQBC2lzV2hpdGVsaXN0AQhfYWRkcmVzcwMDCQAAAgUIX2FkZHJlc3MJAKUIAQkBDnN0YWtpbmdBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQEMdmF1bHRBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQENb3JkZXJzQWRkcmVzcwABC3VwZGF0ZUZ1bmRzAghfYXNzZXRJZAZfdmFsdWUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFB2tfZnVuZHMFCF9hc3NldElkBQZfdmFsdWUFA25pbAkBaQEKaW5pdGlhbGl6ZQMMX2Nvb3JkaW5hdG9yDV9xdW90ZUFzc2V0SWQSX3F1b3RlQXNzZXRNYW5hZ2VyAwMJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhRVbmFibGUgdG8gaW5pdGlhbGl6ZQkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwkApQgBCQERQGV4dHJOYXRpdmUoMTA2MikBBQxfY29vcmRpbmF0b3IJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFDV9xdW90ZUFzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUSX3F1b3RlQXNzZXRNYW5hZ2VyCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBB3VucGF1c2UAAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECFkludmFsaWQgdW5wYXVzZSBwYXJhbXMJAMwIAgkBDEJvb2xlYW5FbnRyeQIFCGtfcGF1c2VkBwUDbmlsAWkBBXBhdXNlAAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhRJbnZhbGlkIHBhdXNlIHBhcmFtcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUIa19wYXVzZWQGBQNuaWwBaQEPYWRkQXNzZXRNYW5hZ2VyAghfYXNzZXRJZA1fdmF1bHRBZGRyZXNzAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MABgkBCWlzRGVmaW5lZAEJAKIIAQkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQACAQIcSW52YWxpZCBhZGRUb2tlblZhdWx0IHBhcmFtcwkAzAgCCQELU3RyaW5nRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBRdrX2Fzc2V0X21hbmFnZXJfYWRkcmVzcwUIX2Fzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUNX3ZhdWx0QWRkcmVzcwUDbmlsAWkBCHdpdGhkcmF3AghfYXNzZXRJZAdfYW1vdW50AwMDAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgYJAQEhAQkBC2luaXRpYWxpemVkAAYJAQZwYXVzZWQABgkAZgIFB19hbW91bnQJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAkAAgEJAKwCAgkArAICCQCsAgICIkludmFsaWQgd2l0aGRyYXcgcGFyYW1zIChtYW5hZ2VyKSAJAKQDAQUHX2Ftb3VudAIDID4gCQCkAwEJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAQHdW5zdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgh3aXRoZHJhdwkAzAgCBQhfYXNzZXRJZAkAzAgCBQdfYW1vdW50BQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlBBNjdXJyZW50QXNzZXRCYWxhbmNlCQBlAgkBCWJhbGFuY2VPZgEFCF9hc3NldElkBQdfYW1vdW50CQDOCAIJAQt1cGRhdGVGdW5kcwIFCF9hc3NldElkBRNjdXJyZW50QXNzZXRCYWxhbmNlCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUHX2Ftb3VudAkA2QQBBQhfYXNzZXRJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB2RlcG9zaXQABAdfYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQIX2Fzc2V0SWQJANgEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQCCk5vIGFzc2V0SWQDAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAcGCQEGcGF1c2VkAAYJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIEludmFsaWQgZGVwb3NpdCBwYXJhbXMgKG1hbmFnZXIpBAVzdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUHX2Ftb3VudAUDbmlsAwkAAAIFBXN0YWtlBQVzdGFrZQQTY3VycmVudEFzc2V0QmFsYW5jZQkAZAIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUHX2Ftb3VudAkBC3VwZGF0ZUZ1bmRzAgUIX2Fzc2V0SWQFE2N1cnJlbnRBc3NldEJhbGFuY2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELY2xhaW1Qcm9maXQBCF9hc3NldElkAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDHZhdWx0QWRkcmVzcwAJAAIBAiRJbnZhbGlkIGNsYWltUHJvZml0IHBhcmFtcyAobWFuYWdlcikEE2RvQ2xhaW1Qcm9maXRSZXN1bHQJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAILY2xhaW1Qcm9maXQJAMwIAgUIX2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFE2RvQ2xhaW1Qcm9maXRSZXN1bHQFE2RvQ2xhaW1Qcm9maXRSZXN1bHQEBnByb2ZpdAQHJG1hdGNoMAUTZG9DbGFpbVByb2ZpdFJlc3VsdAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAh9JbnZhbGlkIGNsYWltUHJvZml0IHJlc3VsdCB0eXBlCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQZwcm9maXQJANkEAQUIX2Fzc2V0SWQFA25pbAUGcHJvZml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBEHZpZXdfY2xhaW1Qcm9maXQBCF9hc3NldElkAwkBASEBCQELaW5pdGlhbGl6ZWQACQACAQIpSW52YWxpZCB2aWV3X2NsYWltUHJvZml0IHBhcmFtcyAobWFuYWdlcikEE2RvQ2xhaW1Qcm9maXRSZXN1bHQJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAILY2xhaW1Qcm9maXQJAMwIAgUIX2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFE2RvQ2xhaW1Qcm9maXRSZXN1bHQFE2RvQ2xhaW1Qcm9maXRSZXN1bHQEBnByb2ZpdAQHJG1hdGNoMAUTZG9DbGFpbVByb2ZpdFJlc3VsdAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAh9JbnZhbGlkIGNsYWltUHJvZml0IHJlc3VsdCB0eXBlCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCkAwEJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAIBLAkApAMBCQBkAgkBCWJhbGFuY2VPZgEFCF9hc3NldElkBQZwcm9maXQCASwJAKQDAQUGcHJvZml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB21pZ3JhdGUBCF9hc3NldElkBAdfYW1vdW50CQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQDAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAGCQEBIQEJAQZwYXVzZWQACQACAQIgSW52YWxpZCBtaWdyYXRlIHBhcmFtcyAobWFuYWdlcikEB3Vuc3Rha2UJAPwHBAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzAg9rX3ZpcmVzX2FkZHJlc3MCF05vIGxlZ2FjeSB2aXJlcyBhZGRyZXNzAhxJbnZhbGlkIGxlZ2FjeSB2aXJlcyBhZGRyZXNzAgh3aXRoZHJhdwkAzAgCBQhfYXNzZXRJZAkAzAgCBQdfYW1vdW50BQNuaWwFA25pbAMJAAACBQd1bnN0YWtlBQd1bnN0YWtlBAVzdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUIX2Fzc2V0SWQFB19hbW91bnQFA25pbAMJAAACBQVzdGFrZQUFc3Rha2UJAMwIAgkBC0RlbGV0ZUVudHJ5AQIPa192aXJlc19hZGRyZXNzCQDMCAIJAQtEZWxldGVFbnRyeQECDWtfdmlyZXNfdmF1bHQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAEDmNvb3JkaW5hdG9yU3RyCQCdCAIFBHRoaXMFFGtfY29vcmRpbmF0b3JBZGRyZXNzAwkBCWlzRGVmaW5lZAEFDmNvb3JkaW5hdG9yU3RyBAVhZG1pbgkAnQgCCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBBQ5jb29yZGluYXRvclN0cgUPa19hZG1pbl9hZGRyZXNzAwkBCWlzRGVmaW5lZAEFBWFkbWluCQELdmFsdWVPckVsc2UCCQCbCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFBWFkbWluCQCsAgIJAKwCAgkArAICAgdzdGF0dXNfCQClCAEFBHRoaXMCAV8JANgEAQgFAnR4AmlkBwkAAgECLnVuYWJsZSB0byB2ZXJpZnk6IGFkbWluIG5vdCBzZXQgaW4gY29vcmRpbmF0b3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXl9/W95", "height": 2538836, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Ceoojvfoem57bXehrotTwycmnSTqVCWCrE9YBtY6y4YD Next: none Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let k_funds = "k_funds" | |
5 | 5 | ||
6 | - | let k_vires_address = "k_vires_address" | |
7 | - | ||
8 | - | let k_vires_vault = "k_vires_vault" | |
9 | - | ||
10 | - | let k_asset_claimed_profit = "k_asset_claimed_profit" | |
6 | + | let k_asset_manager_address = "k_asset_manager_address" | |
11 | 7 | ||
12 | 8 | let k_coordinatorAddress = "k_coordinatorAddress" | |
13 | - | ||
14 | - | let k_insurance_address = "k_insurance_address" | |
15 | 9 | ||
16 | 10 | let k_orders_address = "k_orders_address" | |
17 | 11 | ||
21 | 15 | ||
22 | 16 | let k_admin_address = "k_admin_address" | |
23 | 17 | ||
24 | - | let k_admin_public_key = "k_admin_public_key" | |
25 | - | ||
26 | - | let k_quote_asset = "k_quote_asset" | |
27 | - | ||
28 | - | let k_quote_staking = "k_quote_staking" | |
29 | - | ||
30 | 18 | let k_staking_address = "k_staking_address" | |
31 | 19 | ||
32 | 20 | let k_initialized = "k_initialized" | |
21 | + | ||
22 | + | let k_paused = "k_paused" | |
33 | 23 | ||
34 | 24 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
35 | 25 | ||
37 | 27 | func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0) | |
38 | 28 | ||
39 | 29 | ||
40 | - | func coordinator () = valueOrErrorMessage(addressFromString( | |
30 | + | func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid") | |
41 | 31 | ||
42 | 32 | ||
43 | - | func | |
33 | + | func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid") | |
44 | 34 | ||
45 | 35 | ||
46 | - | func | |
36 | + | func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid") | |
47 | 37 | ||
48 | 38 | ||
49 | - | func | |
39 | + | func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set")) | |
50 | 40 | ||
51 | 41 | ||
52 | - | func | |
42 | + | func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid") | |
53 | 43 | ||
54 | 44 | ||
55 | 45 | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
56 | 46 | ||
57 | 47 | ||
58 | - | func | |
48 | + | func paused () = valueOrElse(getBoolean(this, k_paused), false) | |
59 | 49 | ||
60 | 50 | ||
61 | - | func | |
51 | + | func assetManagerAddress (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_asset_manager_address, _assetId)), ("No asset manager for token " + _assetId))), ("Invalid asset manager address for token " + _assetId)) | |
62 | 52 | ||
63 | 53 | ||
64 | - | func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset)) | |
65 | - | ||
66 | - | ||
67 | - | func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set") | |
68 | - | ||
69 | - | ||
70 | - | func viresAddress () = valueOrErrorMessage(addressFromString(getStringValue(this, k_vires_address)), "Vires not set") | |
71 | - | ||
72 | - | ||
73 | - | func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId)) | |
74 | - | ||
75 | - | ||
76 | - | func isWhitelist (_address) = if (if (if (if (isAmm(_address)) | |
77 | - | then true | |
78 | - | else (_address == toString(insuranceAddress()))) | |
79 | - | then true | |
80 | - | else (_address == toString(stakingAddress()))) | |
54 | + | func isWhitelist (_address) = if (if ((_address == toString(stakingAddress()))) | |
81 | 55 | then true | |
82 | 56 | else (_address == toString(vaultAddress()))) | |
83 | 57 | then true | |
88 | 62 | ||
89 | 63 | ||
90 | 64 | @Callable(i) | |
91 | - | func initialize (_coordinator,_viresAddress,_quoteAssetId,_quoteAssetVault) = if (initialized()) | |
92 | - | then throw("Already initialized") | |
93 | - | else [StringEntry(k_coordinatorAddress, _coordinator), StringEntry(k_vires_address, _viresAddress), StringEntry(toCompositeKey(k_vires_vault, _quoteAssetId), _quoteAssetVault), BooleanEntry(k_initialized, true)] | |
65 | + | func initialize (_coordinator,_quoteAssetId,_quoteAssetManager) = if (if (initialized()) | |
66 | + | then true | |
67 | + | else (i.caller != this)) | |
68 | + | then throw("Unable to initialize") | |
69 | + | else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), StringEntry(toCompositeKey(k_asset_manager_address, _quoteAssetId), toString(addressFromStringValue(_quoteAssetManager))), BooleanEntry(k_initialized, true)] | |
94 | 70 | ||
95 | 71 | ||
96 | 72 | ||
97 | 73 | @Callable(i) | |
98 | - | func addTokenVault (_assetId,_vaultAddress) = if (if (!(initialized())) | |
99 | - | then true | |
100 | - | else (i.caller != adminAddress())) | |
101 | - | then throw("Invalid addTokenVault params") | |
102 | - | else [StringEntry(toCompositeKey(k_vires_vault, _assetId), _vaultAddress)] | |
74 | + | func unpause () = if ((i.caller != adminAddress())) | |
75 | + | then throw("Invalid unpause params") | |
76 | + | else [BooleanEntry(k_paused, false)] | |
103 | 77 | ||
104 | 78 | ||
105 | 79 | ||
106 | 80 | @Callable(i) | |
107 | - | func withdraw (_assetId,_amount) = if (if (if (!(isWhitelist(toString(i.caller)))) | |
81 | + | func pause () = if ((i.caller != adminAddress())) | |
82 | + | then throw("Invalid pause params") | |
83 | + | else [BooleanEntry(k_paused, true)] | |
84 | + | ||
85 | + | ||
86 | + | ||
87 | + | @Callable(i) | |
88 | + | func addAssetManager (_assetId,_vaultAddress) = if (if (if (!(initialized())) | |
89 | + | then true | |
90 | + | else (i.caller != adminAddress())) | |
91 | + | then true | |
92 | + | else isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId)))) | |
93 | + | then throw("Invalid addTokenVault params") | |
94 | + | else [StringEntry(toCompositeKey(k_asset_manager_address, _assetId), toString(addressFromStringValue(_vaultAddress)))] | |
95 | + | ||
96 | + | ||
97 | + | ||
98 | + | @Callable(i) | |
99 | + | func withdraw (_assetId,_amount) = if (if (if (if (!(isWhitelist(toString(i.caller)))) | |
108 | 100 | then true | |
109 | 101 | else !(initialized())) | |
102 | + | then true | |
103 | + | else paused()) | |
110 | 104 | then true | |
111 | 105 | else (_amount > balanceOf(_assetId))) | |
112 | 106 | then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
113 | 107 | else { | |
114 | - | let unstake = invoke( | |
108 | + | let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil) | |
115 | 109 | if ((unstake == unstake)) | |
116 | 110 | then { | |
117 | 111 | let currentAssetBalance = (balanceOf(_assetId) - _amount) | |
126 | 120 | func deposit () = { | |
127 | 121 | let _amount = i.payments[0].amount | |
128 | 122 | let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId")) | |
129 | - | if (if (if ((i.payments[0].assetId != quoteAsset())) | |
130 | - | then true | |
131 | - | else !(initialized())) | |
123 | + | if (if (if (if (!(initialized())) | |
132 | 124 | then true | |
133 | 125 | else if (!(isWhitelist(toString(i.caller)))) | |
134 | 126 | then (i.caller != adminAddress()) | |
135 | 127 | else false) | |
128 | + | then true | |
129 | + | else paused()) | |
130 | + | then true | |
131 | + | else (size(i.payments) != 1)) | |
136 | 132 | then throw("Invalid deposit params (manager)") | |
137 | 133 | else { | |
138 | - | let vault = viresVault(_assetId) | |
139 | - | let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)]) | |
134 | + | let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(i.payments[0].assetId, _amount)]) | |
140 | 135 | if ((stake == stake)) | |
141 | 136 | then { | |
142 | 137 | let currentAssetBalance = (balanceOf(_assetId) + _amount) | |
149 | 144 | ||
150 | 145 | ||
151 | 146 | @Callable(i) | |
152 | - | func claimProfit (_assetId) = if (if ( | |
147 | + | func claimProfit (_assetId) = if (if (!(initialized())) | |
153 | 148 | then true | |
154 | - | else !(initialized())) | |
155 | - | then true | |
156 | - | else (i.caller != adminAddress())) | |
157 | - | then throw("Invalid claimProfit params") | |
149 | + | else (i.caller != vaultAddress())) | |
150 | + | then throw("Invalid claimProfit params (manager)") | |
158 | 151 | else { | |
159 | - | let | |
160 | - | if (( | |
152 | + | let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil) | |
153 | + | if ((doClaimProfitResult == doClaimProfitResult)) | |
161 | 154 | then { | |
162 | - | let | |
163 | - | case t: | |
164 | - | t | |
155 | + | let profit = match doClaimProfitResult { | |
156 | + | case t: Int => | |
157 | + | t | |
165 | 158 | case _ => | |
166 | - | throw("Invalid | |
159 | + | throw("Invalid claimProfit result type") | |
167 | 160 | } | |
168 | - | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
169 | - | let unstake = invoke(viresAddress(), "withdraw", [_assetId, profit], nil) | |
170 | - | if ((unstake == unstake)) | |
171 | - | then [ScriptTransfer(i.caller, profit, fromBase58String(_assetId))] | |
172 | - | else throw("Strict value is not equal to itself.") | |
161 | + | $Tuple2([ScriptTransfer(i.caller, profit, fromBase58String(_assetId))], profit) | |
173 | 162 | } | |
174 | 163 | else throw("Strict value is not equal to itself.") | |
175 | 164 | } | |
177 | 166 | ||
178 | 167 | ||
179 | 168 | @Callable(i) | |
180 | - | func view_claimProfit (_assetId) = if (if ((fromBase58String(_assetId) != quoteAsset())) | |
181 | - | then true | |
182 | - | else !(initialized())) | |
183 | - | then throw("Invalid view_claimProfit params") | |
169 | + | func view_claimProfit (_assetId) = if (!(initialized())) | |
170 | + | then throw("Invalid view_claimProfit params (manager)") | |
184 | 171 | else { | |
185 | - | let | |
186 | - | if (( | |
172 | + | let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil) | |
173 | + | if ((doClaimProfitResult == doClaimProfitResult)) | |
187 | 174 | then { | |
188 | - | let | |
189 | - | case t: | |
190 | - | t | |
175 | + | let profit = match doClaimProfitResult { | |
176 | + | case t: Int => | |
177 | + | t | |
191 | 178 | case _ => | |
192 | - | throw("Invalid | |
179 | + | throw("Invalid claimProfit result type") | |
193 | 180 | } | |
194 | - | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
195 | - | throw(((((toString(balanceOf(_assetId)) + ",") + toString(currentAssetBalance)) + ",") + toString(profit))) | |
181 | + | throw(((((toString(balanceOf(_assetId)) + ",") + toString((balanceOf(_assetId) + profit))) + ",") + toString(profit))) | |
196 | 182 | } | |
197 | 183 | else throw("Strict value is not equal to itself.") | |
198 | 184 | } | |
199 | 185 | ||
200 | 186 | ||
187 | + | ||
188 | + | @Callable(i) | |
189 | + | func migrate (_assetId) = { | |
190 | + | let _amount = balanceOf(_assetId) | |
191 | + | if (if (if (!(initialized())) | |
192 | + | then true | |
193 | + | else (i.caller != adminAddress())) | |
194 | + | then true | |
195 | + | else !(paused())) | |
196 | + | then throw("Invalid migrate params (manager)") | |
197 | + | else { | |
198 | + | let unstake = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [_assetId, _amount], nil) | |
199 | + | if ((unstake == unstake)) | |
200 | + | then { | |
201 | + | let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(fromBase58String(_assetId), _amount)]) | |
202 | + | if ((stake == stake)) | |
203 | + | then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")] | |
204 | + | else throw("Strict value is not equal to itself.") | |
205 | + | } | |
206 | + | else throw("Strict value is not equal to itself.") | |
207 | + | } | |
208 | + | } | |
209 | + | ||
210 | + | ||
201 | 211 | @Verifier(tx) | |
202 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey()) | |
212 | + | func verify () = { | |
213 | + | let coordinatorStr = getString(this, k_coordinatorAddress) | |
214 | + | if (isDefined(coordinatorStr)) | |
215 | + | then { | |
216 | + | let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address) | |
217 | + | if (isDefined(admin)) | |
218 | + | then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false) | |
219 | + | else throw("unable to verify: admin not set in coordinator") | |
220 | + | } | |
221 | + | else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
222 | + | } | |
203 | 223 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let k_funds = "k_funds" | |
5 | 5 | ||
6 | - | let k_vires_address = "k_vires_address" | |
7 | - | ||
8 | - | let k_vires_vault = "k_vires_vault" | |
9 | - | ||
10 | - | let k_asset_claimed_profit = "k_asset_claimed_profit" | |
6 | + | let k_asset_manager_address = "k_asset_manager_address" | |
11 | 7 | ||
12 | 8 | let k_coordinatorAddress = "k_coordinatorAddress" | |
13 | - | ||
14 | - | let k_insurance_address = "k_insurance_address" | |
15 | 9 | ||
16 | 10 | let k_orders_address = "k_orders_address" | |
17 | 11 | ||
18 | 12 | let k_vault_address = "k_vault_address" | |
19 | 13 | ||
20 | 14 | let k_amm = "k_amm" | |
21 | 15 | ||
22 | 16 | let k_admin_address = "k_admin_address" | |
23 | 17 | ||
24 | - | let k_admin_public_key = "k_admin_public_key" | |
25 | - | ||
26 | - | let k_quote_asset = "k_quote_asset" | |
27 | - | ||
28 | - | let k_quote_staking = "k_quote_staking" | |
29 | - | ||
30 | 18 | let k_staking_address = "k_staking_address" | |
31 | 19 | ||
32 | 20 | let k_initialized = "k_initialized" | |
21 | + | ||
22 | + | let k_paused = "k_paused" | |
33 | 23 | ||
34 | 24 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
35 | 25 | ||
36 | 26 | ||
37 | 27 | func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0) | |
38 | 28 | ||
39 | 29 | ||
40 | - | func coordinator () = valueOrErrorMessage(addressFromString( | |
30 | + | func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid") | |
41 | 31 | ||
42 | 32 | ||
43 | - | func | |
33 | + | func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid") | |
44 | 34 | ||
45 | 35 | ||
46 | - | func | |
36 | + | func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid") | |
47 | 37 | ||
48 | 38 | ||
49 | - | func | |
39 | + | func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set")) | |
50 | 40 | ||
51 | 41 | ||
52 | - | func | |
42 | + | func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid") | |
53 | 43 | ||
54 | 44 | ||
55 | 45 | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
56 | 46 | ||
57 | 47 | ||
58 | - | func | |
48 | + | func paused () = valueOrElse(getBoolean(this, k_paused), false) | |
59 | 49 | ||
60 | 50 | ||
61 | - | func | |
51 | + | func assetManagerAddress (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_asset_manager_address, _assetId)), ("No asset manager for token " + _assetId))), ("Invalid asset manager address for token " + _assetId)) | |
62 | 52 | ||
63 | 53 | ||
64 | - | func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset)) | |
65 | - | ||
66 | - | ||
67 | - | func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set") | |
68 | - | ||
69 | - | ||
70 | - | func viresAddress () = valueOrErrorMessage(addressFromString(getStringValue(this, k_vires_address)), "Vires not set") | |
71 | - | ||
72 | - | ||
73 | - | func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId)) | |
74 | - | ||
75 | - | ||
76 | - | func isWhitelist (_address) = if (if (if (if (isAmm(_address)) | |
77 | - | then true | |
78 | - | else (_address == toString(insuranceAddress()))) | |
79 | - | then true | |
80 | - | else (_address == toString(stakingAddress()))) | |
54 | + | func isWhitelist (_address) = if (if ((_address == toString(stakingAddress()))) | |
81 | 55 | then true | |
82 | 56 | else (_address == toString(vaultAddress()))) | |
83 | 57 | then true | |
84 | 58 | else (_address == toString(ordersAddress())) | |
85 | 59 | ||
86 | 60 | ||
87 | 61 | func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)] | |
88 | 62 | ||
89 | 63 | ||
90 | 64 | @Callable(i) | |
91 | - | func initialize (_coordinator,_viresAddress,_quoteAssetId,_quoteAssetVault) = if (initialized()) | |
92 | - | then throw("Already initialized") | |
93 | - | else [StringEntry(k_coordinatorAddress, _coordinator), StringEntry(k_vires_address, _viresAddress), StringEntry(toCompositeKey(k_vires_vault, _quoteAssetId), _quoteAssetVault), BooleanEntry(k_initialized, true)] | |
65 | + | func initialize (_coordinator,_quoteAssetId,_quoteAssetManager) = if (if (initialized()) | |
66 | + | then true | |
67 | + | else (i.caller != this)) | |
68 | + | then throw("Unable to initialize") | |
69 | + | else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), StringEntry(toCompositeKey(k_asset_manager_address, _quoteAssetId), toString(addressFromStringValue(_quoteAssetManager))), BooleanEntry(k_initialized, true)] | |
94 | 70 | ||
95 | 71 | ||
96 | 72 | ||
97 | 73 | @Callable(i) | |
98 | - | func addTokenVault (_assetId,_vaultAddress) = if (if (!(initialized())) | |
99 | - | then true | |
100 | - | else (i.caller != adminAddress())) | |
101 | - | then throw("Invalid addTokenVault params") | |
102 | - | else [StringEntry(toCompositeKey(k_vires_vault, _assetId), _vaultAddress)] | |
74 | + | func unpause () = if ((i.caller != adminAddress())) | |
75 | + | then throw("Invalid unpause params") | |
76 | + | else [BooleanEntry(k_paused, false)] | |
103 | 77 | ||
104 | 78 | ||
105 | 79 | ||
106 | 80 | @Callable(i) | |
107 | - | func withdraw (_assetId,_amount) = if (if (if (!(isWhitelist(toString(i.caller)))) | |
81 | + | func pause () = if ((i.caller != adminAddress())) | |
82 | + | then throw("Invalid pause params") | |
83 | + | else [BooleanEntry(k_paused, true)] | |
84 | + | ||
85 | + | ||
86 | + | ||
87 | + | @Callable(i) | |
88 | + | func addAssetManager (_assetId,_vaultAddress) = if (if (if (!(initialized())) | |
89 | + | then true | |
90 | + | else (i.caller != adminAddress())) | |
91 | + | then true | |
92 | + | else isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId)))) | |
93 | + | then throw("Invalid addTokenVault params") | |
94 | + | else [StringEntry(toCompositeKey(k_asset_manager_address, _assetId), toString(addressFromStringValue(_vaultAddress)))] | |
95 | + | ||
96 | + | ||
97 | + | ||
98 | + | @Callable(i) | |
99 | + | func withdraw (_assetId,_amount) = if (if (if (if (!(isWhitelist(toString(i.caller)))) | |
108 | 100 | then true | |
109 | 101 | else !(initialized())) | |
102 | + | then true | |
103 | + | else paused()) | |
110 | 104 | then true | |
111 | 105 | else (_amount > balanceOf(_assetId))) | |
112 | 106 | then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
113 | 107 | else { | |
114 | - | let unstake = invoke( | |
108 | + | let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil) | |
115 | 109 | if ((unstake == unstake)) | |
116 | 110 | then { | |
117 | 111 | let currentAssetBalance = (balanceOf(_assetId) - _amount) | |
118 | 112 | (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))]) | |
119 | 113 | } | |
120 | 114 | else throw("Strict value is not equal to itself.") | |
121 | 115 | } | |
122 | 116 | ||
123 | 117 | ||
124 | 118 | ||
125 | 119 | @Callable(i) | |
126 | 120 | func deposit () = { | |
127 | 121 | let _amount = i.payments[0].amount | |
128 | 122 | let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId")) | |
129 | - | if (if (if ((i.payments[0].assetId != quoteAsset())) | |
130 | - | then true | |
131 | - | else !(initialized())) | |
123 | + | if (if (if (if (!(initialized())) | |
132 | 124 | then true | |
133 | 125 | else if (!(isWhitelist(toString(i.caller)))) | |
134 | 126 | then (i.caller != adminAddress()) | |
135 | 127 | else false) | |
128 | + | then true | |
129 | + | else paused()) | |
130 | + | then true | |
131 | + | else (size(i.payments) != 1)) | |
136 | 132 | then throw("Invalid deposit params (manager)") | |
137 | 133 | else { | |
138 | - | let vault = viresVault(_assetId) | |
139 | - | let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)]) | |
134 | + | let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(i.payments[0].assetId, _amount)]) | |
140 | 135 | if ((stake == stake)) | |
141 | 136 | then { | |
142 | 137 | let currentAssetBalance = (balanceOf(_assetId) + _amount) | |
143 | 138 | updateFunds(_assetId, currentAssetBalance) | |
144 | 139 | } | |
145 | 140 | else throw("Strict value is not equal to itself.") | |
146 | 141 | } | |
147 | 142 | } | |
148 | 143 | ||
149 | 144 | ||
150 | 145 | ||
151 | 146 | @Callable(i) | |
152 | - | func claimProfit (_assetId) = if (if ( | |
147 | + | func claimProfit (_assetId) = if (if (!(initialized())) | |
153 | 148 | then true | |
154 | - | else !(initialized())) | |
155 | - | then true | |
156 | - | else (i.caller != adminAddress())) | |
157 | - | then throw("Invalid claimProfit params") | |
149 | + | else (i.caller != vaultAddress())) | |
150 | + | then throw("Invalid claimProfit params (manager)") | |
158 | 151 | else { | |
159 | - | let | |
160 | - | if (( | |
152 | + | let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil) | |
153 | + | if ((doClaimProfitResult == doClaimProfitResult)) | |
161 | 154 | then { | |
162 | - | let | |
163 | - | case t: | |
164 | - | t | |
155 | + | let profit = match doClaimProfitResult { | |
156 | + | case t: Int => | |
157 | + | t | |
165 | 158 | case _ => | |
166 | - | throw("Invalid | |
159 | + | throw("Invalid claimProfit result type") | |
167 | 160 | } | |
168 | - | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
169 | - | let unstake = invoke(viresAddress(), "withdraw", [_assetId, profit], nil) | |
170 | - | if ((unstake == unstake)) | |
171 | - | then [ScriptTransfer(i.caller, profit, fromBase58String(_assetId))] | |
172 | - | else throw("Strict value is not equal to itself.") | |
161 | + | $Tuple2([ScriptTransfer(i.caller, profit, fromBase58String(_assetId))], profit) | |
173 | 162 | } | |
174 | 163 | else throw("Strict value is not equal to itself.") | |
175 | 164 | } | |
176 | 165 | ||
177 | 166 | ||
178 | 167 | ||
179 | 168 | @Callable(i) | |
180 | - | func view_claimProfit (_assetId) = if (if ((fromBase58String(_assetId) != quoteAsset())) | |
181 | - | then true | |
182 | - | else !(initialized())) | |
183 | - | then throw("Invalid view_claimProfit params") | |
169 | + | func view_claimProfit (_assetId) = if (!(initialized())) | |
170 | + | then throw("Invalid view_claimProfit params (manager)") | |
184 | 171 | else { | |
185 | - | let | |
186 | - | if (( | |
172 | + | let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil) | |
173 | + | if ((doClaimProfitResult == doClaimProfitResult)) | |
187 | 174 | then { | |
188 | - | let | |
189 | - | case t: | |
190 | - | t | |
175 | + | let profit = match doClaimProfitResult { | |
176 | + | case t: Int => | |
177 | + | t | |
191 | 178 | case _ => | |
192 | - | throw("Invalid | |
179 | + | throw("Invalid claimProfit result type") | |
193 | 180 | } | |
194 | - | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
195 | - | throw(((((toString(balanceOf(_assetId)) + ",") + toString(currentAssetBalance)) + ",") + toString(profit))) | |
181 | + | throw(((((toString(balanceOf(_assetId)) + ",") + toString((balanceOf(_assetId) + profit))) + ",") + toString(profit))) | |
196 | 182 | } | |
197 | 183 | else throw("Strict value is not equal to itself.") | |
198 | 184 | } | |
199 | 185 | ||
200 | 186 | ||
187 | + | ||
188 | + | @Callable(i) | |
189 | + | func migrate (_assetId) = { | |
190 | + | let _amount = balanceOf(_assetId) | |
191 | + | if (if (if (!(initialized())) | |
192 | + | then true | |
193 | + | else (i.caller != adminAddress())) | |
194 | + | then true | |
195 | + | else !(paused())) | |
196 | + | then throw("Invalid migrate params (manager)") | |
197 | + | else { | |
198 | + | let unstake = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [_assetId, _amount], nil) | |
199 | + | if ((unstake == unstake)) | |
200 | + | then { | |
201 | + | let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(fromBase58String(_assetId), _amount)]) | |
202 | + | if ((stake == stake)) | |
203 | + | then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")] | |
204 | + | else throw("Strict value is not equal to itself.") | |
205 | + | } | |
206 | + | else throw("Strict value is not equal to itself.") | |
207 | + | } | |
208 | + | } | |
209 | + | ||
210 | + | ||
201 | 211 | @Verifier(tx) | |
202 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey()) | |
212 | + | func verify () = { | |
213 | + | let coordinatorStr = getString(this, k_coordinatorAddress) | |
214 | + | if (isDefined(coordinatorStr)) | |
215 | + | then { | |
216 | + | let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address) | |
217 | + | if (isDefined(admin)) | |
218 | + | then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false) | |
219 | + | else throw("unable to verify: admin not set in coordinator") | |
220 | + | } | |
221 | + | else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
222 | + | } | |
203 | 223 |
github/deemru/w8io/169f3d6 57.21 ms ◑