tx · 6waEmHuwcdZmw8wgfV33YP5rChLfS6WeSk31tgbL8qMA

3N7FAcM14gZRpGB9RTZXtr5BLPfrkeZofev:  -0.03700000 Waves

2023.04.17 20:05 [2538841] smart account 3N7FAcM14gZRpGB9RTZXtr5BLPfrkeZofev > SELF 0.00000000 Waves

{ "type": 13, "id": "6waEmHuwcdZmw8wgfV33YP5rChLfS6WeSk31tgbL8qMA", "fee": 3700000, "feeAssetId": null, "timestamp": 1681751211980, "version": 2, "chainId": 84, "sender": "3N7FAcM14gZRpGB9RTZXtr5BLPfrkeZofev", "senderPublicKey": "E4aZzkomsqh9guBfrarxEhZhPsVg3TsqmKToYSPbXYLd", "proofs": [ "3Jbiwx9VS61ZP8SdUgs3rhssJ5LnBABKNNQxqRRy3bpZi9hUbCSdHXst7z4H7XcPe4xgx9mjbHP6ucQEL4spH8ou" ], "script": "base64:BgIPCAISAwoBCBIGCgQEBAQIDQANa19pbml0aWFsaXplZAINa19pbml0aWFsaXplZAAUa19jb29yZGluYXRvckFkZHJlc3MCFGtfY29vcmRpbmF0b3JBZGRyZXNzABFrX3N0YWtpbmdfYWRkcmVzcwIRa19zdGFraW5nX2FkZHJlc3MAEWtfZmFybWluZ19hZGRyZXNzAhFrX2Zhcm1pbmdfYWRkcmVzcwAPa192YXVsdF9hZGRyZXNzAg9rX3ZhdWx0X2FkZHJlc3MAD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzAQlzdHJUb0xpc3QBBF9zdHIDCQAAAgUEX3N0cgIABQNuaWwJALUJAgUEX3N0cgIBLAELY29vcmRpbmF0b3IACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFFGtfY29vcmRpbmF0b3JBZGRyZXNzAhZDb29yZGluYXRvciBub3Qgc2V0IEhDAhtDb29yZGluYXRvciBhZGRyZXNzIGludmFsaWQBDGFkbWluQWRkcmVzcwAJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFD2tfYWRtaW5fYWRkcmVzcwIVQWRtaW4gYWRkcmVzcyBub3Qgc2V0AQ5zdGFraW5nQWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAURa19zdGFraW5nX2FkZHJlc3MCF1N0YWtpbmcgYWRkcmVzcyBub3Qgc2V0AhdTdGFraW5nIGFkZHJlc3MgaW52YWxpZAEOZmFybWluZ0FkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEWtfZmFybWluZ19hZGRyZXNzAhdGYXJtaW5nIGFkZHJlc3Mgbm90IHNldAIXRmFybWluZyBhZGRyZXNzIGludmFsaWQBDHZhdWx0QWRkcmVzcwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAUPa192YXVsdF9hZGRyZXNzAhVWYXVsdCBhZGRyZXNzIG5vdCBzZXQCFVZhdWx0IGFkZHJlc3MgaW52YWxpZAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAgFpAQppbml0aWFsaXplAQxfY29vcmRpbmF0b3IDAwkBC2luaXRpYWxpemVkAAYJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECFFVuYWJsZSB0byBpbml0aWFsaXplCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGtfY29vcmRpbmF0b3JBZGRyZXNzCQClCAEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDF9jb29yZGluYXRvcgkAzAgCCQEMQm9vbGVhbkVudHJ5AgUNa19pbml0aWFsaXplZAYFA25pbAFpARNwZXJmb3JtSG91c2VrZWVwaW5nBAZfdmF1bHQIX2Zhcm1pbmcIX3N0YWtpbmcLX3BheUZ1bmRpbmcEE2RvQWNrUmV3YXJkc1N0YWtpbmcDBQhfc3Rha2luZwkA/AcECQEOc3Rha2luZ0FkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFE2RvQWNrUmV3YXJkc1N0YWtpbmcFE2RvQWNrUmV3YXJkc1N0YWtpbmcEE2RvQWNrUmV3YXJkc0Zhcm1pbmcDBQhfZmFybWluZwkA/AcECQEOZmFybWluZ0FkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFE2RvQWNrUmV3YXJkc0Zhcm1pbmcFE2RvQWNrUmV3YXJkc0Zhcm1pbmcEEWRvQWNrUmV3YXJkc1ZhdWx0AwUGX3ZhdWx0CQD8BwQJAQx2YXVsdEFkZHJlc3MAAgphY2tSZXdhcmRzBQNuaWwFA25pbAUDbmlsAwkAAAIFEWRvQWNrUmV3YXJkc1ZhdWx0BRFkb0Fja1Jld2FyZHNWYXVsdAQEYW1tcwkBCXN0clRvTGlzdAEFC19wYXlGdW5kaW5nCgEHY29tcHV0ZQIEX2FjYwRfYW1tBAxkb1BheUZ1bmRpbmcJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQUEX2FtbQIKcGF5RnVuZGluZwUDbmlsBQNuaWwDCQAAAgUMZG9QYXlGdW5kaW5nBQxkb1BheUZ1bmRpbmcFBF9hY2MJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4KAAIkbAUEYW1tcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEHY29tcHV0ZQIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQOY29vcmRpbmF0b3JTdHIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MDCQEJaXNEZWZpbmVkAQUOY29vcmRpbmF0b3JTdHIEBWFkbWluCQCdCAIJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQV2YWx1ZQEFDmNvb3JkaW5hdG9yU3RyBQ9rX2FkbWluX2FkZHJlc3MDCQEJaXNEZWZpbmVkAQUFYWRtaW4JAQt2YWx1ZU9yRWxzZQIJAJsIAgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQUFYWRtaW4JAKwCAgkArAICCQCsAgICB3N0YXR1c18JAKUIAQUEdGhpcwIBXwkA2AQBCAUCdHgCaWQHCQACAQIudW5hYmxlIHRvIHZlcmlmeTogYWRtaW4gbm90IHNldCBpbiBjb29yZGluYXRvcgkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tlea2sWp8=", "height": 2538841, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: G9hvkjF3X5VkqJSz6GSE17NqVBcaEjHYwm5PKRHDzRrS Next: none Diff:
OldNewDifferences
99
1010 let k_farming_address = "k_farming_address"
1111
12-let k_governance_asset = "k_gov_asset"
13-
14-let k_quote_asset = "k_quote_asset"
15-
16-let k_admin_public_key = "k_admin_public_key"
12+let k_vault_address = "k_vault_address"
1713
1814 let k_admin_address = "k_admin_address"
1915
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 adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key))
27+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
3228
3329
34-func governanceAsset () = fromBase58String(getStringValue(coordinator(), k_governance_asset))
30+func farmingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_farming_address), "Farming address not set")), "Farming address invalid")
3531
3632
37-func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset))
38-
39-
40-func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set")
41-
42-
43-func farmingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_farming_address)), "Staking 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)
50-func initialize (_coordinator) = if (initialized())
51- then throw("Already initialized")
52- else [StringEntry(k_coordinatorAddress, _coordinator), BooleanEntry(k_initialized, true)]
40+func initialize (_coordinator) = if (if (initialized())
41+ then true
42+ else (i.caller != this))
43+ then throw("Unable to initialize")
44+ else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), BooleanEntry(k_initialized, true)]
5345
5446
5547
5648 @Callable(i)
57-func performHousekeeping (_payFunding) = {
58- let doAckRewardsStaking = invoke(stakingAddress(), "ackRewards", nil, nil)
49+func performHousekeeping (_vault,_farming,_staking,_payFunding) = {
50+ let doAckRewardsStaking = if (_staking)
51+ then invoke(stakingAddress(), "ackRewards", nil, nil)
52+ else nil
5953 if ((doAckRewardsStaking == doAckRewardsStaking))
6054 then {
61- let doAckRewardsFarming = invoke(farmingAddress(), "ackRewards", nil, nil)
55+ let doAckRewardsFarming = if (_farming)
56+ then invoke(farmingAddress(), "ackRewards", nil, nil)
57+ else nil
6258 if ((doAckRewardsFarming == doAckRewardsFarming))
6359 then {
64- let amms = strToList(_payFunding)
65- func compute (_acc,_amm) = {
66- let doPayFunding = invoke(addressFromStringValue(_amm), "payFunding", nil, nil)
67- if ((doPayFunding == doPayFunding))
68- then _acc
69- else throw("Strict value is not equal to itself.")
70- }
60+ let doAckRewardsVault = if (_vault)
61+ then invoke(vaultAddress(), "ackRewards", nil, nil)
62+ else nil
63+ if ((doAckRewardsVault == doAckRewardsVault))
64+ then {
65+ let amms = strToList(_payFunding)
66+ func compute (_acc,_amm) = {
67+ let doPayFunding = invoke(addressFromStringValue(_amm), "payFunding", nil, nil)
68+ if ((doPayFunding == doPayFunding))
69+ then _acc
70+ else throw("Strict value is not equal to itself.")
71+ }
7172
72- let $l = amms
73- let $s = size($l)
74- let $acc0 = nil
75- func $f0_1 ($a,$i) = if (($i >= $s))
76- then $a
77- else compute($a, $l[$i])
73+ let $l = amms
74+ let $s = size($l)
75+ let $acc0 = nil
76+ func $f0_1 ($a,$i) = if (($i >= $s))
77+ then $a
78+ else compute($a, $l[$i])
7879
79- func $f0_2 ($a,$i) = if (($i >= $s))
80- then $a
81- else throw("List size exceeds 20")
80+ func $f0_2 ($a,$i) = if (($i >= $s))
81+ then $a
82+ else throw("List size exceeds 20")
8283
83- $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)
84+ $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)
85+ }
86+ else throw("Strict value is not equal to itself.")
8487 }
8588 else throw("Strict value is not equal to itself.")
8689 }
8992
9093
9194 @Verifier(tx)
92-func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey())
95+func verify () = {
96+ let coordinatorStr = getString(this, k_coordinatorAddress)
97+ if (isDefined(coordinatorStr))
98+ then {
99+ let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address)
100+ if (isDefined(admin))
101+ then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false)
102+ else throw("unable to verify: admin not set in coordinator")
103+ }
104+ else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
105+ }
93106
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
12-let k_governance_asset = "k_gov_asset"
13-
14-let k_quote_asset = "k_quote_asset"
15-
16-let k_admin_public_key = "k_admin_public_key"
12+let k_vault_address = "k_vault_address"
1713
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 adminPublicKey () = fromBase58String(getStringValue(coordinator(), k_admin_public_key))
27+func stakingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_staking_address), "Staking address not set")), "Staking address invalid")
3228
3329
34-func governanceAsset () = fromBase58String(getStringValue(coordinator(), k_governance_asset))
30+func farmingAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_farming_address), "Farming address not set")), "Farming address invalid")
3531
3632
37-func quoteAsset () = fromBase58String(getStringValue(coordinator(), k_quote_asset))
38-
39-
40-func stakingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_staking_address)), "Staking not set")
41-
42-
43-func farmingAddress () = valueOrErrorMessage(addressFromString(getStringValue(coordinator(), k_farming_address)), "Staking 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)
50-func initialize (_coordinator) = if (initialized())
51- then throw("Already initialized")
52- else [StringEntry(k_coordinatorAddress, _coordinator), BooleanEntry(k_initialized, true)]
40+func initialize (_coordinator) = if (if (initialized())
41+ then true
42+ else (i.caller != this))
43+ then throw("Unable to initialize")
44+ else [StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), BooleanEntry(k_initialized, true)]
5345
5446
5547
5648 @Callable(i)
57-func performHousekeeping (_payFunding) = {
58- let doAckRewardsStaking = invoke(stakingAddress(), "ackRewards", nil, nil)
49+func performHousekeeping (_vault,_farming,_staking,_payFunding) = {
50+ let doAckRewardsStaking = if (_staking)
51+ then invoke(stakingAddress(), "ackRewards", nil, nil)
52+ else nil
5953 if ((doAckRewardsStaking == doAckRewardsStaking))
6054 then {
61- let doAckRewardsFarming = invoke(farmingAddress(), "ackRewards", nil, nil)
55+ let doAckRewardsFarming = if (_farming)
56+ then invoke(farmingAddress(), "ackRewards", nil, nil)
57+ else nil
6258 if ((doAckRewardsFarming == doAckRewardsFarming))
6359 then {
64- let amms = strToList(_payFunding)
65- func compute (_acc,_amm) = {
66- let doPayFunding = invoke(addressFromStringValue(_amm), "payFunding", nil, nil)
67- if ((doPayFunding == doPayFunding))
68- then _acc
69- else throw("Strict value is not equal to itself.")
70- }
60+ let doAckRewardsVault = if (_vault)
61+ then invoke(vaultAddress(), "ackRewards", nil, nil)
62+ else nil
63+ if ((doAckRewardsVault == doAckRewardsVault))
64+ then {
65+ let amms = strToList(_payFunding)
66+ func compute (_acc,_amm) = {
67+ let doPayFunding = invoke(addressFromStringValue(_amm), "payFunding", nil, nil)
68+ if ((doPayFunding == doPayFunding))
69+ then _acc
70+ else throw("Strict value is not equal to itself.")
71+ }
7172
72- let $l = amms
73- let $s = size($l)
74- let $acc0 = nil
75- func $f0_1 ($a,$i) = if (($i >= $s))
76- then $a
77- else compute($a, $l[$i])
73+ let $l = amms
74+ let $s = size($l)
75+ let $acc0 = nil
76+ func $f0_1 ($a,$i) = if (($i >= $s))
77+ then $a
78+ else compute($a, $l[$i])
7879
79- func $f0_2 ($a,$i) = if (($i >= $s))
80- then $a
81- else throw("List size exceeds 20")
80+ func $f0_2 ($a,$i) = if (($i >= $s))
81+ then $a
82+ else throw("List size exceeds 20")
8283
83- $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)
84+ $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)
85+ }
86+ else throw("Strict value is not equal to itself.")
8487 }
8588 else throw("Strict value is not equal to itself.")
8689 }
8790 else throw("Strict value is not equal to itself.")
8891 }
8992
9093
9194 @Verifier(tx)
92-func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey())
95+func verify () = {
96+ let coordinatorStr = getString(this, k_coordinatorAddress)
97+ if (isDefined(coordinatorStr))
98+ then {
99+ let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address)
100+ if (isDefined(admin))
101+ then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false)
102+ else throw("unable to verify: admin not set in coordinator")
103+ }
104+ else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
105+ }
93106

github/deemru/w8io/3ef1775 
50.23 ms