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:
OldNewDifferences
1212 let k_coordinatorAddress = "k_coordinatorAddress"
1313
1414 let k_insurance_address = "k_insurance_address"
15+
16+let k_vault_address = "k_vault_address"
1517
1618 let k_amm = "k_amm"
1719
3941 func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set")
4042
4143
44+func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
45+
46+
4247 func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false)
4348
4449
6368 func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId))
6469
6570
66-func isWhitelist (_address) = if (if (isAmm(_address))
71+func isWhitelist (_address) = if (if (if (isAmm(_address))
6772 then true
6873 else (_address == toString(insuranceAddress())))
6974 then true
70- else (_address == toString(stakingAddress()))
75+ else (_address == toString(stakingAddress())))
76+ then true
77+ else (_address == toString(vaultAddress()))
7178
7279
7380 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
95102 else !(initialized()))
96103 then true
97104 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))))
99106 else {
100107 let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil)
101108 if ((unstake == unstake))
119126 else if (!(isWhitelist(toString(i.caller))))
120127 then (i.caller != adminAddress())
121128 else false)
122- then throw("Invalid deposit params")
129+ then throw("Invalid deposit params (manager)")
123130 else {
124131 let vault = viresVault(_assetId)
125132 let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)])
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let k_funds = "k_funds"
55
66 let k_vires_address = "k_vires_address"
77
88 let k_vires_vault = "k_vires_vault"
99
1010 let k_asset_claimed_profit = "k_asset_claimed_profit"
1111
1212 let k_coordinatorAddress = "k_coordinatorAddress"
1313
1414 let k_insurance_address = "k_insurance_address"
15+
16+let k_vault_address = "k_vault_address"
1517
1618 let k_amm = "k_amm"
1719
1820 let k_admin_address = "k_admin_address"
1921
2022 let k_admin_public_key = "k_admin_public_key"
2123
2224 let k_quote_asset = "k_quote_asset"
2325
2426 let k_quote_staking = "k_quote_staking"
2527
2628 let k_staking_address = "k_staking_address"
2729
2830 let k_initialized = "k_initialized"
2931
3032 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
3133
3234
3335 func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0)
3436
3537
3638 func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set")
3739
3840
3941 func insuranceAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_insurance_address)), "Insurance not set")
4042
4143
44+func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
45+
46+
4247 func isAmm (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false)
4348
4449
4550 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
4651
4752
4853 func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address))
4954
5055
5156 func adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key))
5257
5358
5459 func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset))
5560
5661
5762 func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set")
5863
5964
6065 func viresAddress () = valueOrErrorMessage(addressFromString(getStringValue(this, k_vires_address)), "Vires not set")
6166
6267
6368 func viresVault (_assetId) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, toCompositeKey(k_vires_vault, _assetId)), ("No vault for token " + _assetId))), ("Invalid address for token " + _assetId))
6469
6570
66-func isWhitelist (_address) = if (if (isAmm(_address))
71+func isWhitelist (_address) = if (if (if (isAmm(_address))
6772 then true
6873 else (_address == toString(insuranceAddress())))
6974 then true
70- else (_address == toString(stakingAddress()))
75+ else (_address == toString(stakingAddress())))
76+ then true
77+ else (_address == toString(vaultAddress()))
7178
7279
7380 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
7481
7582
7683 @Callable(i)
7784 func initialize (_coordinator,_viresAddress,_quoteAssetId,_quoteAssetVault) = if (initialized())
7885 then throw("Already initialized")
7986 else [StringEntry(k_coordinatorAddress, _coordinator), StringEntry(k_vires_address, _viresAddress), StringEntry(toCompositeKey(k_vires_vault, _quoteAssetId), _quoteAssetVault), BooleanEntry(k_initialized, true)]
8087
8188
8289
8390 @Callable(i)
8491 func addTokenVault (_assetId,_vaultAddress) = if (if (!(initialized()))
8592 then true
8693 else (i.caller != adminAddress()))
8794 then throw("Invalid addTokenVault params")
8895 else [StringEntry(toCompositeKey(k_vires_vault, _assetId), _vaultAddress)]
8996
9097
9198
9299 @Callable(i)
93100 func withdraw (_assetId,_amount) = if (if (if (!(isWhitelist(toString(i.caller))))
94101 then true
95102 else !(initialized()))
96103 then true
97104 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))))
99106 else {
100107 let unstake = invoke(viresAddress(), "withdraw", [_assetId, _amount], nil)
101108 if ((unstake == unstake))
102109 then {
103110 let currentAssetBalance = (balanceOf(_assetId) - _amount)
104111 (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))])
105112 }
106113 else throw("Strict value is not equal to itself.")
107114 }
108115
109116
110117
111118 @Callable(i)
112119 func deposit () = {
113120 let _amount = i.payments[0].amount
114121 let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId"))
115122 if (if (if ((i.payments[0].assetId != quoteAsset()))
116123 then true
117124 else !(initialized()))
118125 then true
119126 else if (!(isWhitelist(toString(i.caller))))
120127 then (i.caller != adminAddress())
121128 else false)
122- then throw("Invalid deposit params")
129+ then throw("Invalid deposit params (manager)")
123130 else {
124131 let vault = viresVault(_assetId)
125132 let stake = invoke(viresAddress(), "deposit", [toString(vault), false], [AttachedPayment(i.payments[0].assetId, _amount)])
126133 if ((stake == stake))
127134 then {
128135 let currentAssetBalance = (balanceOf(_assetId) + _amount)
129136 updateFunds(_assetId, currentAssetBalance)
130137 }
131138 else throw("Strict value is not equal to itself.")
132139 }
133140 }
134141
135142
136143
137144 @Callable(i)
138145 func claimProfit (_assetId) = if (if (if ((fromBase58String(_assetId) != quoteAsset()))
139146 then true
140147 else !(initialized()))
141148 then true
142149 else (i.caller != adminAddress()))
143150 then throw("Invalid claimProfit params")
144151 else {
145152 let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
146153 if ((currentAmount == currentAmount))
147154 then {
148155 let currentAssetBalance = match currentAmount {
149156 case t: (Int, Int, Int, Int) =>
150157 t._3
151158 case _ =>
152159 throw("Invalid currentAmount type")
153160 }
154161 let profit = (currentAssetBalance - balanceOf(_assetId))
155162 let unstake = invoke(viresAddress(), "withdraw", [_assetId, profit], nil)
156163 if ((unstake == unstake))
157164 then [ScriptTransfer(i.caller, profit, fromBase58String(_assetId))]
158165 else throw("Strict value is not equal to itself.")
159166 }
160167 else throw("Strict value is not equal to itself.")
161168 }
162169
163170
164171
165172 @Callable(i)
166173 func view_claimProfit (_assetId) = if (if ((fromBase58String(_assetId) != quoteAsset()))
167174 then true
168175 else !(initialized()))
169176 then throw("Invalid view_claimProfit params")
170177 else {
171178 let currentAmount = invoke(viresVault(_assetId), "getCurrentTotals", [toString(this)], nil)
172179 if ((currentAmount == currentAmount))
173180 then {
174181 let currentAssetBalance = match currentAmount {
175182 case t: (Int, Int, Int, Int) =>
176183 t._3
177184 case _ =>
178185 throw("Invalid currentAmount type")
179186 }
180187 let profit = (currentAssetBalance - balanceOf(_assetId))
181188 throw(((((toString(balanceOf(_assetId)) + ",") + toString(currentAssetBalance)) + ",") + toString(profit)))
182189 }
183190 else throw("Strict value is not equal to itself.")
184191 }
185192
186193
187194 @Verifier(tx)
188195 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey())
189196

github/deemru/w8io/873ac7e 
33.58 ms