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:
OldNewDifferences
33 {-# CONTENT_TYPE DAPP #-}
44 let k_funds = "k_funds"
55
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"
117
128 let k_coordinatorAddress = "k_coordinatorAddress"
13-
14-let k_insurance_address = "k_insurance_address"
159
1610 let k_orders_address = "k_orders_address"
1711
2115
2216 let k_admin_address = "k_admin_address"
2317
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-
3018 let k_staking_address = "k_staking_address"
3119
3220 let k_initialized = "k_initialized"
21+
22+let k_paused = "k_paused"
3323
3424 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
3525
3727 func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0)
3828
3929
40-func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set")
30+func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid")
4131
4232
43-func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set")
33+func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
4434
4535
46-func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
36+func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid")
4737
4838
49-func ordersAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_orders_address)), "Orders not set")
39+func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
5040
5141
52-func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false)
42+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
5343
5444
5545 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
5646
5747
58-func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address))
48+func paused () = valueOrElse(getBoolean(this, k_paused), false)
5949
6050
61-func adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key))
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))
6252
6353
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())))
8155 then true
8256 else (_address == toString(vaultAddress())))
8357 then true
8862
8963
9064 @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)]
9470
9571
9672
9773 @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)]
10377
10478
10579
10680 @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))))
108100 then true
109101 else !(initialized()))
102+ then true
103+ else paused())
110104 then true
111105 else (_amount > balanceOf(_assetId)))
112106 then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId))))
113107 else {
114- let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil)
108+ let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil)
115109 if ((unstake == unstake))
116110 then {
117111 let currentAssetBalance = (balanceOf(_assetId) - _amount)
126120 func deposit () = {
127121 let _amount = i.payments[0].amount
128122 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()))
132124 then true
133125 else if (!(isWhitelist(toString(i.caller))))
134126 then (i.caller != adminAddress())
135127 else false)
128+ then true
129+ else paused())
130+ then true
131+ else (size(i.payments) != 1))
136132 then throw("Invalid deposit params (manager)")
137133 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)])
140135 if ((stake == stake))
141136 then {
142137 let currentAssetBalance = (balanceOf(_assetId) + _amount)
149144
150145
151146 @Callable(i)
152-func claimProfit (_assetId) = if (if (if ((fromBase58String(_assetId) != quoteAsset()))
147+func claimProfit (_assetId) = if (if (!(initialized()))
153148 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)")
158151 else {
159- let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
160- if ((currentAmount == currentAmount))
152+ let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
153+ if ((doClaimProfitResult == doClaimProfitResult))
161154 then {
162- let currentAssetBalance = match currentAmount {
163- case t: (Int, Int, Int, Int) =>
164- t._3
155+ let profit = match doClaimProfitResult {
156+ case t: Int =>
157+ t
165158 case _ =>
166- throw("Invalid currentAmount type")
159+ throw("Invalid claimProfit result type")
167160 }
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)
173162 }
174163 else throw("Strict value is not equal to itself.")
175164 }
177166
178167
179168 @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)")
184171 else {
185- let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
186- if ((currentAmount == currentAmount))
172+ let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
173+ if ((doClaimProfitResult == doClaimProfitResult))
187174 then {
188- let currentAssetBalance = match currentAmount {
189- case t: (Int, Int, Int, Int) =>
190- t._3
175+ let profit = match doClaimProfitResult {
176+ case t: Int =>
177+ t
191178 case _ =>
192- throw("Invalid currentAmount type")
179+ throw("Invalid claimProfit result type")
193180 }
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)))
196182 }
197183 else throw("Strict value is not equal to itself.")
198184 }
199185
200186
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+
201211 @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+ }
203223
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let k_funds = "k_funds"
55
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"
117
128 let k_coordinatorAddress = "k_coordinatorAddress"
13-
14-let k_insurance_address = "k_insurance_address"
159
1610 let k_orders_address = "k_orders_address"
1711
1812 let k_vault_address = "k_vault_address"
1913
2014 let k_amm = "k_amm"
2115
2216 let k_admin_address = "k_admin_address"
2317
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-
3018 let k_staking_address = "k_staking_address"
3119
3220 let k_initialized = "k_initialized"
21+
22+let k_paused = "k_paused"
3323
3424 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
3525
3626
3727 func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0)
3828
3929
40-func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set")
30+func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid")
4131
4232
43-func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set")
33+func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
4434
4535
46-func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
36+func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid")
4737
4838
49-func ordersAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_orders_address)), "Orders not set")
39+func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
5040
5141
52-func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false)
42+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
5343
5444
5545 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
5646
5747
58-func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address))
48+func paused () = valueOrElse(getBoolean(this, k_paused), false)
5949
6050
61-func adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key))
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))
6252
6353
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())))
8155 then true
8256 else (_address == toString(vaultAddress())))
8357 then true
8458 else (_address == toString(ordersAddress()))
8559
8660
8761 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
8862
8963
9064 @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)]
9470
9571
9672
9773 @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)]
10377
10478
10579
10680 @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))))
108100 then true
109101 else !(initialized()))
102+ then true
103+ else paused())
110104 then true
111105 else (_amount > balanceOf(_assetId)))
112106 then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId))))
113107 else {
114- let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil)
108+ let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil)
115109 if ((unstake == unstake))
116110 then {
117111 let currentAssetBalance = (balanceOf(_assetId) - _amount)
118112 (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))])
119113 }
120114 else throw("Strict value is not equal to itself.")
121115 }
122116
123117
124118
125119 @Callable(i)
126120 func deposit () = {
127121 let _amount = i.payments[0].amount
128122 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()))
132124 then true
133125 else if (!(isWhitelist(toString(i.caller))))
134126 then (i.caller != adminAddress())
135127 else false)
128+ then true
129+ else paused())
130+ then true
131+ else (size(i.payments) != 1))
136132 then throw("Invalid deposit params (manager)")
137133 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)])
140135 if ((stake == stake))
141136 then {
142137 let currentAssetBalance = (balanceOf(_assetId) + _amount)
143138 updateFunds(_assetId, currentAssetBalance)
144139 }
145140 else throw("Strict value is not equal to itself.")
146141 }
147142 }
148143
149144
150145
151146 @Callable(i)
152-func claimProfit (_assetId) = if (if (if ((fromBase58String(_assetId) != quoteAsset()))
147+func claimProfit (_assetId) = if (if (!(initialized()))
153148 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)")
158151 else {
159- let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
160- if ((currentAmount == currentAmount))
152+ let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
153+ if ((doClaimProfitResult == doClaimProfitResult))
161154 then {
162- let currentAssetBalance = match currentAmount {
163- case t: (Int, Int, Int, Int) =>
164- t._3
155+ let profit = match doClaimProfitResult {
156+ case t: Int =>
157+ t
165158 case _ =>
166- throw("Invalid currentAmount type")
159+ throw("Invalid claimProfit result type")
167160 }
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)
173162 }
174163 else throw("Strict value is not equal to itself.")
175164 }
176165
177166
178167
179168 @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)")
184171 else {
185- let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
186- if ((currentAmount == currentAmount))
172+ let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
173+ if ((doClaimProfitResult == doClaimProfitResult))
187174 then {
188- let currentAssetBalance = match currentAmount {
189- case t: (Int, Int, Int, Int) =>
190- t._3
175+ let profit = match doClaimProfitResult {
176+ case t: Int =>
177+ t
191178 case _ =>
192- throw("Invalid currentAmount type")
179+ throw("Invalid claimProfit result type")
193180 }
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)))
196182 }
197183 else throw("Strict value is not equal to itself.")
198184 }
199185
200186
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+
201211 @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+ }
203223

github/deemru/w8io/169f3d6 
57.21 ms