tx · Ga8ix3Wcaf4Hr4JJR7B1r4T3TtmjmwKU4yRqNorkHQGZ 3N1HdGqmcf4nVsUgmWiwB8p6p8ErWBmvQua: -0.01000000 Waves 2023.11.16 15:43 [2845952] smart account 3N1HdGqmcf4nVsUgmWiwB8p6p8ErWBmvQua > SELF 0.00000000 Waves
{ "type": 13, "id": "Ga8ix3Wcaf4Hr4JJR7B1r4T3TtmjmwKU4yRqNorkHQGZ", "fee": 1000000, "feeAssetId": null, "timestamp": 1700138659692, "version": 2, "chainId": 84, "sender": "3N1HdGqmcf4nVsUgmWiwB8p6p8ErWBmvQua", "senderPublicKey": "JAEVvs5E9kGyXWx3YQaivUpUP3vb3pgr2eS6UrYr1A8P", "proofs": [ "eaiDtjvXCH6QToxjBgX4QDLWpjmFNBgwJYrfQwHuGFHzFdvjrXJHSCnrC8FZT2WrD6n44cM21Kf9rj39kXAGyKq" ], "script": "base64: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", "height": 2845952, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Gr3wQvFqWEQmDpPUeQnfFazxu5tqRDW1agfzAVU15tTc Next: 4Dqtd1ucyeBYQGnhd2rjxCgyLSiKGrYLdSKynpGHaN5A Diff:
Old | New | Differences | |
---|---|---|---|
12 | 12 | let DENOMINATOR = 1000000000000000000 | |
13 | 13 | ||
14 | 14 | func userDepositedKey (user) = makeString(["ud", toBase58String(user.bytes)], SEP) | |
15 | - | ||
16 | - | ||
17 | - | func userUpdateKey (user) = makeString(["uu", toBase58String(user.bytes)], SEP) | |
18 | 15 | ||
19 | 16 | ||
20 | 17 | func totalDepositedKey () = "td" | |
115 | 112 | 0 | |
116 | 113 | } | |
117 | 114 | let earnedTokens = toInt(earned(i.caller)) | |
118 | - | [IntegerEntry(userDepositedKey(i.caller), 0), IntegerEntry(totalDepositedKey(), (totalDeposited - userDeposited)), IntegerEntry(lastUpdateKey(), lastBlock.timestamp), ScriptTransfer(i.caller, userDeposited, STAKE_ASSET), ScriptTransfer(i.caller, earnedTokens, EARN_ASSET), StringEntry(rewardPerTokenStoredKey(), toString(calcRewardPerTokenStored())), StringEntry(userRewardPerTokenPaidKey(i.caller), toString(calcRewardPerTokenStored())), IntegerEntry(userRewards(i.caller), 0)] | |
115 | + | if ((userDeposited == 0)) | |
116 | + | then throw("empty deposit") | |
117 | + | else [IntegerEntry(userDepositedKey(i.caller), 0), IntegerEntry(totalDepositedKey(), (totalDeposited - userDeposited)), IntegerEntry(lastUpdateKey(), lastBlock.timestamp), ScriptTransfer(i.caller, userDeposited, STAKE_ASSET), ScriptTransfer(i.caller, earnedTokens, EARN_ASSET), StringEntry(rewardPerTokenStoredKey(), toString(calcRewardPerTokenStored())), StringEntry(userRewardPerTokenPaidKey(i.caller), toString(calcRewardPerTokenStored())), IntegerEntry(userRewards(i.caller), 0)] | |
119 | 118 | } | |
120 | 119 | ||
121 | 120 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let STAKE_ASSET = base58'HuV7L2uJ4v2SDS5xqZLWPHhimTUgEMKstmxwfBY17SX3' | |
5 | 5 | ||
6 | 6 | let EARN_ASSET = base58'HuV7L2uJ4v2SDS5xqZLWPHhimTUgEMKstmxwfBY17SX3' | |
7 | 7 | ||
8 | 8 | let TOKENS_PER_MS = 1 | |
9 | 9 | ||
10 | 10 | let SEP = "__" | |
11 | 11 | ||
12 | 12 | let DENOMINATOR = 1000000000000000000 | |
13 | 13 | ||
14 | 14 | func userDepositedKey (user) = makeString(["ud", toBase58String(user.bytes)], SEP) | |
15 | - | ||
16 | - | ||
17 | - | func userUpdateKey (user) = makeString(["uu", toBase58String(user.bytes)], SEP) | |
18 | 15 | ||
19 | 16 | ||
20 | 17 | func totalDepositedKey () = "td" | |
21 | 18 | ||
22 | 19 | ||
23 | 20 | func lastUpdateKey () = "lu" | |
24 | 21 | ||
25 | 22 | ||
26 | 23 | func rewardPerTokenStoredKey () = "rpts" | |
27 | 24 | ||
28 | 25 | ||
29 | 26 | func userRewardPerTokenPaidKey (user) = makeString(["urpd", toBase58String(user.bytes)], SEP) | |
30 | 27 | ||
31 | 28 | ||
32 | 29 | func userRewards (user) = makeString(["ur", toBase58String(user.bytes)], SEP) | |
33 | 30 | ||
34 | 31 | ||
35 | 32 | func calcRewardPerTokenStored () = { | |
36 | 33 | let totalDeposited = toBigInt( match getInteger(totalDepositedKey()) { | |
37 | 34 | case a: Int => | |
38 | 35 | a | |
39 | 36 | case _ => | |
40 | 37 | 0 | |
41 | 38 | }) | |
42 | 39 | let lastUpdate = toBigInt( match getInteger(lastUpdateKey()) { | |
43 | 40 | case a: Int => | |
44 | 41 | a | |
45 | 42 | case _ => | |
46 | 43 | lastBlock.timestamp | |
47 | 44 | }) | |
48 | 45 | let rewardPerTokenStored = parseBigIntValue( match getString(rewardPerTokenStoredKey()) { | |
49 | 46 | case a: String => | |
50 | 47 | a | |
51 | 48 | case _ => | |
52 | 49 | "0" | |
53 | 50 | }) | |
54 | 51 | if ((totalDeposited == toBigInt(0))) | |
55 | 52 | then rewardPerTokenStored | |
56 | 53 | else (rewardPerTokenStored + (((toBigInt(TOKENS_PER_MS) * (toBigInt(lastBlock.timestamp) - lastUpdate)) * toBigInt(DENOMINATOR)) / totalDeposited)) | |
57 | 54 | } | |
58 | 55 | ||
59 | 56 | ||
60 | 57 | func earned (user) = { | |
61 | 58 | let userDeposited = toBigInt( match getInteger(userDepositedKey(user)) { | |
62 | 59 | case a: Int => | |
63 | 60 | a | |
64 | 61 | case _ => | |
65 | 62 | 0 | |
66 | 63 | }) | |
67 | 64 | let userRewardPerTokenPaid = parseBigIntValue(getStringValue(userRewardPerTokenPaidKey(user))) | |
68 | 65 | let rewards = toBigInt( match getInteger(userRewards(user)) { | |
69 | 66 | case a: Int => | |
70 | 67 | a | |
71 | 68 | case _ => | |
72 | 69 | 0 | |
73 | 70 | }) | |
74 | 71 | (fraction(userDeposited, (calcRewardPerTokenStored() - userRewardPerTokenPaid), toBigInt(DENOMINATOR)) + rewards) | |
75 | 72 | } | |
76 | 73 | ||
77 | 74 | ||
78 | 75 | @Callable(i) | |
79 | 76 | func deposit () = if (if ((size(i.payments) != 1)) | |
80 | 77 | then true | |
81 | 78 | else (i.payments[0].assetId != STAKE_ASSET)) | |
82 | 79 | then throw("incorrect asset deposits") | |
83 | 80 | else { | |
84 | 81 | let userDeposited = match getInteger(userDepositedKey(i.caller)) { | |
85 | 82 | case a: Int => | |
86 | 83 | a | |
87 | 84 | case _ => | |
88 | 85 | 0 | |
89 | 86 | } | |
90 | 87 | let totalDeposited = match getInteger(totalDepositedKey()) { | |
91 | 88 | case a: Int => | |
92 | 89 | a | |
93 | 90 | case _ => | |
94 | 91 | 0 | |
95 | 92 | } | |
96 | 93 | [IntegerEntry(userDepositedKey(i.caller), (userDeposited + i.payments[0].amount)), IntegerEntry(totalDepositedKey(), (totalDeposited + i.payments[0].amount)), IntegerEntry(lastUpdateKey(), lastBlock.timestamp), StringEntry(rewardPerTokenStoredKey(), toString(calcRewardPerTokenStored())), StringEntry(userRewardPerTokenPaidKey(i.caller), toString(calcRewardPerTokenStored())), IntegerEntry(userRewards(i.caller), if ((userDeposited == 0)) | |
97 | 94 | then 0 | |
98 | 95 | else toInt(earned(i.caller)))] | |
99 | 96 | } | |
100 | 97 | ||
101 | 98 | ||
102 | 99 | ||
103 | 100 | @Callable(i) | |
104 | 101 | func withdraw () = { | |
105 | 102 | let userDeposited = match getInteger(userDepositedKey(i.caller)) { | |
106 | 103 | case a: Int => | |
107 | 104 | a | |
108 | 105 | case _ => | |
109 | 106 | 0 | |
110 | 107 | } | |
111 | 108 | let totalDeposited = match getInteger(totalDepositedKey()) { | |
112 | 109 | case a: Int => | |
113 | 110 | a | |
114 | 111 | case _ => | |
115 | 112 | 0 | |
116 | 113 | } | |
117 | 114 | let earnedTokens = toInt(earned(i.caller)) | |
118 | - | [IntegerEntry(userDepositedKey(i.caller), 0), IntegerEntry(totalDepositedKey(), (totalDeposited - userDeposited)), IntegerEntry(lastUpdateKey(), lastBlock.timestamp), ScriptTransfer(i.caller, userDeposited, STAKE_ASSET), ScriptTransfer(i.caller, earnedTokens, EARN_ASSET), StringEntry(rewardPerTokenStoredKey(), toString(calcRewardPerTokenStored())), StringEntry(userRewardPerTokenPaidKey(i.caller), toString(calcRewardPerTokenStored())), IntegerEntry(userRewards(i.caller), 0)] | |
115 | + | if ((userDeposited == 0)) | |
116 | + | then throw("empty deposit") | |
117 | + | else [IntegerEntry(userDepositedKey(i.caller), 0), IntegerEntry(totalDepositedKey(), (totalDeposited - userDeposited)), IntegerEntry(lastUpdateKey(), lastBlock.timestamp), ScriptTransfer(i.caller, userDeposited, STAKE_ASSET), ScriptTransfer(i.caller, earnedTokens, EARN_ASSET), StringEntry(rewardPerTokenStoredKey(), toString(calcRewardPerTokenStored())), StringEntry(userRewardPerTokenPaidKey(i.caller), toString(calcRewardPerTokenStored())), IntegerEntry(userRewards(i.caller), 0)] | |
119 | 118 | } | |
120 | 119 | ||
121 | 120 | ||
122 | 121 | @Verifier(tx) | |
123 | 122 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
124 | 123 |
github/deemru/w8io/026f985 35.04 ms ◑