tx · iBsmVkuxC6T9pSjW4Q18jLYxsNPEGyPT5vnasyVTxT9

3MtbzcFZjxhPwaM1HoYr7sSSGDk7bjBsRNN:  -0.03700000 Waves

2023.05.15 15:51 [2579098] smart account 3MtbzcFZjxhPwaM1HoYr7sSSGDk7bjBsRNN > SELF 0.00000000 Waves

{ "type": 13, "id": "iBsmVkuxC6T9pSjW4Q18jLYxsNPEGyPT5vnasyVTxT9", "fee": 3700000, "feeAssetId": null, "timestamp": 1684155155360, "version": 2, "chainId": 84, "sender": "3MtbzcFZjxhPwaM1HoYr7sSSGDk7bjBsRNN", "senderPublicKey": "269hMEydX4R6CjK9TRgFMec4TtjsckD91Vxo2pzLVzv4", "proofs": [ "5UoLaZyMAyxKb1PTB5VdaPztGQGYg1np18R5fYn5ncGnG1UTBANZpGJJHns3ZM3brFHuKZP8dUZZNnKkRRZZawN5" ], "script": "base64:BgIlCAISBQoDCAgIEgASABIECgIICBIECgIIARIAEgMKAQgSAwoBCBsAB2tfZnVuZHMCB2tfZnVuZHMAF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzAhdrX2Fzc2V0X21hbmFnZXJfYWRkcmVzcwAUa19jb29yZGluYXRvckFkZHJlc3MCFGtfY29vcmRpbmF0b3JBZGRyZXNzABBrX29yZGVyc19hZGRyZXNzAhBrX29yZGVyc19hZGRyZXNzAA9rX3ZhdWx0X2FkZHJlc3MCD2tfdmF1bHRfYWRkcmVzcwAFa19hbW0CBWtfYW1tAA9rX2FkbWluX2FkZHJlc3MCD2tfYWRtaW5fYWRkcmVzcwARa19zdGFraW5nX2FkZHJlc3MCEWtfc3Rha2luZ19hZGRyZXNzAA5rX3Nwb3RfYWRkcmVzcwIOa19zcG90X2FkZHJlc3MAB2tfdmF1bHQCB2tfdmF1bHQADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQACGtfcGF1c2VkAghrX3BhdXNlZAEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEJYmFsYW5jZU9mAQhfYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAAAAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCG0Nvb3JkaW5hdG9yIG5vdCBzZXQgTWFuYWdlcgIbQ29vcmRpbmF0b3IgYWRkcmVzcyBpbnZhbGlkAQx2YXVsdEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfdmF1bHRfYWRkcmVzcwIVVmF1bHQgYWRkcmVzcyBub3Qgc2V0AhVWYXVsdCBhZGRyZXNzIGludmFsaWQBDW9yZGVyc0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEGtfb3JkZXJzX2FkZHJlc3MCFk9yZGVycyBhZGRyZXNzIG5vdCBzZXQCFk9yZGVycyBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAELc3BvdEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFDmtfc3BvdF9hZGRyZXNzAhRTcG90IGFkZHJlc3Mgbm90IHNldAIUU3BvdCBhZGRyZXNzIGludmFsaWQBC2luaXRpYWxpemVkAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQ1rX2luaXRpYWxpemVkBwEGcGF1c2VkAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQhrX3BhdXNlZAcBE2Fzc2V0TWFuYWdlckFkZHJlc3MBCF9hc3NldElkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAQ50b0NvbXBvc2l0ZUtleQIFF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzBQhfYXNzZXRJZAkArAICAhtObyBhc3NldCBtYW5hZ2VyIGZvciB0b2tlbiAFCF9hc3NldElkCQCsAgICKEludmFsaWQgYXNzZXQgbWFuYWdlciBhZGRyZXNzIGZvciB0b2tlbiAFCF9hc3NldElkAQtpc1Nwb3RWYXVsdAEIX2FkZHJlc3MEBHNwb3QJAQtzcG90QWRkcmVzcwAJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEc3BvdAkBDnRvQ29tcG9zaXRlS2V5AgUHa192YXVsdAUIX2FkZHJlc3MHAQtpc1doaXRlbGlzdAEIX2FkZHJlc3MDAwkAAAIFCF9hZGRyZXNzCQClCAEJAQ5zdGFraW5nQWRkcmVzcwAGCQAAAgUIX2FkZHJlc3MJAKUIAQkBDHZhdWx0QWRkcmVzcwAGCQAAAgUIX2FkZHJlc3MJAKUIAQkBDW9yZGVyc0FkZHJlc3MAAQt1cGRhdGVGdW5kcwIIX2Fzc2V0SWQGX3ZhbHVlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAUGX3ZhbHVlBQNuaWwBCnN0ckFzc2V0SWQBBl9hc3NldAMJAQlpc0RlZmluZWQBBQZfYXNzZXQJANgEAQkBBXZhbHVlAQUGX2Fzc2V0AgVXQVZFUwgBaQEKaW5pdGlhbGl6ZQMMX2Nvb3JkaW5hdG9yDV9xdW90ZUFzc2V0SWQSX3F1b3RlQXNzZXRNYW5hZ2VyAwMJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhRVbmFibGUgdG8gaW5pdGlhbGl6ZQkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwkApQgBCQERQGV4dHJOYXRpdmUoMTA2MikBBQxfY29vcmRpbmF0b3IJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFDV9xdW90ZUFzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUSX3F1b3RlQXNzZXRNYW5hZ2VyCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBB3VucGF1c2UAAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECFkludmFsaWQgdW5wYXVzZSBwYXJhbXMJAMwIAgkBDEJvb2xlYW5FbnRyeQIFCGtfcGF1c2VkBwUDbmlsAWkBBXBhdXNlAAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhRJbnZhbGlkIHBhdXNlIHBhcmFtcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUIa19wYXVzZWQGBQNuaWwBaQEPYWRkQXNzZXRNYW5hZ2VyAghfYXNzZXRJZA1fdmF1bHRBZGRyZXNzAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MABgMJAQlpc0RlZmluZWQBCQCiCAEJAQ50b0NvbXBvc2l0ZUtleQIFF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzBQhfYXNzZXRJZAkAZgIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAAABwkAAgECHEludmFsaWQgYWRkVG9rZW5WYXVsdCBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQClCAEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDV92YXVsdEFkZHJlc3MFA25pbAFpAQh3aXRoZHJhdwIIX2Fzc2V0SWQHX2Ftb3VudAMDAwMJAQEhAQkBC2lzV2hpdGVsaXN0AQkApQgBCAUBaQZjYWxsZXIGCQEBIQEJAQtpbml0aWFsaXplZAAGCQEGcGF1c2VkAAYJAGYCBQdfYW1vdW50CQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQJAAIBCQCsAgIJAKwCAgkArAICAiJJbnZhbGlkIHdpdGhkcmF3IHBhcmFtcyAobWFuYWdlcikgCQCkAwEFB19hbW91bnQCAyA+IAkApAMBCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQEB3Vuc3Rha2UJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAIId2l0aGRyYXcJAMwIAgUIX2Fzc2V0SWQJAMwIAgUHX2Ftb3VudAUDbmlsBQNuaWwDCQAAAgUHdW5zdGFrZQUHdW5zdGFrZQQTY3VycmVudEFzc2V0QmFsYW5jZQkAZQIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUHX2Ftb3VudAkAzggCCQELdXBkYXRlRnVuZHMCBQhfYXNzZXRJZAUTY3VycmVudEFzc2V0QmFsYW5jZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFB19hbW91bnQDCQAAAgUIX2Fzc2V0SWQCBVdBVkVTBQR1bml0CQDZBAEFCF9hc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEHZGVwb3NpdAAEB19hbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BAhfYXNzZXRJZAkBCnN0ckFzc2V0SWQBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQDAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGAwkBASEBCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAcGCQEGcGF1c2VkAAYJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECIEludmFsaWQgZGVwb3NpdCBwYXJhbXMgKG1hbmFnZXIpBAVzdGFrZQkA/AcECQETYXNzZXRNYW5hZ2VyQWRkcmVzcwEFCF9hc3NldElkAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUHX2Ftb3VudAUDbmlsAwkAAAIFBXN0YWtlBQVzdGFrZQQTY3VycmVudEFzc2V0QmFsYW5jZQkAZAIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUHX2Ftb3VudAkBC3VwZGF0ZUZ1bmRzAgUIX2Fzc2V0SWQFE2N1cnJlbnRBc3NldEJhbGFuY2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELY2xhaW1Qcm9maXQBCF9hc3NldElkAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgkBDHZhdWx0QWRkcmVzcwAJAAIBAiRJbnZhbGlkIGNsYWltUHJvZml0IHBhcmFtcyAobWFuYWdlcikEE2RvQ2xhaW1Qcm9maXRSZXN1bHQJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAILY2xhaW1Qcm9maXQJAMwIAgUIX2Fzc2V0SWQFA25pbAUDbmlsAwkAAAIFE2RvQ2xhaW1Qcm9maXRSZXN1bHQFE2RvQ2xhaW1Qcm9maXRSZXN1bHQEBnByb2ZpdAQHJG1hdGNoMAUTZG9DbGFpbVByb2ZpdFJlc3VsdAMJAAECBQckbWF0Y2gwAgNJbnQEAXQFByRtYXRjaDAFAXQJAAIBAh9JbnZhbGlkIGNsYWltUHJvZml0IHJlc3VsdCB0eXBlCQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQZwcm9maXQDCQAAAgUIX2Fzc2V0SWQCBVdBVkVTBQR1bml0CQDZBAEFCF9hc3NldElkBQNuaWwFBnByb2ZpdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARB2aWV3X2NsYWltUHJvZml0AQhfYXNzZXRJZAMJAQEhAQkBC2luaXRpYWxpemVkAAkAAgECKUludmFsaWQgdmlld19jbGFpbVByb2ZpdCBwYXJhbXMgKG1hbmFnZXIpBBNkb0NsYWltUHJvZml0UmVzdWx0CQD8BwQJARNhc3NldE1hbmFnZXJBZGRyZXNzAQUIX2Fzc2V0SWQCC2NsYWltUHJvZml0CQDMCAIFCF9hc3NldElkBQNuaWwFA25pbAMJAAACBRNkb0NsYWltUHJvZml0UmVzdWx0BRNkb0NsYWltUHJvZml0UmVzdWx0BAZwcm9maXQEByRtYXRjaDAFE2RvQ2xhaW1Qcm9maXRSZXN1bHQDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIfSW52YWxpZCBjbGFpbVByb2ZpdCByZXN1bHQgdHlwZQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkApAMBCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQCASwJAKQDAQkAZAIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUGcHJvZml0AgEsCQCkAwEFBnByb2ZpdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAEDmNvb3JkaW5hdG9yU3RyCQCdCAIFBHRoaXMFFGtfY29vcmRpbmF0b3JBZGRyZXNzAwkBCWlzRGVmaW5lZAEFDmNvb3JkaW5hdG9yU3RyBAVhZG1pbgkAnQgCCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBBQ5jb29yZGluYXRvclN0cgUPa19hZG1pbl9hZGRyZXNzAwkBCWlzRGVmaW5lZAEFBWFkbWluCQELdmFsdWVPckVsc2UCCQCbCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFBWFkbWluCQCsAgIJAKwCAgkArAICAgdzdGF0dXNfCQClCAEFBHRoaXMCAV8JANgEAQgFAnR4AmlkBwkAAgECLnVuYWJsZSB0byB2ZXJpZnk6IGFkbWluIG5vdCBzZXQgaW4gY29vcmRpbmF0b3IJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXnCyePe", "height": 2579098, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GKpUL4v1hktsbMJje7x7Tb5r6xuAMvaDANtsHx2PPx3A Next: An4pt343oh4z2dwrLkH8FtgWRGYUqbyxeAp845jnGHDM Diff:
OldNewDifferences
1616 let k_admin_address = "k_admin_address"
1717
1818 let k_staking_address = "k_staking_address"
19+
20+let k_spot_address = "k_spot_address"
21+
22+let k_vault = "k_vault"
1923
2024 let k_initialized = "k_initialized"
2125
4246 func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
4347
4448
49+func spotAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_spot_address), "Spot address not set")), "Spot address invalid")
50+
51+
4552 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
4653
4754
4956
5057
5158 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))
59+
60+
61+func isSpotVault (_address) = {
62+ let spot = spotAddress()
63+ valueOrElse(getBoolean(spot, toCompositeKey(k_vault, _address)), false)
64+ }
5265
5366
5467 func isWhitelist (_address) = if (if ((_address == toString(stakingAddress())))
5972
6073
6174 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
75+
76+
77+func strAssetId (_asset) = if (isDefined(_asset))
78+ then toBase58String(value(_asset))
79+ else "WAVES"
6280
6381
6482 @Callable(i)
111129 if ((unstake == unstake))
112130 then {
113131 let currentAssetBalance = (balanceOf(_assetId) - _amount)
114- (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))])
132+ (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, if ((_assetId == "WAVES"))
133+ then unit
134+ else fromBase58String(_assetId))])
115135 }
116136 else throw("Strict value is not equal to itself.")
117137 }
121141 @Callable(i)
122142 func deposit () = {
123143 let _amount = i.payments[0].amount
124- let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId"))
144+ let _assetId = strAssetId(i.payments[0].assetId)
125145 if (if (if (if (!(initialized()))
126146 then true
127147 else if (!(isWhitelist(toString(i.caller))))
160180 case _ =>
161181 throw("Invalid claimProfit result type")
162182 }
163- $Tuple2([ScriptTransfer(i.caller, profit, fromBase58String(_assetId))], profit)
183+ $Tuple2([ScriptTransfer(i.caller, profit, if ((_assetId == "WAVES"))
184+ then unit
185+ else fromBase58String(_assetId))], profit)
164186 }
165187 else throw("Strict value is not equal to itself.")
166188 }
186208 }
187209
188210
189-
190-@Callable(i)
191-func migrate (_assetId) = {
192- let _amount = balanceOf(_assetId)
193- if (if (if (!(initialized()))
194- then true
195- else (i.caller != adminAddress()))
196- then true
197- else !(paused()))
198- then throw("Invalid migrate params (manager)")
199- else {
200- let unstake = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [_assetId, _amount], nil)
201- if ((unstake == unstake))
202- then {
203- let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(fromBase58String(_assetId), _amount)])
204- if ((stake == stake))
205- then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")]
206- else throw("Strict value is not equal to itself.")
207- }
208- else throw("Strict value is not equal to itself.")
209- }
210- }
211-
212-
213211 @Verifier(tx)
214212 func verify () = {
215213 let coordinatorStr = getString(this, k_coordinatorAddress)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let k_funds = "k_funds"
55
66 let k_asset_manager_address = "k_asset_manager_address"
77
88 let k_coordinatorAddress = "k_coordinatorAddress"
99
1010 let k_orders_address = "k_orders_address"
1111
1212 let k_vault_address = "k_vault_address"
1313
1414 let k_amm = "k_amm"
1515
1616 let k_admin_address = "k_admin_address"
1717
1818 let k_staking_address = "k_staking_address"
19+
20+let k_spot_address = "k_spot_address"
21+
22+let k_vault = "k_vault"
1923
2024 let k_initialized = "k_initialized"
2125
2226 let k_paused = "k_paused"
2327
2428 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
2529
2630
2731 func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0)
2832
2933
3034 func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid")
3135
3236
3337 func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
3438
3539
3640 func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid")
3741
3842
3943 func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
4044
4145
4246 func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
4347
4448
49+func spotAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_spot_address), "Spot address not set")), "Spot address invalid")
50+
51+
4552 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
4653
4754
4855 func paused () = valueOrElse(getBoolean(this, k_paused), false)
4956
5057
5158 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))
59+
60+
61+func isSpotVault (_address) = {
62+ let spot = spotAddress()
63+ valueOrElse(getBoolean(spot, toCompositeKey(k_vault, _address)), false)
64+ }
5265
5366
5467 func isWhitelist (_address) = if (if ((_address == toString(stakingAddress())))
5568 then true
5669 else (_address == toString(vaultAddress())))
5770 then true
5871 else (_address == toString(ordersAddress()))
5972
6073
6174 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
75+
76+
77+func strAssetId (_asset) = if (isDefined(_asset))
78+ then toBase58String(value(_asset))
79+ else "WAVES"
6280
6381
6482 @Callable(i)
6583 func initialize (_coordinator,_quoteAssetId,_quoteAssetManager) = if (if (initialized())
6684 then true
6785 else (i.caller != this))
6886 then throw("Unable to initialize")
6987 else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), StringEntry(toCompositeKey(k_asset_manager_address, _quoteAssetId), toString(addressFromStringValue(_quoteAssetManager))), BooleanEntry(k_initialized, true)]
7088
7189
7290
7391 @Callable(i)
7492 func unpause () = if ((i.caller != adminAddress()))
7593 then throw("Invalid unpause params")
7694 else [BooleanEntry(k_paused, false)]
7795
7896
7997
8098 @Callable(i)
8199 func pause () = if ((i.caller != adminAddress()))
82100 then throw("Invalid pause params")
83101 else [BooleanEntry(k_paused, true)]
84102
85103
86104
87105 @Callable(i)
88106 func addAssetManager (_assetId,_vaultAddress) = if (if (if (!(initialized()))
89107 then true
90108 else (i.caller != adminAddress()))
91109 then true
92110 else if (isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId))))
93111 then (balanceOf(_assetId) > 0)
94112 else false)
95113 then throw("Invalid addTokenVault params")
96114 else [StringEntry(toCompositeKey(k_asset_manager_address, _assetId), toString(addressFromStringValue(_vaultAddress)))]
97115
98116
99117
100118 @Callable(i)
101119 func withdraw (_assetId,_amount) = if (if (if (if (!(isWhitelist(toString(i.caller))))
102120 then true
103121 else !(initialized()))
104122 then true
105123 else paused())
106124 then true
107125 else (_amount > balanceOf(_assetId)))
108126 then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId))))
109127 else {
110128 let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil)
111129 if ((unstake == unstake))
112130 then {
113131 let currentAssetBalance = (balanceOf(_assetId) - _amount)
114- (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))])
132+ (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, if ((_assetId == "WAVES"))
133+ then unit
134+ else fromBase58String(_assetId))])
115135 }
116136 else throw("Strict value is not equal to itself.")
117137 }
118138
119139
120140
121141 @Callable(i)
122142 func deposit () = {
123143 let _amount = i.payments[0].amount
124- let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId"))
144+ let _assetId = strAssetId(i.payments[0].assetId)
125145 if (if (if (if (!(initialized()))
126146 then true
127147 else if (!(isWhitelist(toString(i.caller))))
128148 then (i.caller != adminAddress())
129149 else false)
130150 then true
131151 else paused())
132152 then true
133153 else (size(i.payments) != 1))
134154 then throw("Invalid deposit params (manager)")
135155 else {
136156 let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(i.payments[0].assetId, _amount)])
137157 if ((stake == stake))
138158 then {
139159 let currentAssetBalance = (balanceOf(_assetId) + _amount)
140160 updateFunds(_assetId, currentAssetBalance)
141161 }
142162 else throw("Strict value is not equal to itself.")
143163 }
144164 }
145165
146166
147167
148168 @Callable(i)
149169 func claimProfit (_assetId) = if (if (!(initialized()))
150170 then true
151171 else (i.caller != vaultAddress()))
152172 then throw("Invalid claimProfit params (manager)")
153173 else {
154174 let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
155175 if ((doClaimProfitResult == doClaimProfitResult))
156176 then {
157177 let profit = match doClaimProfitResult {
158178 case t: Int =>
159179 t
160180 case _ =>
161181 throw("Invalid claimProfit result type")
162182 }
163- $Tuple2([ScriptTransfer(i.caller, profit, fromBase58String(_assetId))], profit)
183+ $Tuple2([ScriptTransfer(i.caller, profit, if ((_assetId == "WAVES"))
184+ then unit
185+ else fromBase58String(_assetId))], profit)
164186 }
165187 else throw("Strict value is not equal to itself.")
166188 }
167189
168190
169191
170192 @Callable(i)
171193 func view_claimProfit (_assetId) = if (!(initialized()))
172194 then throw("Invalid view_claimProfit params (manager)")
173195 else {
174196 let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
175197 if ((doClaimProfitResult == doClaimProfitResult))
176198 then {
177199 let profit = match doClaimProfitResult {
178200 case t: Int =>
179201 t
180202 case _ =>
181203 throw("Invalid claimProfit result type")
182204 }
183205 throw(((((toString(balanceOf(_assetId)) + ",") + toString((balanceOf(_assetId) + profit))) + ",") + toString(profit)))
184206 }
185207 else throw("Strict value is not equal to itself.")
186208 }
187209
188210
189-
190-@Callable(i)
191-func migrate (_assetId) = {
192- let _amount = balanceOf(_assetId)
193- if (if (if (!(initialized()))
194- then true
195- else (i.caller != adminAddress()))
196- then true
197- else !(paused()))
198- then throw("Invalid migrate params (manager)")
199- else {
200- let unstake = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [_assetId, _amount], nil)
201- if ((unstake == unstake))
202- then {
203- let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(fromBase58String(_assetId), _amount)])
204- if ((stake == stake))
205- then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")]
206- else throw("Strict value is not equal to itself.")
207- }
208- else throw("Strict value is not equal to itself.")
209- }
210- }
211-
212-
213211 @Verifier(tx)
214212 func verify () = {
215213 let coordinatorStr = getString(this, k_coordinatorAddress)
216214 if (isDefined(coordinatorStr))
217215 then {
218216 let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address)
219217 if (isDefined(admin))
220218 then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false)
221219 else throw("unable to verify: admin not set in coordinator")
222220 }
223221 else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
224222 }
225223

github/deemru/w8io/3ef1775 
58.09 ms