tx · 7eATv3DdzwKPGQCPwjr5hXTrmbSk3t8K896mUCqNNqiJ 3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1: -0.03700000 Waves 2022.11.25 19:32 [2332867] smart account 3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1 > SELF 0.00000000 Waves
{ "type": 13, "id": "7eATv3DdzwKPGQCPwjr5hXTrmbSk3t8K896mUCqNNqiJ", "fee": 3700000, "feeAssetId": null, "timestamp": 1669394009185, "version": 2, "chainId": 84, "sender": "3N6DSGKkzQthvo3S2Ru8MEKNkTVqB2XFMV1", "senderPublicKey": "CTp72rvnrsKt4McoAfMqWvCXKfQQyvcrLiM1ff8k77cK", "proofs": [ "CX6qcky26iMBNPuJfeGoPhouodLxfMmHL2M9gEU1KpPvRacjGpoqUb3BeYfzKB25uv4WVmQZJGAcbCANDF8HdwJ" ], "script": "base64:BgIiCAISBgoECAgICBIECgIICBIECgIIARIAEgMKAQgSAwoBCB0AB2tfZnVuZHMCB2tfZnVuZHMAD2tfdmlyZXNfYWRkcmVzcwIPa192aXJlc19hZGRyZXNzAA1rX3ZpcmVzX3ZhdWx0Ag1rX3ZpcmVzX3ZhdWx0ABZrX2Fzc2V0X2NsYWltZWRfcHJvZml0AhZrX2Fzc2V0X2NsYWltZWRfcHJvZml0ABRrX2Nvb3JkaW5hdG9yQWRkcmVzcwIUa19jb29yZGluYXRvckFkZHJlc3MAE2tfaW5zdXJhbmNlX2FkZHJlc3MCE2tfaW5zdXJhbmNlX2FkZHJlc3MAD2tfdmF1bHRfYWRkcmVzcwIPa192YXVsdF9hZGRyZXNzAAVrX2FtbQIFa19hbW0AD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzABJrX2FkbWluX3B1YmxpY19rZXkCEmtfYWRtaW5fcHVibGljX2tleQANa19xdW90ZV9hc3NldAINa19xdW90ZV9hc3NldAAPa19xdW90ZV9zdGFraW5nAg9rX3F1b3RlX3N0YWtpbmcAEWtfc3Rha2luZ19hZGRyZXNzAhFrX3N0YWtpbmdfYWRkcmVzcwANa19pbml0aWFsaXplZAINa19pbml0aWFsaXplZAEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEJYmFsYW5jZU9mAQhfYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAAAAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwITQ29vcmRpbmF0b3Igbm90IHNldAEQaW5zdXJhbmNlQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABRNrX2luc3VyYW5jZV9hZGRyZXNzAhFJbnN1cmFuY2Ugbm90IHNldAEMdmF1bHRBZGRyZXNzAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARFAZXh0ck5hdGl2ZSgxMDUzKQIJAQtjb29yZGluYXRvcgAFD2tfdmF1bHRfYWRkcmVzcwINVmF1bHQgbm90IHNldAEFaXNBbW0BCF9hZGRyZXNzCQELdmFsdWVPckVsc2UCCQCbCAIJAQtjb29yZGluYXRvcgAJAQ50b0NvbXBvc2l0ZUtleQIFBWtfYW1tBQhfYWRkcmVzcwcBC2luaXRpYWxpemVkAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQ1rX2luaXRpYWxpemVkBwEMYWRtaW5BZGRyZXNzAAkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABQ9rX2FkbWluX2FkZHJlc3MBDmFkbWluUHVibGljS2V5AAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCCQELY29vcmRpbmF0b3IABRJrX2FkbWluX3B1YmxpY19rZXkBCnF1b3RlQXNzZXQACQDZBAEJARFAZXh0ck5hdGl2ZSgxMDUzKQIJAQtjb29yZGluYXRvcgAFDWtfcXVvdGVfYXNzZXQBDnN0YWtpbmdBZGRyZXNzAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARFAZXh0ck5hdGl2ZSgxMDUzKQIJAQtjb29yZGluYXRvcgAFEWtfc3Rha2luZ19hZGRyZXNzAg9TdGFraW5nIG5vdCBzZXQBDHZpcmVzQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQ9rX3ZpcmVzX2FkZHJlc3MCDVZpcmVzIG5vdCBzZXQBCnZpcmVzVmF1bHQBCF9hc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFDWtfdmlyZXNfdmF1bHQFCF9hc3NldElkCQCsAgICE05vIHZhdWx0IGZvciB0b2tlbiAFCF9hc3NldElkCQCsAgICGkludmFsaWQgYWRkcmVzcyBmb3IgdG9rZW4gBQhfYXNzZXRJZAELaXNXaGl0ZWxpc3QBCF9hZGRyZXNzAwMDCQEFaXNBbW0BBQhfYWRkcmVzcwYJAAACBQhfYWRkcmVzcwkApQgBCQEQaW5zdXJhbmNlQWRkcmVzcwAGCQAAAgUIX2FkZHJlc3MJAKUIAQkBDnN0YWtpbmdBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQEMdmF1bHRBZGRyZXNzAAELdXBkYXRlRnVuZHMCCF9hc3NldElkBl92YWx1ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUHa19mdW5kcwUIX2Fzc2V0SWQFBl92YWx1ZQUDbmlsBgFpAQppbml0aWFsaXplBAxfY29vcmRpbmF0b3INX3ZpcmVzQWRkcmVzcw1fcXVvdGVBc3NldElkEF9xdW90ZUFzc2V0VmF1bHQDCQELaW5pdGlhbGl6ZWQACQACAQITQWxyZWFkeSBpbml0aWFsaXplZAkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwUMX2Nvb3JkaW5hdG9yCQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tfdmlyZXNfYWRkcmVzcwUNX3ZpcmVzQWRkcmVzcwkAzAgCCQELU3RyaW5nRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQ1rX3ZpcmVzX3ZhdWx0BQ1fcXVvdGVBc3NldElkBRBfcXVvdGVBc3NldFZhdWx0CQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBDWFkZFRva2VuVmF1bHQCCF9hc3NldElkDV92YXVsdEFkZHJlc3MDAwkBASEBCQELaW5pdGlhbGl6ZWQABgkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECHEludmFsaWQgYWRkVG9rZW5WYXVsdCBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUNa192aXJlc192YXVsdAUIX2Fzc2V0SWQFDV92YXVsdEFkZHJlc3MFA25pbAFpAQh3aXRoZHJhdwIIX2Fzc2V0SWQHX2Ftb3VudAMDAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgYJAQEhAQkBC2luaXRpYWxpemVkAAYJAGYCBQdfYW1vdW50CQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQJAAIBCQCsAgIJAKwCAgkArAICAiJJbnZhbGlkIHdpdGhkcmF3IHBhcmFtcyAobWFuYWdlcikgCQCkAwEFB19hbW91bnQCAyA+IAkApAMBCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQEB3Vuc3Rha2UJAPwHBAkBDHZpcmVzQWRkcmVzcwACCHdpdGhkcmF3CQDMCAIFCF9hc3NldElkCQDMCAIFB19hbW91bnQFA25pbAUDbmlsAwkAAAIFB3Vuc3Rha2UFB3Vuc3Rha2UEE2N1cnJlbnRBc3NldEJhbGFuY2UJAGUCCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQFB19hbW91bnQJAM4IAgkBC3VwZGF0ZUZ1bmRzAgUIX2Fzc2V0SWQFE2N1cnJlbnRBc3NldEJhbGFuY2UJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQdfYW1vdW50CQDZBAEFCF9hc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEHZGVwb3NpdAAEB19hbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BAhfYXNzZXRJZAkA2AQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAIKTm8gYXNzZXRJZAMDAwkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkCQEKcXVvdGVBc3NldAAGCQEBIQEJAQtpbml0aWFsaXplZAAGAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAcJAAIBAiBJbnZhbGlkIGRlcG9zaXQgcGFyYW1zIChtYW5hZ2VyKQQFdmF1bHQJAQp2aXJlc1ZhdWx0AQUIX2Fzc2V0SWQEBXN0YWtlCQD8BwQJAQx2aXJlc0FkZHJlc3MAAgdkZXBvc2l0CQDMCAIJAKUIAQUFdmF1bHQJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQdfYW1vdW50BQNuaWwDCQAAAgUFc3Rha2UFBXN0YWtlBBNjdXJyZW50QXNzZXRCYWxhbmNlCQBkAgkBCWJhbGFuY2VPZgEFCF9hc3NldElkBQdfYW1vdW50CQELdXBkYXRlRnVuZHMCBQhfYXNzZXRJZAUTY3VycmVudEFzc2V0QmFsYW5jZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQtjbGFpbVByb2ZpdAEIX2Fzc2V0SWQDAwMJAQIhPQIJANkEAQUIX2Fzc2V0SWQJAQpxdW90ZUFzc2V0AAYJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhpJbnZhbGlkIGNsYWltUHJvZml0IHBhcmFtcwQNY3VycmVudEFtb3VudAkA/AcECQEKdmlyZXNWYXVsdAEFCF9hc3NldElkAhBnZXRDdXJyZW50VG90YWxzCQDMCAIJAKUIAQUEdGhpcwUDbmlsBQNuaWwDCQAAAgUNY3VycmVudEFtb3VudAUNY3VycmVudEFtb3VudAQTY3VycmVudEFzc2V0QmFsYW5jZQQHJG1hdGNoMAUNY3VycmVudEFtb3VudAMJAAECBQckbWF0Y2gwAhQoSW50LCBJbnQsIEludCwgSW50KQQBdAUHJG1hdGNoMAgFAXQCXzMJAAIBAhpJbnZhbGlkIGN1cnJlbnRBbW91bnQgdHlwZQQGcHJvZml0CQBlAgUTY3VycmVudEFzc2V0QmFsYW5jZQkBCWJhbGFuY2VPZgEFCF9hc3NldElkBAd1bnN0YWtlCQD8BwQJAQx2aXJlc0FkZHJlc3MAAgh3aXRoZHJhdwkAzAgCBQhfYXNzZXRJZAkAzAgCBQZwcm9maXQFA25pbAUDbmlsAwkAAAIFB3Vuc3Rha2UFB3Vuc3Rha2UJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQZwcm9maXQJANkEAQUIX2Fzc2V0SWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARB2aWV3X2NsYWltUHJvZml0AQhfYXNzZXRJZAMDCQECIT0CCQDZBAEFCF9hc3NldElkCQEKcXVvdGVBc3NldAAGCQEBIQEJAQtpbml0aWFsaXplZAAJAAIBAh9JbnZhbGlkIHZpZXdfY2xhaW1Qcm9maXQgcGFyYW1zBA1jdXJyZW50QW1vdW50CQD8BwQJAQp2aXJlc1ZhdWx0AQUIX2Fzc2V0SWQCEGdldEN1cnJlbnRUb3RhbHMJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAMJAAACBQ1jdXJyZW50QW1vdW50BQ1jdXJyZW50QW1vdW50BBNjdXJyZW50QXNzZXRCYWxhbmNlBAckbWF0Y2gwBQ1jdXJyZW50QW1vdW50AwkAAQIFByRtYXRjaDACFChJbnQsIEludCwgSW50LCBJbnQpBAF0BQckbWF0Y2gwCAUBdAJfMwkAAgECGkludmFsaWQgY3VycmVudEFtb3VudCB0eXBlBAZwcm9maXQJAGUCBRNjdXJyZW50QXNzZXRCYWxhbmNlCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKQDAQkBCWJhbGFuY2VPZgEFCF9hc3NldElkAgEsCQCkAwEFE2N1cnJlbnRBc3NldEJhbGFuY2UCASwJAKQDAQUGcHJvZml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAkBDmFkbWluUHVibGljS2V5AN/QDRw=", "height": 2332867, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Cb6x9V1ueuxqMerV5H9o2HRTzWZ2AWJTLHMv1TCAZQC1 Next: Ceoojvfoem57bXehrotTwycmnSTqVCWCrE9YBtY6y4YD Diff:
Old | New | Differences | |
---|---|---|---|
12 | 12 | let k_coordinatorAddress = "k_coordinatorAddress" | |
13 | 13 | ||
14 | 14 | let k_insurance_address = "k_insurance_address" | |
15 | + | ||
16 | + | let k_vault_address = "k_vault_address" | |
15 | 17 | ||
16 | 18 | let k_amm = "k_amm" | |
17 | 19 | ||
39 | 41 | func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set") | |
40 | 42 | ||
41 | 43 | ||
44 | + | func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set") | |
45 | + | ||
46 | + | ||
42 | 47 | func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false) | |
43 | 48 | ||
44 | 49 | ||
63 | 68 | func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId)) | |
64 | 69 | ||
65 | 70 | ||
66 | - | func isWhitelist (_address) = if (if (isAmm(_address)) | |
71 | + | func isWhitelist (_address) = if (if (if (isAmm(_address)) | |
67 | 72 | then true | |
68 | 73 | else (_address == toString(insuranceAddress()))) | |
69 | 74 | then true | |
70 | - | else (_address == toString(stakingAddress())) | |
75 | + | else (_address == toString(stakingAddress()))) | |
76 | + | then true | |
77 | + | else (_address == toString(vaultAddress())) | |
71 | 78 | ||
72 | 79 | ||
73 | 80 | func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)] | |
95 | 102 | else !(initialized())) | |
96 | 103 | then true | |
97 | 104 | else (_amount > balanceOf(_assetId))) | |
98 | - | then throw(((("Invalid withdraw params " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
105 | + | then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
99 | 106 | else { | |
100 | 107 | let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil) | |
101 | 108 | if ((unstake == unstake)) | |
119 | 126 | else if (!(isWhitelist(toString(i.caller)))) | |
120 | 127 | then (i.caller != adminAddress()) | |
121 | 128 | else false) | |
122 | - | then throw("Invalid deposit params") | |
129 | + | then throw("Invalid deposit params (manager)") | |
123 | 130 | else { | |
124 | 131 | let vault = viresVault(_assetId) | |
125 | 132 | let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)]) |
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 | 6 | let k_vires_address = "k_vires_address" | |
7 | 7 | ||
8 | 8 | let k_vires_vault = "k_vires_vault" | |
9 | 9 | ||
10 | 10 | let k_asset_claimed_profit = "k_asset_claimed_profit" | |
11 | 11 | ||
12 | 12 | let k_coordinatorAddress = "k_coordinatorAddress" | |
13 | 13 | ||
14 | 14 | let k_insurance_address = "k_insurance_address" | |
15 | + | ||
16 | + | let k_vault_address = "k_vault_address" | |
15 | 17 | ||
16 | 18 | let k_amm = "k_amm" | |
17 | 19 | ||
18 | 20 | let k_admin_address = "k_admin_address" | |
19 | 21 | ||
20 | 22 | let k_admin_public_key = "k_admin_public_key" | |
21 | 23 | ||
22 | 24 | let k_quote_asset = "k_quote_asset" | |
23 | 25 | ||
24 | 26 | let k_quote_staking = "k_quote_staking" | |
25 | 27 | ||
26 | 28 | let k_staking_address = "k_staking_address" | |
27 | 29 | ||
28 | 30 | let k_initialized = "k_initialized" | |
29 | 31 | ||
30 | 32 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
31 | 33 | ||
32 | 34 | ||
33 | 35 | func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0) | |
34 | 36 | ||
35 | 37 | ||
36 | 38 | func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set") | |
37 | 39 | ||
38 | 40 | ||
39 | 41 | func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set") | |
40 | 42 | ||
41 | 43 | ||
44 | + | func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set") | |
45 | + | ||
46 | + | ||
42 | 47 | func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false) | |
43 | 48 | ||
44 | 49 | ||
45 | 50 | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
46 | 51 | ||
47 | 52 | ||
48 | 53 | func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address)) | |
49 | 54 | ||
50 | 55 | ||
51 | 56 | func adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key)) | |
52 | 57 | ||
53 | 58 | ||
54 | 59 | func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset)) | |
55 | 60 | ||
56 | 61 | ||
57 | 62 | func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set") | |
58 | 63 | ||
59 | 64 | ||
60 | 65 | func viresAddress () = valueOrErrorMessage(addressFromString(getStringValue(this, k_vires_address)), "Vires not set") | |
61 | 66 | ||
62 | 67 | ||
63 | 68 | func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId)) | |
64 | 69 | ||
65 | 70 | ||
66 | - | func isWhitelist (_address) = if (if (isAmm(_address)) | |
71 | + | func isWhitelist (_address) = if (if (if (isAmm(_address)) | |
67 | 72 | then true | |
68 | 73 | else (_address == toString(insuranceAddress()))) | |
69 | 74 | then true | |
70 | - | else (_address == toString(stakingAddress())) | |
75 | + | else (_address == toString(stakingAddress()))) | |
76 | + | then true | |
77 | + | else (_address == toString(vaultAddress())) | |
71 | 78 | ||
72 | 79 | ||
73 | 80 | func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)] | |
74 | 81 | ||
75 | 82 | ||
76 | 83 | @Callable(i) | |
77 | 84 | func initialize (_coordinator,_viresAddress,_quoteAssetId,_quoteAssetVault) = if (initialized()) | |
78 | 85 | then throw("Already initialized") | |
79 | 86 | else [StringEntry(k_coordinatorAddress, _coordinator), StringEntry(k_vires_address, _viresAddress), StringEntry(toCompositeKey(k_vires_vault, _quoteAssetId), _quoteAssetVault), BooleanEntry(k_initialized, true)] | |
80 | 87 | ||
81 | 88 | ||
82 | 89 | ||
83 | 90 | @Callable(i) | |
84 | 91 | func addTokenVault (_assetId,_vaultAddress) = if (if (!(initialized())) | |
85 | 92 | then true | |
86 | 93 | else (i.caller != adminAddress())) | |
87 | 94 | then throw("Invalid addTokenVault params") | |
88 | 95 | else [StringEntry(toCompositeKey(k_vires_vault, _assetId), _vaultAddress)] | |
89 | 96 | ||
90 | 97 | ||
91 | 98 | ||
92 | 99 | @Callable(i) | |
93 | 100 | func withdraw (_assetId,_amount) = if (if (if (!(isWhitelist(toString(i.caller)))) | |
94 | 101 | then true | |
95 | 102 | else !(initialized())) | |
96 | 103 | then true | |
97 | 104 | else (_amount > balanceOf(_assetId))) | |
98 | - | then throw(((("Invalid withdraw params " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
105 | + | then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId)))) | |
99 | 106 | else { | |
100 | 107 | let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil) | |
101 | 108 | if ((unstake == unstake)) | |
102 | 109 | then { | |
103 | 110 | let currentAssetBalance = (balanceOf(_assetId) - _amount) | |
104 | 111 | (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))]) | |
105 | 112 | } | |
106 | 113 | else throw("Strict value is not equal to itself.") | |
107 | 114 | } | |
108 | 115 | ||
109 | 116 | ||
110 | 117 | ||
111 | 118 | @Callable(i) | |
112 | 119 | func deposit () = { | |
113 | 120 | let _amount = i.payments[0].amount | |
114 | 121 | let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId")) | |
115 | 122 | if (if (if ((i.payments[0].assetId != quoteAsset())) | |
116 | 123 | then true | |
117 | 124 | else !(initialized())) | |
118 | 125 | then true | |
119 | 126 | else if (!(isWhitelist(toString(i.caller)))) | |
120 | 127 | then (i.caller != adminAddress()) | |
121 | 128 | else false) | |
122 | - | then throw("Invalid deposit params") | |
129 | + | then throw("Invalid deposit params (manager)") | |
123 | 130 | else { | |
124 | 131 | let vault = viresVault(_assetId) | |
125 | 132 | let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)]) | |
126 | 133 | if ((stake == stake)) | |
127 | 134 | then { | |
128 | 135 | let currentAssetBalance = (balanceOf(_assetId) + _amount) | |
129 | 136 | updateFunds(_assetId, currentAssetBalance) | |
130 | 137 | } | |
131 | 138 | else throw("Strict value is not equal to itself.") | |
132 | 139 | } | |
133 | 140 | } | |
134 | 141 | ||
135 | 142 | ||
136 | 143 | ||
137 | 144 | @Callable(i) | |
138 | 145 | func claimProfit (_assetId) = if (if (if ((fromBase58String(_assetId) != quoteAsset())) | |
139 | 146 | then true | |
140 | 147 | else !(initialized())) | |
141 | 148 | then true | |
142 | 149 | else (i.caller != adminAddress())) | |
143 | 150 | then throw("Invalid claimProfit params") | |
144 | 151 | else { | |
145 | 152 | let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil) | |
146 | 153 | if ((currentAmount == currentAmount)) | |
147 | 154 | then { | |
148 | 155 | let currentAssetBalance = match currentAmount { | |
149 | 156 | case t: (Int, Int, Int, Int) => | |
150 | 157 | t._3 | |
151 | 158 | case _ => | |
152 | 159 | throw("Invalid currentAmount type") | |
153 | 160 | } | |
154 | 161 | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
155 | 162 | let unstake = invoke(viresAddress(), "withdraw", [_assetId, profit], nil) | |
156 | 163 | if ((unstake == unstake)) | |
157 | 164 | then [ScriptTransfer(i.caller, profit, fromBase58String(_assetId))] | |
158 | 165 | else throw("Strict value is not equal to itself.") | |
159 | 166 | } | |
160 | 167 | else throw("Strict value is not equal to itself.") | |
161 | 168 | } | |
162 | 169 | ||
163 | 170 | ||
164 | 171 | ||
165 | 172 | @Callable(i) | |
166 | 173 | func view_claimProfit (_assetId) = if (if ((fromBase58String(_assetId) != quoteAsset())) | |
167 | 174 | then true | |
168 | 175 | else !(initialized())) | |
169 | 176 | then throw("Invalid view_claimProfit params") | |
170 | 177 | else { | |
171 | 178 | let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil) | |
172 | 179 | if ((currentAmount == currentAmount)) | |
173 | 180 | then { | |
174 | 181 | let currentAssetBalance = match currentAmount { | |
175 | 182 | case t: (Int, Int, Int, Int) => | |
176 | 183 | t._3 | |
177 | 184 | case _ => | |
178 | 185 | throw("Invalid currentAmount type") | |
179 | 186 | } | |
180 | 187 | let profit = (currentAssetBalance - balanceOf(_assetId)) | |
181 | 188 | throw(((((toString(balanceOf(_assetId)) + ",") + toString(currentAssetBalance)) + ",") + toString(profit))) | |
182 | 189 | } | |
183 | 190 | else throw("Strict value is not equal to itself.") | |
184 | 191 | } | |
185 | 192 | ||
186 | 193 | ||
187 | 194 | @Verifier(tx) | |
188 | 195 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey()) | |
189 | 196 |
github/deemru/w8io/873ac7e 33.58 ms ◑![]()