tx · GdxZUNveJHrcz9ayuw36PrqzjWf9ivi5JQjdRGLbh7bf

3PC63UyjuKYohBwBA2gaUEu4LXr6HB8acrm:  -0.03700000 Waves

2023.04.18 18:59 [3605760] smart account 3PC63UyjuKYohBwBA2gaUEu4LXr6HB8acrm > SELF 0.00000000 Waves

{ "type": 13, "id": "GdxZUNveJHrcz9ayuw36PrqzjWf9ivi5JQjdRGLbh7bf", "fee": 3700000, "feeAssetId": null, "timestamp": 1681833577623, "version": 2, "chainId": 87, "sender": "3PC63UyjuKYohBwBA2gaUEu4LXr6HB8acrm", "senderPublicKey": "3h1iv2Yfaw1ryKh5jRMeTicLYmFqYU6Au1uJxRrSUC9L", "proofs": [ "4SNBVNfEr9XSffUrNmLyPapH6Vefpf4UMz1wKuKWSHVAnLstV4TWcJW7Fp5MrZy1s7zXXnpx81uMyMosKnyBSF8z" ], "script": "base64:BgIPCAISAwoBCBIGCgQEBAQIDQANa19pbml0aWFsaXplZAINa19pbml0aWFsaXplZAAUa19jb29yZGluYXRvckFkZHJlc3MCFGtfY29vcmRpbmF0b3JBZGRyZXNzABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MAEWtfZmFybWluZ19hZGRyZXNzAhFrX2Zhcm1pbmdfYWRkcmVzcwAPa192YXVsdF9hZGRyZXNzAg9rX3ZhdWx0X2FkZHJlc3MAD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzAQlzdHJUb0xpc3QBBF9zdHIDCQAAAgUEX3N0cgIABQNuaWwJALUJAgUEX3N0cgIBLAELY29vcmRpbmF0b3IACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFFGtfY29vcmRpbmF0b3JBZGRyZXNzAhZDb29yZGluYXRvciBub3Qgc2V0IEhDAhtDb29yZGluYXRvciBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAEOZmFybWluZ0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEWtfZmFybWluZ19hZGRyZXNzAhdGYXJtaW5nIGFkZHJlc3Mgbm90IHNldAIXRmFybWluZyBhZGRyZXNzIGludmFsaWQBDHZhdWx0QWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAUPa192YXVsdF9hZGRyZXNzAhVWYXVsdCBhZGRyZXNzIG5vdCBzZXQCFVZhdWx0IGFkZHJlc3MgaW52YWxpZAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAgFpAQppbml0aWFsaXplAQxfY29vcmRpbmF0b3IDAwkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECFFVuYWJsZSB0byBpbml0aWFsaXplCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGtfY29vcmRpbmF0b3JBZGRyZXNzCQClCAEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDF9jb29yZGluYXRvcgkAzAgCCQEMQm9vbGVhbkVudHJ5AgUNa19pbml0aWFsaXplZAYFA25pbAFpARNwZXJmb3JtSG91c2VrZWVwaW5nBAZfdmF1bHQIX2Zhcm1pbmcIX3N0YWtpbmcLX3BheUZ1bmRpbmcEE2RvQWNrUmV3YXJkc1N0YWtpbmcDBQhfc3Rha2luZwkA/AcECQEOc3Rha2luZ0FkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFE2RvQWNrUmV3YXJkc1N0YWtpbmcFE2RvQWNrUmV3YXJkc1N0YWtpbmcEE2RvQWNrUmV3YXJkc0Zhcm1pbmcDBQhfZmFybWluZwkA/AcECQEOZmFybWluZ0FkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFE2RvQWNrUmV3YXJkc0Zhcm1pbmcFE2RvQWNrUmV3YXJkc0Zhcm1pbmcEEWRvQWNrUmV3YXJkc1ZhdWx0AwUGX3ZhdWx0CQD8BwQJAQx2YXVsdEFkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFEWRvQWNrUmV3YXJkc1ZhdWx0BRFkb0Fja1Jld2FyZHNWYXVsdAQEYW1tcwkBCXN0clRvTGlzdAEFC19wYXlGdW5kaW5nCgEHY29tcHV0ZQIEX2FjYwRfYW1tBAxkb1BheUZ1bmRpbmcJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQUEX2FtbQIKcGF5RnVuZGluZwUDbmlsBQNuaWwDCQAAAgUMZG9QYXlGdW5kaW5nBQxkb1BheUZ1bmRpbmcFBF9hY2MJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4KAAIkbAUEYW1tcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEHY29tcHV0ZQIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQOY29vcmRpbmF0b3JTdHIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MDCQEJaXNEZWZpbmVkAQUOY29vcmRpbmF0b3JTdHIEBWFkbWluCQCdCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFDmNvb3JkaW5hdG9yU3RyBQ9rX2FkbWluX2FkZHJlc3MDCQEJaXNEZWZpbmVkAQUFYWRtaW4JAQt2YWx1ZU9yRWxzZQIJAJsIAgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQUFYWRtaW4JAKwCAgkArAICCQCsAgICB3N0YXR1c18JAKUIAQUEdGhpcwIBXwkA2AQBCAUCdHgCaWQHCQACAQIudW5hYmxlIHRvIHZlcmlmeTogYWRtaW4gbm90IHNldCBpbiBjb29yZGluYXRvcgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tlea2sWp8=", "height": 3605760, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 63ac1YREq7HwiS18HhGHwEZuN1huwLzDSkkKPTw3Ybs1 Next: 6epKiFwK9qXniy85LopZ3e481PZjHSN324uaZp7TaEcs Diff:
OldNewDifferences
1111
1212 let k_vault_address = "k_vault_address"
1313
14-let k_governance_asset = "k_gov_asset"
15-
16-let k_quote_asset = "k_quote_asset"
17-
1814 let k_admin_address = "k_admin_address"
1915
2016 func strToList (_str) = if ((_str == ""))
2218 else split(_str, ",")
2319
2420
25-func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set")
21+func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set HC")), "Coordinator address invalid")
2622
2723
28-func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address))
24+func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
2925
3026
31-func governanceAsset () = fromBase58String(getStringValue(coordinator(), k_governance_asset))
27+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
3228
3329
34-func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset))
30+func farmingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_farming_address), "Farming address not set")), "Farming address invalid")
3531
3632
37-func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set")
38-
39-
40-func farmingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_farming_address)), "Farming not set")
41-
42-
43-func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
33+func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
4434
4535
4636 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let k_initialized = "k_initialized"
55
66 let k_coordinatorAddress = "k_coordinatorAddress"
77
88 let k_staking_address = "k_staking_address"
99
1010 let k_farming_address = "k_farming_address"
1111
1212 let k_vault_address = "k_vault_address"
1313
14-let k_governance_asset = "k_gov_asset"
15-
16-let k_quote_asset = "k_quote_asset"
17-
1814 let k_admin_address = "k_admin_address"
1915
2016 func strToList (_str) = if ((_str == ""))
2117 then nil
2218 else split(_str, ",")
2319
2420
25-func coordinator () = valueOrErrorMessage(addressFromString(getStringValue(this, k_coordinatorAddress)), "Coordinator not set")
21+func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set HC")), "Coordinator address invalid")
2622
2723
28-func adminAddress () = addressFromString(getStringValue(coordinator(), k_admin_address))
24+func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set"))
2925
3026
31-func governanceAsset () = fromBase58String(getStringValue(coordinator(), k_governance_asset))
27+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
3228
3329
34-func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset))
30+func farmingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_farming_address), "Farming address not set")), "Farming address invalid")
3531
3632
37-func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set")
38-
39-
40-func farmingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_farming_address)), "Farming not set")
41-
42-
43-func vaultAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_vault_address)), "Vault not set")
33+func vaultAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_vault_address), "Vault address not set")), "Vault address invalid")
4434
4535
4636 func initialized () = valueOrElse(getBoolean(this, k_initialized), false)
4737
4838
4939 @Callable(i)
5040 func initialize (_coordinator) = if (if (initialized())
5141 then true
5242 else (i.caller != this))
5343 then throw("Unable to initialize")
5444 else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), BooleanEntry(k_initialized, true)]
5545
5646
5747
5848 @Callable(i)
5949 func performHousekeeping (_vault,_farming,_staking,_payFunding) = {
6050 let doAckRewardsStaking = if (_staking)
6151 then invoke(stakingAddress(), "ackRewards", nil, nil)
6252 else nil
6353 if ((doAckRewardsStaking == doAckRewardsStaking))
6454 then {
6555 let doAckRewardsFarming = if (_farming)
6656 then invoke(farmingAddress(), "ackRewards", nil, nil)
6757 else nil
6858 if ((doAckRewardsFarming == doAckRewardsFarming))
6959 then {
7060 let doAckRewardsVault = if (_vault)
7161 then invoke(vaultAddress(), "ackRewards", nil, nil)
7262 else nil
7363 if ((doAckRewardsVault == doAckRewardsVault))
7464 then {
7565 let amms = strToList(_payFunding)
7666 func compute (_acc,_amm) = {
7767 let doPayFunding = invoke(addressFromStringValue(_amm), "payFunding", nil, nil)
7868 if ((doPayFunding == doPayFunding))
7969 then _acc
8070 else throw("Strict value is not equal to itself.")
8171 }
8272
8373 let $l = amms
8474 let $s = size($l)
8575 let $acc0 = nil
8676 func $f0_1 ($a,$i) = if (($i >= $s))
8777 then $a
8878 else compute($a, $l[$i])
8979
9080 func $f0_2 ($a,$i) = if (($i >= $s))
9181 then $a
9282 else throw("List size exceeds 20")
9383
9484 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
9585 }
9686 else throw("Strict value is not equal to itself.")
9787 }
9888 else throw("Strict value is not equal to itself.")
9989 }
10090 else throw("Strict value is not equal to itself.")
10191 }
10292
10393
10494 @Verifier(tx)
10595 func verify () = {
10696 let coordinatorStr = getString(this, k_coordinatorAddress)
10797 if (isDefined(coordinatorStr))
10898 then {
10999 let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address)
110100 if (isDefined(admin))
111101 then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false)
112102 else throw("unable to verify: admin not set in coordinator")
113103 }
114104 else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
115105 }
116106

github/deemru/w8io/3ef1775 
31.20 ms