tx · 2Kt552qWbY8Qai6uYCM9mrh16NYbVc1Ao7Qwt1sPfP94 3NBqs2vfpyT5cMdUJ97mEJ1Ycp2y8GbAZDA: -0.01300000 Waves 2023.05.19 15:23 [2584838] smart account 3NBqs2vfpyT5cMdUJ97mEJ1Ycp2y8GbAZDA > SELF 0.00000000 Waves
{ "type": 13, "id": "2Kt552qWbY8Qai6uYCM9mrh16NYbVc1Ao7Qwt1sPfP94", "fee": 1300000, "feeAssetId": null, "timestamp": 1684498989085, "version": 2, "chainId": 84, "sender": "3NBqs2vfpyT5cMdUJ97mEJ1Ycp2y8GbAZDA", "senderPublicKey": "H19CeJVbUnfsK8EYs8K6fHxwBH7pLyxw8WCDFu7D4rGQ", "proofs": [ "5ghFVNmvvh8AcsvBQ8AA3r1qZRfeNcUCoZBfMASSLsCfNEH7DJqdbmCpVoiwwoh1SDBsvLF8Ko89VUfKZn64PkcG" ], "script": "base64:BgLnDQgCEgkKBwgBAQEBAQgSAwoBCBIDCgEBEgASABIAEgMKAQEiA1NFUCIHd3JhcEVyciIDbXNnIgh0aHJvd0VyciIPZ2V0U3RyaW5nT3JGYWlsIgdhZGRyZXNzIgNrZXkiEWtleUZhY3RvcnlBZGRyZXNzIhlrZXlWb3RpbmdWZXJpZmllZENvbnRyYWN0IiJrZXlWb3RpbmdFbWlzc2lvbkNhbmRpZGF0ZUNvbnRyYWN0IhRrZXlVc2VyUG9vbHNDb250cmFjdCIda2V5Vm90aW5nRW1pc3Npb25SYXRlQ29udHJhY3QiFnZvdGluZ1ZlcmlmaWVkQ29udHJhY3QiH3ZvdGluZ0VtaXNzaW9uQ2FuZGlkYXRlQ29udHJhY3QiEXVzZXJQb29sc0NvbnRyYWN0Ihp2b3RpbmdFbWlzc2lvblJhdGVDb250cmFjdCIYSWR4RmFjdG9yeUNmZ1N0YWtpbmdEYXBwIhlJZHhGYWN0b3J5Q2ZnQm9vc3RpbmdEYXBwIhRJZHhGYWN0b3J5Q2ZnSWRvRGFwcCIVSWR4RmFjdG9yeUNmZ1RlYW1EYXBwIhlJZHhGYWN0b3J5Q2ZnRW1pc3Npb25EYXBwIhVJZHhGYWN0b3J5Q2ZnUmVzdERhcHAiGUlkeEZhY3RvcnlDZmdTbGlwcGFnZURhcHAiGklkeEZhY3RvcnlDZmdHd3hSZXdhcmREYXBwIg1rZXlGYWN0b3J5Q2ZnIhprZXlGYWN0b3J5THAyQXNzZXRzTWFwcGluZyIKbHBBc3NldFN0ciIQa2V5RmFjdG9yeUxwTGlzdCIma2V5RmFjdG9yeUxwQXNzZXRUb1Bvb2xDb250cmFjdEFkZHJlc3MiFGtleUZhY3RvcnlQb29sV2VpZ2h0Ig9jb250cmFjdEFkZHJlc3MiGHJlYWRGYWN0b3J5QWRkcmVzc09yRmFpbCIKcmVhZExwTGlzdCIUcmVhZEZhY3RvcnlDZmdPckZhaWwiB2ZhY3RvcnkiGGdldEJvb3N0aW5nQWRkcmVzc09yRmFpbCIKZmFjdG9yeUNmZyIYZ2V0RW1pc3Npb25BZGRyZXNzT3JGYWlsIhdnZXRTdGFraW5nQWRkcmVzc09yRmFpbCIZZ2V0R3d4UmV3YXJkQWRkcmVzc09yRmFpbCIJa2V5Q29uZmlnIhlrZXlSYXRlUGVyQmxvY2tNYXhDdXJyZW50IhtrZXlSYXRlUGVyQmxvY2tNYXhTdGFydEZyb20iCXRpbWVzdGFtcCIFYmxvY2siFmtleVJhdGVQZXJCbG9ja0N1cnJlbnQiGGtleVJhdGVQZXJCbG9ja1N0YXJ0RnJvbSIVa2V5RW1pc3Npb25TdGFydEJsb2NrIhtrZXlFbWlzc2lvbkR1cmF0aW9uSW5CbG9ja3MiE2tleUVtaXNzaW9uRW5kQmxvY2siDWtleUJvb3N0Q29lZmYiEWJvb3N0Q29lZmZEZWZhdWx0Igpib29zdENvZWZmIhprZXlHd3hIb2xkZXJzUmV3YXJkQ3VycmVudCIXa2V5R3d4SG9sZGVyc1Jld2FyZE5leHQiE2tleU1hbmFnZXJQdWJsaWNLZXkiFmtleU1hbmFnZXJWYXVsdEFkZHJlc3MiHGdldE1hbmFnZXJWYXVsdEFkZHJlc3NPclRoaXMiByRtYXRjaDAiAXMiFm1hbmFnZXJQdWJsaWNLZXlPclVuaXQiE21hbmFnZXJWYXVsdEFkZHJlc3MiC211c3RNYW5hZ2VyIgFpIgJwZCICcGsiDmZhY3RvcnlBZGRyZXNzIg9yYXRlUGVyQmxvY2tNYXgiDHJhdGVQZXJCbG9jayISZW1pc3Npb25TdGFydEJsb2NrIhBlbWlzc2lvbkR1cmF0aW9uIhZlbWlzc2lvblN0YXJ0VGltZXN0YW1wIgx3eEFzc2V0SWRTdHIiC2NoZWNrQ2FsbGVyIhl2b3RpbmdWZXJpZmllZENvbnRyYWN0UHJtIgZhbW91bnQiD2ZhY3RvcnlDb250cmFjdCIPc3Rha2luZ0NvbnRyYWN0IhJnd3hSZXdhcmRzQ29udHJhY3QiBmNhbGxlciIJd3hBc3NldElkIhBib29zdGluZ0NvbnRyYWN0IgNwbXQiB2Fzc2V0SWQiCXBtdEFtb3VudCIWZ3d4SG9sZGVyUmV3YXJkQ3VycmVudCITZ3d4SG9sZGVyUmV3YXJkTmV4dCIPc2hvdWxkQmVVcGRhdGVkIgdhY3Rpb25zIg9uZXdSYXRlUGVyQmxvY2siBWNoZWNrIg5ibG9ja1RpbWVzdGFtcCICYmkiAnR4IgZ2ZXJpZnkiD3RhcmdldFB1YmxpY0tleTMAAWECAl9fAQFiAQFjCQC5CQIJAMwIAgIOZW1p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BAJhbQkBAWQBAhFQZXJtaXNzaW9uIGRlbmllZAQCYWcJAQJhaQADCQABAgUCYWcCCkJ5dGVWZWN0b3IEAmFuBQJhZwMJAAACCAUCYWwPY2FsbGVyUHVibGljS2V5BQJhbgYFAmFtAwkAAQIFAmFnAgRVbml0AwkAAAIIBQJhbAZjYWxsZXIFBHRoaXMGBQJhbQkAAgECC01hdGNoIGVycm9yBwJhbAELY29uc3RydWN0b3IHAmFvAmFwAmFxAmFyAmFzAmF0AmF1BAJhdgkBAmFrAQUCYWwDCQAAAgUCYXYFAmF2CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUQIFAmF0BQJhcgUCYXAJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFQAAUCYXAJAMwIAgkBDEludGVnZXJFbnRyeQIJAQFVAgUCYXQFAmFyBQJhcQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVQABQJhcQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVYABQJhcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVcABQJhcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVgACQBkAgUCYXIFAmFzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQFoAAUCYW8JAMwIAgkBC1N0cmluZ0VudHJ5AgkBAU8ACQCsAgICBCVzX18FAmF1BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4CYWwBDWNvbnN0cnVjdG9yVjIBAmF3BAJhdgkBAmFrAQUCYWwDCQAAAgUCYXYFAmF2CQCUCgIJAMwIAgkBC1N0cmluZ0VudHJ5AgUBaQUCYXcFA25pbAUEdW5pdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJhbAEEZW1pdAECYXgDCQBnAgAABQJheAkAlAoCBQNuaWwFA25pbAQCYXkJAQFGAAQBSwkBAUgBBQJheQQCYXoJAQFNAQUBSwQCYUEJAQFOAQUBSwQCYUIIBQJhbAZjYWxsZXIDAwkBAiE9AgUCYUIFAmF6CQECIT0CBQJhQgUCYUEHCQEBZAECEnBlcm1pc3Npb25zIGRlbmllZAQCYXUJAJEDAgkAtQkCCQEBZQIFBHRoaXMJAQFPAAUBYQABBAJhQwkA2QQBBQJhdQkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFAmFCBQJheAUCYUMFA25pbAkAzAgCBQJhQwUDbmlsAmFsAQRidXJuAAQCYXkJAQFGAAQBSwkBAUgBBQJheQQCYUQJAQFKAQUBSwMJAQIhPQIJAJADAQgFAmFsCHBheW1lbnRzAAEJAQFkAQIcZXhhY3Qgb25lIHBheW1lbnQgaXMgYWxsb3dlZAQCYUUJAJEDAggFAmFsCHBheW1lbnRzAAAEAmFGCQEFdmFsdWUBCAUCYUUHYXNzZXRJZAQCYUcIBQJhRQZhbW91bnQEAmFDCQDZBAEJAJEDAgkAtQkCCQEBZQIFBHRoaXMJAQFPAAUBYQABAwkBAiE9AgUCYUYFAmFDCQEBZAECG2ludmFsaWQgd3hBc3NldElkIGlzIHBhc3NlZAMJAQEhAQkBD2NvbnRhaW5zRWxlbWVudAIJAMwIAgUCYUQJAMwIAgUBbQkAzAgCBQFuCQDMCAIFAW8FA25pbAgFAmFsBmNhbGxlcgkBAWQBAhJwZXJtaXNzaW9ucyBkZW5pZWQJAMwIAgkBBEJ1cm4CBQJhRgUCYUcJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICAhclcyVzJXNfX2hpc3RvcnlfX2J1cm5fXwkA2AQBCAUCYWwNdHJhbnNhY3Rpb25JZAkAuQkCCQDMCAICBiVkJWQlZAkAzAgCCQCkAwEFBmhlaWdodAkAzAgCCQCkAwEIBQlsYXN0QmxvY2sJdGltZXN0YW1wCQDMCAIJAKQDAQUCYUcFA25pbAUBYQUDbmlsAmFsARZnd3hIb2xkZXJzUmV3YXJkVXBkYXRlAAQCYXkJAQFGAAQBSwkBAUgBBQJheQQCYUEJAQFOAQUBSwQCYXYDCQAAAggFAmFsBmNhbGxlcgUCYUEGCQECYWsBBQJhbAMJAAACBQJhdgUCYXYEAmFICQELdmFsdWVPckVsc2UCCQCfCAEJAQJhYgAAAAQCYUkJAQt2YWx1ZU9yRWxzZQIJAJ8IAQkBAmFjAAUCYUgEAmFKCQECIT0CBQJhSAUCYUkEAmFLAwUCYUoJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJhYgAFAmFJCQDMCAIJAQtEZWxldGVFbnRyeQEJAQJhYwAFA25pbAUDbmlsCQCUCgIFAmFLBQJhSgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgJhbAEVZ2V0Qm9vc3RDb2VmZlJFQURPTkxZAAkAlAoCBQNuaWwFAmFhAmFsARJjaGFuZ2VSYXRlUGVyQmxvY2sBAmFMBAJhTQMJAAACCAUCYWwGY2FsbGVyBQFwBgkBAWQBAhxzaG91bGQgYmUgaW52b2tlZCBpbnRlcm5hbGx5AwkAAAIFAmFNBQJhTQQCYU4EAmFnCQDtBwEFBmhlaWdodAMJAAECBQJhZwIJQmxvY2tJbmZvBAJhTwUCYWcIBQJhTwl0aW1lc3RhbXAJAQFkAQIZQmxvY2tJbmZvLnRpbWVzdGFtcCBlcnJvcgkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVUCBQJhTgUGaGVpZ2h0BQJhTAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAVQABQJhTAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJhUAECYVEABAJhUgQCYWcJAQJhaQADCQABAgUCYWcCCkJ5dGVWZWN0b3IEAmFuBQJhZwUCYW4DCQABAgUCYWcCBFVuaXQIBQJhUA9zZW5kZXJQdWJsaWNLZXkJAAIBAgtNYXRjaCBlcnJvcgkA9AMDCAUCYVAJYm9keUJ5dGVzCQCRAwIIBQJhUAZwcm9vZnMAAAUCYVIp28l9", "height": 2584838, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HwsjgXbVdVHiWR2zTWfQBixHfvVJPYv8TF2Ma28nBz7S Next: CTsXi4T5zn3gHE44ezhGzyM5cbX64cfZvBRH9yhw3gAM Diff:
Old | New | Differences | |
---|---|---|---|
257 | 257 | ||
258 | 258 | ||
259 | 259 | @Callable(i) | |
260 | - | func | |
261 | - | let check = if ((i.caller == | |
260 | + | func changeRatePerBlock (newRatePerBlock) = { | |
261 | + | let check = if ((i.caller == votingEmissionRateContract)) | |
262 | 262 | then true | |
263 | 263 | else throwErr("should be invoked internally") | |
264 | 264 | if ((check == check)) | |
270 | 270 | throwErr("BlockInfo.timestamp error") | |
271 | 271 | } | |
272 | 272 | [IntegerEntry(keyRatePerBlockStartFrom(blockTimestamp, height), newRatePerBlock), IntegerEntry(keyRatePerBlockCurrent(), newRatePerBlock)] | |
273 | - | } | |
274 | - | else throw("Strict value is not equal to itself.") | |
275 | - | } | |
276 | - | ||
277 | - | ||
278 | - | ||
279 | - | @Callable(i) | |
280 | - | func changeRatePerBlock (newRatePerBlock) = { | |
281 | - | let check = if ((i.caller == votingEmissionRateContract)) | |
282 | - | then true | |
283 | - | else mustManager(i) | |
284 | - | if ((check == check)) | |
285 | - | then { | |
286 | - | let factoryContract = readFactoryAddressOrFail() | |
287 | - | let factoryCfg = readFactoryCfgOrFail(factoryContract) | |
288 | - | let boostingContract = getBoostingAddressOrFail(factoryCfg) | |
289 | - | let changeRate = invoke(this, "changeRatePerBlockINTERNAL", [newRatePerBlock], nil) | |
290 | - | if ((changeRate == changeRate)) | |
291 | - | then { | |
292 | - | let boostinEmissionUpdate = invoke(boostingContract, "onBoostEmissionUpdate", nil, nil) | |
293 | - | if ((boostinEmissionUpdate == boostinEmissionUpdate)) | |
294 | - | then nil | |
295 | - | else throw("Strict value is not equal to itself.") | |
296 | - | } | |
297 | - | else throw("Strict value is not equal to itself.") | |
298 | 273 | } | |
299 | 274 | else throw("Strict value is not equal to itself.") | |
300 | 275 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let SEP = "__" | |
5 | 5 | ||
6 | 6 | func wrapErr (msg) = makeString(["emission.ride:", toString(this), msg], " ") | |
7 | 7 | ||
8 | 8 | ||
9 | 9 | func throwErr (msg) = throw(wrapErr(msg)) | |
10 | 10 | ||
11 | 11 | ||
12 | 12 | func getStringOrFail (address,key) = valueOrErrorMessage(getString(address, key), wrapErr((("mandatory this." + key) + " is not defined"))) | |
13 | 13 | ||
14 | 14 | ||
15 | 15 | func keyFactoryAddress () = "%s%s__config__factoryAddress" | |
16 | 16 | ||
17 | 17 | ||
18 | 18 | let keyVotingVerifiedContract = "%s%s__config__votingVerifiedContract" | |
19 | 19 | ||
20 | 20 | let keyVotingEmissionCandidateContract = "%s%s__config__votingEmissionCandidateContract" | |
21 | 21 | ||
22 | 22 | let keyUserPoolsContract = "%s%s__config__userPoolsContract" | |
23 | 23 | ||
24 | 24 | let keyVotingEmissionRateContract = "%s%s__config__votingEmissionRateContract" | |
25 | 25 | ||
26 | 26 | let votingVerifiedContract = addressFromStringValue(getStringOrFail(this, keyVotingVerifiedContract)) | |
27 | 27 | ||
28 | 28 | let votingEmissionCandidateContract = addressFromStringValue(getStringOrFail(this, keyVotingEmissionCandidateContract)) | |
29 | 29 | ||
30 | 30 | let userPoolsContract = addressFromStringValue(getStringOrFail(this, keyUserPoolsContract)) | |
31 | 31 | ||
32 | 32 | let votingEmissionRateContract = addressFromStringValue(getStringOrFail(this, keyVotingEmissionRateContract)) | |
33 | 33 | ||
34 | 34 | let IdxFactoryCfgStakingDapp = 1 | |
35 | 35 | ||
36 | 36 | let IdxFactoryCfgBoostingDapp = 2 | |
37 | 37 | ||
38 | 38 | let IdxFactoryCfgIdoDapp = 3 | |
39 | 39 | ||
40 | 40 | let IdxFactoryCfgTeamDapp = 4 | |
41 | 41 | ||
42 | 42 | let IdxFactoryCfgEmissionDapp = 5 | |
43 | 43 | ||
44 | 44 | let IdxFactoryCfgRestDapp = 6 | |
45 | 45 | ||
46 | 46 | let IdxFactoryCfgSlippageDapp = 7 | |
47 | 47 | ||
48 | 48 | let IdxFactoryCfgGwxRewardDapp = 10 | |
49 | 49 | ||
50 | 50 | func keyFactoryCfg () = "%s__factoryConfig" | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | func keyFactoryLp2AssetsMapping (lpAssetStr) = makeString(["%s%s%s", lpAssetStr, "mappings__lpAsset2PoolContract"], SEP) | |
54 | 54 | ||
55 | 55 | ||
56 | 56 | func keyFactoryLpList () = "%s__lpTokensList" | |
57 | 57 | ||
58 | 58 | ||
59 | 59 | func keyFactoryLpAssetToPoolContractAddress (lpAssetStr) = makeString(["%s%s%s", lpAssetStr, "mappings__lpAsset2PoolContract"], SEP) | |
60 | 60 | ||
61 | 61 | ||
62 | 62 | func keyFactoryPoolWeight (contractAddress) = makeString(["%s%s", "poolWeight", contractAddress], SEP) | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | func readFactoryAddressOrFail () = addressFromStringValue(getStringOrFail(this, keyFactoryAddress())) | |
66 | 66 | ||
67 | 67 | ||
68 | 68 | func readLpList () = split(valueOrElse(getString(readFactoryAddressOrFail(), keyFactoryLpList()), ""), SEP) | |
69 | 69 | ||
70 | 70 | ||
71 | 71 | func readFactoryCfgOrFail (factory) = split(getStringOrFail(factory, keyFactoryCfg()), SEP) | |
72 | 72 | ||
73 | 73 | ||
74 | 74 | func getBoostingAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgBoostingDapp]) | |
75 | 75 | ||
76 | 76 | ||
77 | 77 | func getEmissionAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgEmissionDapp]) | |
78 | 78 | ||
79 | 79 | ||
80 | 80 | func getStakingAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgStakingDapp]) | |
81 | 81 | ||
82 | 82 | ||
83 | 83 | func getGwxRewardAddressOrFail (factoryCfg) = addressFromStringValue(factoryCfg[IdxFactoryCfgGwxRewardDapp]) | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func keyConfig () = "%s__config" | |
87 | 87 | ||
88 | 88 | ||
89 | 89 | func keyRatePerBlockMaxCurrent () = "%s%s__ratePerBlockMax__current" | |
90 | 90 | ||
91 | 91 | ||
92 | 92 | func keyRatePerBlockMaxStartFrom (timestamp,block) = makeString(["%s%s%d%d__ratePerBlockMax__start", toString(timestamp), toString(block)], SEP) | |
93 | 93 | ||
94 | 94 | ||
95 | 95 | func keyRatePerBlockCurrent () = "%s%s__ratePerBlock__current" | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func keyRatePerBlockStartFrom (timestamp,block) = makeString(["%s%s%d%d__ratePerBlock__start", toString(timestamp), toString(block)], SEP) | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | func keyEmissionStartBlock () = "%s%s__emission__startBlock" | |
102 | 102 | ||
103 | 103 | ||
104 | 104 | func keyEmissionDurationInBlocks () = "%s%s__emission__duration" | |
105 | 105 | ||
106 | 106 | ||
107 | 107 | func keyEmissionEndBlock () = "%s%s__emission__endBlock" | |
108 | 108 | ||
109 | 109 | ||
110 | 110 | func keyBoostCoeff () = "%s__boostCoeff" | |
111 | 111 | ||
112 | 112 | ||
113 | 113 | let boostCoeffDefault = 3 | |
114 | 114 | ||
115 | 115 | let boostCoeff = valueOrElse(getInteger(this, keyBoostCoeff()), boostCoeffDefault) | |
116 | 116 | ||
117 | 117 | func keyGwxHoldersRewardCurrent () = "%s%s__gwxHoldersReward__current" | |
118 | 118 | ||
119 | 119 | ||
120 | 120 | func keyGwxHoldersRewardNext () = "%s%s__gwxHoldersReward__next" | |
121 | 121 | ||
122 | 122 | ||
123 | 123 | func keyManagerPublicKey () = "%s__managerPublicKey" | |
124 | 124 | ||
125 | 125 | ||
126 | 126 | func keyManagerVaultAddress () = "%s__managerVaultAddress" | |
127 | 127 | ||
128 | 128 | ||
129 | 129 | func getManagerVaultAddressOrThis () = match getString(keyManagerVaultAddress()) { | |
130 | 130 | case s: String => | |
131 | 131 | addressFromStringValue(s) | |
132 | 132 | case _ => | |
133 | 133 | this | |
134 | 134 | } | |
135 | 135 | ||
136 | 136 | ||
137 | 137 | func managerPublicKeyOrUnit () = { | |
138 | 138 | let managerVaultAddress = getManagerVaultAddressOrThis() | |
139 | 139 | match getString(managerVaultAddress, keyManagerPublicKey()) { | |
140 | 140 | case s: String => | |
141 | 141 | fromBase58String(s) | |
142 | 142 | case _: Unit => | |
143 | 143 | unit | |
144 | 144 | case _ => | |
145 | 145 | throw("Match error") | |
146 | 146 | } | |
147 | 147 | } | |
148 | 148 | ||
149 | 149 | ||
150 | 150 | func mustManager (i) = { | |
151 | 151 | let pd = throwErr("Permission denied") | |
152 | 152 | match managerPublicKeyOrUnit() { | |
153 | 153 | case pk: ByteVector => | |
154 | 154 | if ((i.callerPublicKey == pk)) | |
155 | 155 | then true | |
156 | 156 | else pd | |
157 | 157 | case _: Unit => | |
158 | 158 | if ((i.caller == this)) | |
159 | 159 | then true | |
160 | 160 | else pd | |
161 | 161 | case _ => | |
162 | 162 | throw("Match error") | |
163 | 163 | } | |
164 | 164 | } | |
165 | 165 | ||
166 | 166 | ||
167 | 167 | @Callable(i) | |
168 | 168 | func constructor (factoryAddress,ratePerBlockMax,ratePerBlock,emissionStartBlock,emissionDuration,emissionStartTimestamp,wxAssetIdStr) = { | |
169 | 169 | let checkCaller = mustManager(i) | |
170 | 170 | if ((checkCaller == checkCaller)) | |
171 | 171 | then [IntegerEntry(keyRatePerBlockMaxStartFrom(emissionStartTimestamp, emissionStartBlock), ratePerBlockMax), IntegerEntry(keyRatePerBlockMaxCurrent(), ratePerBlockMax), IntegerEntry(keyRatePerBlockStartFrom(emissionStartTimestamp, emissionStartBlock), ratePerBlock), IntegerEntry(keyRatePerBlockCurrent(), ratePerBlock), IntegerEntry(keyEmissionStartBlock(), emissionStartBlock), IntegerEntry(keyEmissionDurationInBlocks(), emissionDuration), IntegerEntry(keyEmissionEndBlock(), (emissionStartBlock + emissionDuration)), StringEntry(keyFactoryAddress(), factoryAddress), StringEntry(keyConfig(), ("%s__" + wxAssetIdStr))] | |
172 | 172 | else throw("Strict value is not equal to itself.") | |
173 | 173 | } | |
174 | 174 | ||
175 | 175 | ||
176 | 176 | ||
177 | 177 | @Callable(i) | |
178 | 178 | func constructorV2 (votingVerifiedContractPrm) = { | |
179 | 179 | let checkCaller = mustManager(i) | |
180 | 180 | if ((checkCaller == checkCaller)) | |
181 | 181 | then $Tuple2([StringEntry(keyVotingVerifiedContract, votingVerifiedContractPrm)], unit) | |
182 | 182 | else throw("Strict value is not equal to itself.") | |
183 | 183 | } | |
184 | 184 | ||
185 | 185 | ||
186 | 186 | ||
187 | 187 | @Callable(i) | |
188 | 188 | func emit (amount) = if ((0 >= amount)) | |
189 | 189 | then $Tuple2(nil, nil) | |
190 | 190 | else { | |
191 | 191 | let factoryContract = readFactoryAddressOrFail() | |
192 | 192 | let factoryCfg = readFactoryCfgOrFail(factoryContract) | |
193 | 193 | let stakingContract = getStakingAddressOrFail(factoryCfg) | |
194 | 194 | let gwxRewardsContract = getGwxRewardAddressOrFail(factoryCfg) | |
195 | 195 | let caller = i.caller | |
196 | 196 | if (if ((caller != stakingContract)) | |
197 | 197 | then (caller != gwxRewardsContract) | |
198 | 198 | else false) | |
199 | 199 | then throwErr("permissions denied") | |
200 | 200 | else { | |
201 | 201 | let wxAssetIdStr = split(getStringOrFail(this, keyConfig()), SEP)[1] | |
202 | 202 | let wxAssetId = fromBase58String(wxAssetIdStr) | |
203 | 203 | $Tuple2([ScriptTransfer(caller, amount, wxAssetId)], [wxAssetId]) | |
204 | 204 | } | |
205 | 205 | } | |
206 | 206 | ||
207 | 207 | ||
208 | 208 | ||
209 | 209 | @Callable(i) | |
210 | 210 | func burn () = { | |
211 | 211 | let factoryContract = readFactoryAddressOrFail() | |
212 | 212 | let factoryCfg = readFactoryCfgOrFail(factoryContract) | |
213 | 213 | let boostingContract = getBoostingAddressOrFail(factoryCfg) | |
214 | 214 | if ((size(i.payments) != 1)) | |
215 | 215 | then throwErr("exact one payment is allowed") | |
216 | 216 | else { | |
217 | 217 | let pmt = i.payments[0] | |
218 | 218 | let assetId = value(pmt.assetId) | |
219 | 219 | let pmtAmount = pmt.amount | |
220 | 220 | let wxAssetId = fromBase58String(split(getStringOrFail(this, keyConfig()), SEP)[1]) | |
221 | 221 | if ((assetId != wxAssetId)) | |
222 | 222 | then throwErr("invalid wxAssetId is passed") | |
223 | 223 | else if (!(containsElement([boostingContract, votingVerifiedContract, votingEmissionCandidateContract, userPoolsContract], i.caller))) | |
224 | 224 | then throwErr("permissions denied") | |
225 | 225 | else [Burn(assetId, pmtAmount), StringEntry(("%s%s%s__history__burn__" + toBase58String(i.transactionId)), makeString(["%d%d%d", toString(height), toString(lastBlock.timestamp), toString(pmtAmount)], SEP))] | |
226 | 226 | } | |
227 | 227 | } | |
228 | 228 | ||
229 | 229 | ||
230 | 230 | ||
231 | 231 | @Callable(i) | |
232 | 232 | func gwxHoldersRewardUpdate () = { | |
233 | 233 | let factoryContract = readFactoryAddressOrFail() | |
234 | 234 | let factoryCfg = readFactoryCfgOrFail(factoryContract) | |
235 | 235 | let gwxRewardsContract = getGwxRewardAddressOrFail(factoryCfg) | |
236 | 236 | let checkCaller = if ((i.caller == gwxRewardsContract)) | |
237 | 237 | then true | |
238 | 238 | else mustManager(i) | |
239 | 239 | if ((checkCaller == checkCaller)) | |
240 | 240 | then { | |
241 | 241 | let gwxHolderRewardCurrent = valueOrElse(getInteger(keyGwxHoldersRewardCurrent()), 0) | |
242 | 242 | let gwxHolderRewardNext = valueOrElse(getInteger(keyGwxHoldersRewardNext()), gwxHolderRewardCurrent) | |
243 | 243 | let shouldBeUpdated = (gwxHolderRewardCurrent != gwxHolderRewardNext) | |
244 | 244 | let actions = if (shouldBeUpdated) | |
245 | 245 | then [IntegerEntry(keyGwxHoldersRewardCurrent(), gwxHolderRewardNext), DeleteEntry(keyGwxHoldersRewardNext())] | |
246 | 246 | else nil | |
247 | 247 | $Tuple2(actions, shouldBeUpdated) | |
248 | 248 | } | |
249 | 249 | else throw("Strict value is not equal to itself.") | |
250 | 250 | } | |
251 | 251 | ||
252 | 252 | ||
253 | 253 | ||
254 | 254 | @Callable(i) | |
255 | 255 | func getBoostCoeffREADONLY () = $Tuple2(nil, boostCoeff) | |
256 | 256 | ||
257 | 257 | ||
258 | 258 | ||
259 | 259 | @Callable(i) | |
260 | - | func | |
261 | - | let check = if ((i.caller == | |
260 | + | func changeRatePerBlock (newRatePerBlock) = { | |
261 | + | let check = if ((i.caller == votingEmissionRateContract)) | |
262 | 262 | then true | |
263 | 263 | else throwErr("should be invoked internally") | |
264 | 264 | if ((check == check)) | |
265 | 265 | then { | |
266 | 266 | let blockTimestamp = match blockInfoByHeight(height) { | |
267 | 267 | case bi: BlockInfo => | |
268 | 268 | bi.timestamp | |
269 | 269 | case _ => | |
270 | 270 | throwErr("BlockInfo.timestamp error") | |
271 | 271 | } | |
272 | 272 | [IntegerEntry(keyRatePerBlockStartFrom(blockTimestamp, height), newRatePerBlock), IntegerEntry(keyRatePerBlockCurrent(), newRatePerBlock)] | |
273 | - | } | |
274 | - | else throw("Strict value is not equal to itself.") | |
275 | - | } | |
276 | - | ||
277 | - | ||
278 | - | ||
279 | - | @Callable(i) | |
280 | - | func changeRatePerBlock (newRatePerBlock) = { | |
281 | - | let check = if ((i.caller == votingEmissionRateContract)) | |
282 | - | then true | |
283 | - | else mustManager(i) | |
284 | - | if ((check == check)) | |
285 | - | then { | |
286 | - | let factoryContract = readFactoryAddressOrFail() | |
287 | - | let factoryCfg = readFactoryCfgOrFail(factoryContract) | |
288 | - | let boostingContract = getBoostingAddressOrFail(factoryCfg) | |
289 | - | let changeRate = invoke(this, "changeRatePerBlockINTERNAL", [newRatePerBlock], nil) | |
290 | - | if ((changeRate == changeRate)) | |
291 | - | then { | |
292 | - | let boostinEmissionUpdate = invoke(boostingContract, "onBoostEmissionUpdate", nil, nil) | |
293 | - | if ((boostinEmissionUpdate == boostinEmissionUpdate)) | |
294 | - | then nil | |
295 | - | else throw("Strict value is not equal to itself.") | |
296 | - | } | |
297 | - | else throw("Strict value is not equal to itself.") | |
298 | 273 | } | |
299 | 274 | else throw("Strict value is not equal to itself.") | |
300 | 275 | } | |
301 | 276 | ||
302 | 277 | ||
303 | 278 | @Verifier(tx) | |
304 | 279 | func verify () = { | |
305 | 280 | let targetPublicKey = match managerPublicKeyOrUnit() { | |
306 | 281 | case pk: ByteVector => | |
307 | 282 | pk | |
308 | 283 | case _: Unit => | |
309 | 284 | tx.senderPublicKey | |
310 | 285 | case _ => | |
311 | 286 | throw("Match error") | |
312 | 287 | } | |
313 | 288 | sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey) | |
314 | 289 | } | |
315 | 290 |
github/deemru/w8io/026f985 36.49 ms ◑