tx · 6wUiV2vccBxEksodtBJUhqKryzRv9zQkxLoez6ymAKTa

3PHBHv5bHJ54gGPra43dJjmmDQfx3XZnaMh:  -0.03700000 Waves

2023.04.18 21:45 [3605931] smart account 3PHBHv5bHJ54gGPra43dJjmmDQfx3XZnaMh > SELF 0.00000000 Waves

{ "type": 13, "id": "6wUiV2vccBxEksodtBJUhqKryzRv9zQkxLoez6ymAKTa", "fee": 3700000, "feeAssetId": null, "timestamp": 1681843557675, "version": 2, "chainId": 87, "sender": "3PHBHv5bHJ54gGPra43dJjmmDQfx3XZnaMh", "senderPublicKey": "44g3MaVEsS9ULWvcrh5WTeF6neYVgVFeaaEcwf1ypKvs", "proofs": [ "KovQ5fvR9s1EoejavVoKpQLXjmaGQi8cXtZsxj1DZvu3EEpf8zdSqTKMSMGEovibqaCnNMeSn1726dRbaMUHqNK" ], "script": "base64:BgIqCAISBQoDCAgIEgASABIECgIICBIECgIIARIAEgMKAQgSAwoBCBIDCgEIFgAHa19mdW5kcwIHa19mdW5kcwAXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MCF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzABRrX2Nvb3JkaW5hdG9yQWRkcmVzcwIUa19jb29yZGluYXRvckFkZHJlc3MAEGtfb3JkZXJzX2FkZHJlc3MCEGtfb3JkZXJzX2FkZHJlc3MAD2tfdmF1bHRfYWRkcmVzcwIPa192YXVsdF9hZGRyZXNzAAVrX2FtbQIFa19hbW0AD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MADWtfaW5pdGlhbGl6ZWQCDWtfaW5pdGlhbGl6ZWQACGtfcGF1c2VkAghrX3BhdXNlZAEOdG9Db21wb3NpdGVLZXkCBF9rZXkIX2FkZHJlc3MJAKwCAgkArAICBQRfa2V5AgFfBQhfYWRkcmVzcwEJYmFsYW5jZU9mAQhfYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQEOdG9Db21wb3NpdGVLZXkCBQdrX2Z1bmRzBQhfYXNzZXRJZAAAAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCG0Nvb3JkaW5hdG9yIG5vdCBzZXQgTWFuYWdlcgIbQ29vcmRpbmF0b3IgYWRkcmVzcyBpbnZhbGlkAQx2YXVsdEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfdmF1bHRfYWRkcmVzcwIVVmF1bHQgYWRkcmVzcyBub3Qgc2V0AhVWYXVsdCBhZGRyZXNzIGludmFsaWQBDW9yZGVyc0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEGtfb3JkZXJzX2FkZHJlc3MCFk9yZGVycyBhZGRyZXNzIG5vdCBzZXQCFk9yZGVycyBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAQZwYXVzZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFCGtfcGF1c2VkBwETYXNzZXRNYW5hZ2VyQWRkcmVzcwEIX2Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQCsAgICG05vIGFzc2V0IG1hbmFnZXIgZm9yIHRva2VuIAUIX2Fzc2V0SWQJAKwCAgIoSW52YWxpZCBhc3NldCBtYW5hZ2VyIGFkZHJlc3MgZm9yIHRva2VuIAUIX2Fzc2V0SWQBC2lzV2hpdGVsaXN0AQhfYWRkcmVzcwMDCQAAAgUIX2FkZHJlc3MJAKUIAQkBDnN0YWtpbmdBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQEMdmF1bHRBZGRyZXNzAAYJAAACBQhfYWRkcmVzcwkApQgBCQENb3JkZXJzQWRkcmVzcwABC3VwZGF0ZUZ1bmRzAghfYXNzZXRJZAZfdmFsdWUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQ50b0NvbXBvc2l0ZUtleQIFB2tfZnVuZHMFCF9hc3NldElkBQZfdmFsdWUFA25pbAkBaQEKaW5pdGlhbGl6ZQMMX2Nvb3JkaW5hdG9yDV9xdW90ZUFzc2V0SWQSX3F1b3RlQXNzZXRNYW5hZ2VyAwMJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhRVbmFibGUgdG8gaW5pdGlhbGl6ZQkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwkApQgBCQERQGV4dHJOYXRpdmUoMTA2MikBBQxfY29vcmRpbmF0b3IJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFDV9xdW90ZUFzc2V0SWQJAKUIAQkBEUBleHRyTmF0aXZlKDEwNjIpAQUSX3F1b3RlQXNzZXRNYW5hZ2VyCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBB3VucGF1c2UAAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAkAAgECFkludmFsaWQgdW5wYXVzZSBwYXJhbXMJAMwIAgkBDEJvb2xlYW5FbnRyeQIFCGtfcGF1c2VkBwUDbmlsAWkBBXBhdXNlAAMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhRJbnZhbGlkIHBhdXNlIHBhcmFtcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUIa19wYXVzZWQGBQNuaWwBaQEPYWRkQXNzZXRNYW5hZ2VyAghfYXNzZXRJZA1fdmF1bHRBZGRyZXNzAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MABgMJAQlpc0RlZmluZWQBCQCiCAEJAQ50b0NvbXBvc2l0ZUtleQIFF2tfYXNzZXRfbWFuYWdlcl9hZGRyZXNzBQhfYXNzZXRJZAkAZgIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAAABwkAAgECHEludmFsaWQgYWRkVG9rZW5WYXVsdCBwYXJhbXMJAMwIAgkBC1N0cmluZ0VudHJ5AgkBDnRvQ29tcG9zaXRlS2V5AgUXa19hc3NldF9tYW5hZ2VyX2FkZHJlc3MFCF9hc3NldElkCQClCAEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDV92YXVsdEFkZHJlc3MFA25pbAFpAQh3aXRoZHJhdwIIX2Fzc2V0SWQHX2Ftb3VudAMDAwMJAQEhAQkBC2lzV2hpdGVsaXN0AQkApQgBCAUBaQZjYWxsZXIGCQEBIQEJAQtpbml0aWFsaXplZAAGCQEGcGF1c2VkAAYJAGYCBQdfYW1vdW50CQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQJAAIBCQCsAgIJAKwCAgkArAICAiJJbnZhbGlkIHdpdGhkcmF3IHBhcmFtcyAobWFuYWdlcikgCQCkAwEFB19hbW91bnQCAyA+IAkApAMBCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQEB3Vuc3Rha2UJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAIId2l0aGRyYXcJAMwIAgUIX2Fzc2V0SWQJAMwIAgUHX2Ftb3VudAUDbmlsBQNuaWwDCQAAAgUHdW5zdGFrZQUHdW5zdGFrZQQTY3VycmVudEFzc2V0QmFsYW5jZQkAZQIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUHX2Ftb3VudAkAzggCCQELdXBkYXRlRnVuZHMCBQhfYXNzZXRJZAUTY3VycmVudEFzc2V0QmFsYW5jZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFB19hbW91bnQJANkEAQUIX2Fzc2V0SWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQdkZXBvc2l0AAQHX2Ftb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQECF9hc3NldElkCQDYBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAgpObyBhc3NldElkAwMDAwkBASEBCQELaW5pdGlhbGl6ZWQABgMJAQEhAQkBC2lzV2hpdGVsaXN0AQkApQgBCAUBaQZjYWxsZXIJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAHBgkBBnBhdXNlZAAGCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAiBJbnZhbGlkIGRlcG9zaXQgcGFyYW1zIChtYW5hZ2VyKQQFc3Rha2UJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAIHZGVwb3NpdAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFB19hbW91bnQFA25pbAMJAAACBQVzdGFrZQUFc3Rha2UEE2N1cnJlbnRBc3NldEJhbGFuY2UJAGQCCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQFB19hbW91bnQJAQt1cGRhdGVGdW5kcwIFCF9hc3NldElkBRNjdXJyZW50QXNzZXRCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBC2NsYWltUHJvZml0AQhfYXNzZXRJZAMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQx2YXVsdEFkZHJlc3MACQACAQIkSW52YWxpZCBjbGFpbVByb2ZpdCBwYXJhbXMgKG1hbmFnZXIpBBNkb0NsYWltUHJvZml0UmVzdWx0CQD8BwQJARNhc3NldE1hbmFnZXJBZGRyZXNzAQUIX2Fzc2V0SWQCC2NsYWltUHJvZml0CQDMCAIFCF9hc3NldElkBQNuaWwFA25pbAMJAAACBRNkb0NsYWltUHJvZml0UmVzdWx0BRNkb0NsYWltUHJvZml0UmVzdWx0BAZwcm9maXQEByRtYXRjaDAFE2RvQ2xhaW1Qcm9maXRSZXN1bHQDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIfSW52YWxpZCBjbGFpbVByb2ZpdCByZXN1bHQgdHlwZQkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUGcHJvZml0CQDZBAEFCF9hc3NldElkBQNuaWwFBnByb2ZpdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARB2aWV3X2NsYWltUHJvZml0AQhfYXNzZXRJZAMJAQEhAQkBC2luaXRpYWxpemVkAAkAAgECKUludmFsaWQgdmlld19jbGFpbVByb2ZpdCBwYXJhbXMgKG1hbmFnZXIpBBNkb0NsYWltUHJvZml0UmVzdWx0CQD8BwQJARNhc3NldE1hbmFnZXJBZGRyZXNzAQUIX2Fzc2V0SWQCC2NsYWltUHJvZml0CQDMCAIFCF9hc3NldElkBQNuaWwFA25pbAMJAAACBRNkb0NsYWltUHJvZml0UmVzdWx0BRNkb0NsYWltUHJvZml0UmVzdWx0BAZwcm9maXQEByRtYXRjaDAFE2RvQ2xhaW1Qcm9maXRSZXN1bHQDCQABAgUHJG1hdGNoMAIDSW50BAF0BQckbWF0Y2gwBQF0CQACAQIfSW52YWxpZCBjbGFpbVByb2ZpdCByZXN1bHQgdHlwZQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkApAMBCQEJYmFsYW5jZU9mAQUIX2Fzc2V0SWQCASwJAKQDAQkAZAIJAQliYWxhbmNlT2YBBQhfYXNzZXRJZAUGcHJvZml0AgEsCQCkAwEFBnByb2ZpdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQdtaWdyYXRlAQhfYXNzZXRJZAQHX2Ftb3VudAkBCWJhbGFuY2VPZgEFCF9hc3NldElkAwMDCQEBIQEJAQtpbml0aWFsaXplZAAGCQECIT0CCAUBaQZjYWxsZXIJAQxhZG1pbkFkZHJlc3MABgkBASEBCQEGcGF1c2VkAAkAAgECIEludmFsaWQgbWlncmF0ZSBwYXJhbXMgKG1hbmFnZXIpBAd1bnN0YWtlCQD8BwQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwIPa192aXJlc19hZGRyZXNzAhdObyBsZWdhY3kgdmlyZXMgYWRkcmVzcwIcSW52YWxpZCBsZWdhY3kgdmlyZXMgYWRkcmVzcwIId2l0aGRyYXcJAMwIAgUIX2Fzc2V0SWQJAMwIAgUHX2Ftb3VudAUDbmlsBQNuaWwDCQAAAgUHdW5zdGFrZQUHdW5zdGFrZQQFc3Rha2UJAPwHBAkBE2Fzc2V0TWFuYWdlckFkZHJlc3MBBQhfYXNzZXRJZAIHZGVwb3NpdAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFCF9hc3NldElkBQdfYW1vdW50BQNuaWwDCQAAAgUFc3Rha2UFBXN0YWtlCQDMCAIJAQtEZWxldGVFbnRyeQECD2tfdmlyZXNfYWRkcmVzcwkAzAgCCQELRGVsZXRlRW50cnkBAg1rX3ZpcmVzX3ZhdWx0BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABA5jb29yZGluYXRvclN0cgkAnQgCBQR0aGlzBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwMJAQlpc0RlZmluZWQBBQ5jb29yZGluYXRvclN0cgQFYWRtaW4JAJ0IAgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQUOY29vcmRpbmF0b3JTdHIFD2tfYWRtaW5fYWRkcmVzcwMJAQlpc0RlZmluZWQBBQVhZG1pbgkBC3ZhbHVlT3JFbHNlAgkAmwgCCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBBQVhZG1pbgkArAICCQCsAgIJAKwCAgIHc3RhdHVzXwkApQgBBQR0aGlzAgFfCQDYBAEIBQJ0eAJpZAcJAAIBAi51bmFibGUgdG8gdmVyaWZ5OiBhZG1pbiBub3Qgc2V0IGluIGNvb3JkaW5hdG9yCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5uczTng==", "height": 3605931, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6xTH8SdkDFkBR5DwkkViW93LhHRBUdgHRpnabKRZDR4s Next: 73AiLGosBR7iHdKdPCEqapvDk3sPLF73awneSZmvSwoh Diff:
OldNewDifferences
8989 then true
9090 else (i.caller != adminAddress()))
9191 then true
92- else isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId))))
92+ else if (isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId))))
93+ then (balanceOf(_assetId) > 0)
94+ else false)
9395 then throw("Invalid addTokenVault params")
9496 else [StringEntry(toCompositeKey(k_asset_manager_address, _assetId), toString(addressFromStringValue(_vaultAddress)))]
9597
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"
1919
2020 let k_initialized = "k_initialized"
2121
2222 let k_paused = "k_paused"
2323
2424 func toCompositeKey (_key,_address) = ((_key + "_") + _address)
2525
2626
2727 func balanceOf (_assetId) = valueOrElse(getInteger(this, toCompositeKey(k_funds, _assetId)), 0)
2828
2929
3030 func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Manager")), "Coordinator address invalid")
3131
3232
3333 func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
3434
3535
3636 func ordersAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_orders_address), "Orders address not set")), "Orders address invalid")
3737
3838
3939 func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
4040
4141
4242 func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
4343
4444
4545 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
4646
4747
4848 func paused () = valueOrElse(getBoolean(this, k_paused), false)
4949
5050
5151 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))
5252
5353
5454 func isWhitelist (_address) = if (if ((_address == toString(stakingAddress())))
5555 then true
5656 else (_address == toString(vaultAddress())))
5757 then true
5858 else (_address == toString(ordersAddress()))
5959
6060
6161 func updateFunds (_assetId,_value) = [IntegerEntry(toCompositeKey(k_funds, _assetId), _value)]
6262
6363
6464 @Callable(i)
6565 func initialize (_coordinator,_quoteAssetId,_quoteAssetManager) = if (if (initialized())
6666 then true
6767 else (i.caller != this))
6868 then throw("Unable to initialize")
6969 else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), StringEntry(toCompositeKey(k_asset_manager_address, _quoteAssetId), toString(addressFromStringValue(_quoteAssetManager))), BooleanEntry(k_initialized, true)]
7070
7171
7272
7373 @Callable(i)
7474 func unpause () = if ((i.caller != adminAddress()))
7575 then throw("Invalid unpause params")
7676 else [BooleanEntry(k_paused, false)]
7777
7878
7979
8080 @Callable(i)
8181 func pause () = if ((i.caller != adminAddress()))
8282 then throw("Invalid pause params")
8383 else [BooleanEntry(k_paused, true)]
8484
8585
8686
8787 @Callable(i)
8888 func addAssetManager (_assetId,_vaultAddress) = if (if (if (!(initialized()))
8989 then true
9090 else (i.caller != adminAddress()))
9191 then true
92- else isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId))))
92+ else if (isDefined(getString(toCompositeKey(k_asset_manager_address, _assetId))))
93+ then (balanceOf(_assetId) > 0)
94+ else false)
9395 then throw("Invalid addTokenVault params")
9496 else [StringEntry(toCompositeKey(k_asset_manager_address, _assetId), toString(addressFromStringValue(_vaultAddress)))]
9597
9698
9799
98100 @Callable(i)
99101 func withdraw (_assetId,_amount) = if (if (if (if (!(isWhitelist(toString(i.caller))))
100102 then true
101103 else !(initialized()))
102104 then true
103105 else paused())
104106 then true
105107 else (_amount > balanceOf(_assetId)))
106108 then throw(((("Invalid withdraw params (manager) " + toString(_amount)) + " > ") + toString(balanceOf(_assetId))))
107109 else {
108110 let unstake = invoke(assetManagerAddress(_assetId), "withdraw", [_assetId, _amount], nil)
109111 if ((unstake == unstake))
110112 then {
111113 let currentAssetBalance = (balanceOf(_assetId) - _amount)
112114 (updateFunds(_assetId, currentAssetBalance) ++ [ScriptTransfer(i.caller, _amount, fromBase58String(_assetId))])
113115 }
114116 else throw("Strict value is not equal to itself.")
115117 }
116118
117119
118120
119121 @Callable(i)
120122 func deposit () = {
121123 let _amount = i.payments[0].amount
122124 let _assetId = toBase58String(valueOrErrorMessage(i.payments[0].assetId, "No assetId"))
123125 if (if (if (if (!(initialized()))
124126 then true
125127 else if (!(isWhitelist(toString(i.caller))))
126128 then (i.caller != adminAddress())
127129 else false)
128130 then true
129131 else paused())
130132 then true
131133 else (size(i.payments) != 1))
132134 then throw("Invalid deposit params (manager)")
133135 else {
134136 let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(i.payments[0].assetId, _amount)])
135137 if ((stake == stake))
136138 then {
137139 let currentAssetBalance = (balanceOf(_assetId) + _amount)
138140 updateFunds(_assetId, currentAssetBalance)
139141 }
140142 else throw("Strict value is not equal to itself.")
141143 }
142144 }
143145
144146
145147
146148 @Callable(i)
147149 func claimProfit (_assetId) = if (if (!(initialized()))
148150 then true
149151 else (i.caller != vaultAddress()))
150152 then throw("Invalid claimProfit params (manager)")
151153 else {
152154 let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
153155 if ((doClaimProfitResult == doClaimProfitResult))
154156 then {
155157 let profit = match doClaimProfitResult {
156158 case t: Int =>
157159 t
158160 case _ =>
159161 throw("Invalid claimProfit result type")
160162 }
161163 $Tuple2([ScriptTransfer(i.caller, profit, fromBase58String(_assetId))], profit)
162164 }
163165 else throw("Strict value is not equal to itself.")
164166 }
165167
166168
167169
168170 @Callable(i)
169171 func view_claimProfit (_assetId) = if (!(initialized()))
170172 then throw("Invalid view_claimProfit params (manager)")
171173 else {
172174 let doClaimProfitResult = invoke(assetManagerAddress(_assetId), "claimProfit", [_assetId], nil)
173175 if ((doClaimProfitResult == doClaimProfitResult))
174176 then {
175177 let profit = match doClaimProfitResult {
176178 case t: Int =>
177179 t
178180 case _ =>
179181 throw("Invalid claimProfit result type")
180182 }
181183 throw(((((toString(balanceOf(_assetId)) + ",") + toString((balanceOf(_assetId) + profit))) + ",") + toString(profit)))
182184 }
183185 else throw("Strict value is not equal to itself.")
184186 }
185187
186188
187189
188190 @Callable(i)
189191 func migrate (_assetId) = {
190192 let _amount = balanceOf(_assetId)
191193 if (if (if (!(initialized()))
192194 then true
193195 else (i.caller != adminAddress()))
194196 then true
195197 else !(paused()))
196198 then throw("Invalid migrate params (manager)")
197199 else {
198200 let unstake = invoke(valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, "k_vires_address"), "No legacy vires address")), "Invalid legacy vires address"), "withdraw", [_assetId, _amount], nil)
199201 if ((unstake == unstake))
200202 then {
201203 let stake = invoke(assetManagerAddress(_assetId), "deposit", nil, [AttachedPayment(fromBase58String(_assetId), _amount)])
202204 if ((stake == stake))
203205 then [DeleteEntry("k_vires_address"), DeleteEntry("k_vires_vault")]
204206 else throw("Strict value is not equal to itself.")
205207 }
206208 else throw("Strict value is not equal to itself.")
207209 }
208210 }
209211
210212
211213 @Verifier(tx)
212214 func verify () = {
213215 let coordinatorStr = getString(this, k_coordinatorAddress)
214216 if (isDefined(coordinatorStr))
215217 then {
216218 let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address)
217219 if (isDefined(admin))
218220 then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false)
219221 else throw("unable to verify: admin not set in coordinator")
220222 }
221223 else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
222224 }
223225

github/deemru/w8io/873ac7e 
55.18 ms