tx · ErFjhyvLFTXt87jxA11UEXFmp3H866ksP12rZSc9Dmzc 3MuKEDU6qPggcs65swNH6JcUbS7hB6jVzrA: -0.01000000 Waves 2023.09.19 17:28 [2762384] smart account 3MuKEDU6qPggcs65swNH6JcUbS7hB6jVzrA > SELF 0.00000000 Waves
{ "type": 13, "id": "ErFjhyvLFTXt87jxA11UEXFmp3H866ksP12rZSc9Dmzc", "fee": 1000000, "feeAssetId": null, "timestamp": 1695133722350, "version": 2, "chainId": 84, "sender": "3MuKEDU6qPggcs65swNH6JcUbS7hB6jVzrA", "senderPublicKey": "GkZtgtQPEtE9JoxK1tzKc1t7uw12vz6aqKhDcBi136yV", "proofs": [ "2hp6D2Tti6bRSekgX9tsA2tyq92zJdVyduJB7ept5gzkLiLtyvFAjiaKbokzhMdmESFhTQ37XSTYLd4F6YDF4XFD" ], "script": "base64:BgIVCAISABIDCgEBEgQKAgICEgQKAgEEEQADU0VQAgJfXwAPcmVwdXRhdGlvbkFzc2V0ASBxggycON8pyCFInplKujKGtzqQhMOf+vAbfdt6zmK1aAAMcHJvcG9zYWxUaW1lCQBoAgkAaAIJAGgCCQBoAgDoBwA8ADwAGAADARFjb3VudFByb3Bvc2Fsc0tleQACAmNwAQtwcm9wb3NhbEtleQEKcHJvcG9zYWxJZAkAuQkCCQDMCAICAXAJAMwIAgkApAMBBQpwcm9wb3NhbElkBQNuaWwFA1NFUAESdW5sb2NrVGltZXN0YW1wS2V5AQR1c2VyCQC5CQIJAMwIAgICdXQJAMwIAgkA2AQBCAUEdXNlcgVieXRlcwUDbmlsBQNTRVABEHVzZXJEZXBvc2l0ZWRLZXkBBHVzZXIJALkJAgkAzAgCAgJ1ZAkAzAgCCQDYBAEIBQR1c2VyBWJ5dGVzBQNuaWwFA1NFUAETdXNlclByb3Bvc2FsVm90ZUtleQIKcHJvcG9zYWxJZAR1c2VyCQC5CQIJAMwIAgICdXAJAMwIAgkApAMBBQpwcm9wb3NhbElkCQDMCAIJANgEAQgFBHVzZXIFYnl0ZXMFA25pbAUDU0VQAQtzZXRVc2VyVm90ZQMKcHJvcG9zYWxJZAR1c2VyCXZvdGVQb3dlcgkBDEludGVnZXJFbnRyeQIJARN1c2VyUHJvcG9zYWxWb3RlS2V5AgUKcHJvcG9zYWxJZAUEdXNlcgUJdm90ZVBvd2VyAQtnZXRVc2VyVm90ZQIKcHJvcG9zYWxJZAR1c2VyBAckbWF0Y2gwCQCfCAEJARN1c2VyUHJvcG9zYWxWb3RlS2V5AgUKcHJvcG9zYWxJZAUEdXNlcgMJAAECBQckbWF0Y2gwAgNJbnQEAWkFByRtYXRjaDAFAWkAAAELc2V0UHJvcG9zYWwHAmlkB2NyZWF0b3IFdGl0bGUEdGV4dBF0aW1lc3RhbXBDcmVhdGlvbg1jb3VudFZvdGVzRm9yEUNvdW50Vm90ZXNBZ2FpbnN0CQELU3RyaW5nRW50cnkCCQELcHJvcG9zYWxLZXkBBQJpZAkAuwkCCQDMCAIJANwEAQgFB2NyZWF0b3IFYnl0ZXMJAMwIAgUFdGl0bGUJAMwIAgUEdGV4dAkAzAgCCQCkAwEFEXRpbWVzdGFtcENyZWF0aW9uCQDMCAIJAKQDAQUNY291bnRWb3Rlc0ZvcgkAzAgCCQCkAwEFEUNvdW50Vm90ZXNBZ2FpbnN0BQNuaWwFA1NFUAELZ2V0UHJvcG9zYWwBAmlkBAtzYXZlZFN0cmluZwkAtQkCBAckbWF0Y2gwCQCdCAIFBHRoaXMJAQtwcm9wb3NhbEtleQEFAmlkAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAUBcwkAAgECEnByb3Bvc2FsIG5vdCBmb3VuZAUDU0VQCQCYCgYJAQdBZGRyZXNzAQkA3QQBCQCRAwIFC3NhdmVkU3RyaW5nAAAJAJEDAgULc2F2ZWRTdHJpbmcAAQkAkQMCBQtzYXZlZFN0cmluZwACCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgULc2F2ZWRTdHJpbmcAAwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFC3NhdmVkU3RyaW5nAAQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQtzYXZlZFN0cmluZwAFARRpc1BheVJlcHV0YXRpb25Bc3NldAEBaQMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEDCQAAAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQ9yZXB1dGF0aW9uQXNzZXQGCQACAQIWb25seSByZXB1dGF0aW9uIGFzc2V0cwkAAgECDm9ubHkgMSBwYXltZW50ARJnZXRVbmxvY2tUaW1lc3RhbXABBHVzZXIEByRtYXRjaDAJAJoIAgUEdGhpcwkBEnVubG9ja1RpbWVzdGFtcEtleQEFBHVzZXIDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhAAABDmNvdW50UHJvcG9zYWxzAAQHJG1hdGNoMAkAmggCBQR0aGlzCQERY291bnRQcm9wb3NhbHNLZXkAAwkAAQIFByRtYXRjaDACA0ludAQBYQUHJG1hdGNoMAUBYQAAARx1c2VyRGVwb3NpdGVkUmVwdXRhdGlvbkFzc2V0AQR1c2VyBAckbWF0Y2gwCQCaCAIFBHRoaXMJARB1c2VyRGVwb3NpdGVkS2V5AQUEdXNlcgMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEAAAEPaXNQcm9wb3NhbEFsaXZlAQJpZAMDCQBmAgkBDmNvdW50UHJvcG9zYWxzAAUCaWQJAGYCCQBkAggJAQtnZXRQcm9wb3NhbAEFAmlkAl80BQxwcm9wb3NhbFRpbWUIBQlsYXN0QmxvY2sJdGltZXN0YW1wBwYJAAIBAhJwcm9wb3NhbCBub3QgYWxpdmUEAWkBB2RlcG9zaXQABAZjaGVja3MJAMwIAgkBFGlzUGF5UmVwdXRhdGlvbkFzc2V0AQUBaQUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBA1jdXJyZW50QW1vdW50CQEcdXNlckRlcG9zaXRlZFJlcHV0YXRpb25Bc3NldAEIBQFpBmNhbGxlcgQJbmV3QW1vdW50CQBkAgUNY3VycmVudEFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJARB1c2VyRGVwb3NpdGVkS2V5AQgFAWkGY2FsbGVyBQluZXdBbW91bnQFA25pbAkAAgECE29ubHlSZXB1dGF0aW9uQXNzZXQBaQEId2l0aGRyYXcBBmFtb3VudAQKY3VycmVudEtleQkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBA1jdXJyZW50QW1vdW50BAckbWF0Y2gwCQCaCAIFBHRoaXMFCmN1cnJlbnRLZXkDCQABAgUHJG1hdGNoMAIDSW50BAFhBQckbWF0Y2gwBQFhAAAECW5ld0Ftb3VudAkAZQIFDWN1cnJlbnRBbW91bnQFBmFtb3VudAMJAGYCAAAFBmFtb3VudAkAAgECHkNhbid0IHdpdGhkcmF3IG5lZ2F0aXZlIGFtb3VudAMJAGYCCQESZ2V0VW5sb2NrVGltZXN0YW1wAQgFAWkGY2FsbGVyCAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAAgECBkxvY2tlZAMJAGYCAAAFCW5ld0Ftb3VudAkAAgECEk5vdCBlbm91Z2ggYmFsYW5jZQkAzAgCCQEMSW50ZWdlckVudHJ5AgUKY3VycmVudEtleQUJbmV3QW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUGYW1vdW50BQ9yZXB1dGF0aW9uQXNzZXQFA25pbAFpAQ5jcmVhdGVQcm9wb3NhbAIFdGl0bGUEdGV4dAQFY291bnQJAQ5jb3VudFByb3Bvc2FscwAJAMwIAgkBC3NldFByb3Bvc2FsBwUFY291bnQIBQFpBmNhbGxlcgkA3AQBBQV0aXRsZQkA3AQBBQR0ZXh0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAAAAAAJAMwIAgkBDEludGVnZXJFbnRyeQIJARFjb3VudFByb3Bvc2Fsc0tleQAJAGQCBQVjb3VudAABBQNuaWwBaQEEdm90ZQIKcHJvcG9zYWxJZAR2b3RlAwkBASEBCQEPaXNQcm9wb3NhbEFsaXZlAQUKcHJvcG9zYWxJZAkAAgECEHByb3Bvc2FsTm90QWxpdmUECHByb3Bvc2FsCQELZ2V0UHJvcG9zYWwBBQpwcm9wb3NhbElkBAp1bmxvY2tUaW1lCQCWAwEJAMwIAgkAZAIIBQhwcm9wb3NhbAJfNAUMcHJvcG9zYWxUaW1lCQDMCAIJARJnZXRVbmxvY2tUaW1lc3RhbXABCAUBaQZjYWxsZXIFA25pbAQLcHJldml1c1ZvdGUJAQtnZXRVc2VyVm90ZQIFCnByb3Bvc2FsSWQIBQFpBmNhbGxlcgQJdm90ZVBvd2VyCQEcdXNlckRlcG9zaXRlZFJlcHV0YXRpb25Bc3NldAEIBQFpBmNhbGxlcgQIbWludXNGb3IDCQBmAgULcHJldml1c1ZvdGUAAAULcHJldml1c1ZvdGUAAAQMbWludXNBZ2FpbnN0AwkAZgIAAAULcHJldml1c1ZvdGUJAQEtAQULcHJldml1c1ZvdGUAAAQHcGx1c0ZvcgMJAAACBQR2b3RlBgUJdm90ZVBvd2VyAAAEC3BsdXNBZ2FpbnN0AwkAAAIFBHZvdGUHBQl2b3RlUG93ZXIAAAkAzAgCCQELc2V0UHJvcG9zYWwHBQpwcm9wb3NhbElkCAUIcHJvcG9zYWwCXzEIBQhwcm9wb3NhbAJfMggFCHByb3Bvc2FsAl8zCAUIcHJvcG9zYWwCXzQJAGQCCQBlAggFCHByb3Bvc2FsAl81BQhtaW51c0ZvcgUHcGx1c0ZvcgkAZAIJAGUCCAUIcHJvcG9zYWwCXzYFDG1pbnVzQWdhaW5zdAULcGx1c0FnYWluc3QJAMwIAgkBC3NldFVzZXJWb3RlAwUKcHJvcG9zYWxJZAgFAWkGY2FsbGVyAwUEdm90ZQUJdm90ZVBvd2VyCQEBLQEFCXZvdGVQb3dlcgUDbmlsAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tledwpBLE=", "height": 2762384, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 7hVSb8mFdo14WiYKTaaSAZuzY2ju6fntxzePnbqxUFei Next: 92rS1K9D8PFPHGBwYBtD5rQc5bWvTCckzSREn3grWZUu Diff:
Old | New | Differences | |
---|---|---|---|
22 | 22 | func userProposalVoteKey (proposalId,user) = makeString(["up", toString(proposalId), toBase58String(user.bytes)], SEP) | |
23 | 23 | ||
24 | 24 | ||
25 | - | func setUserVote (proposalId,user,votePower) = | |
25 | + | func setUserVote (proposalId,user,votePower) = IntegerEntry(userProposalVoteKey(proposalId, user), votePower) | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func getUserVote (proposalId,user) = match getInteger(userProposalVoteKey(proposalId, user)) { |
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 | let reputationAsset = base58'8e65zYSAcGfmQnVX462UEMWf6PmHgtckyGcrEMXKZZaF' | |
7 | 7 | ||
8 | 8 | let proposalTime = ((((1000 * 60) * 60) * 24) * 3) | |
9 | 9 | ||
10 | 10 | func countProposalsKey () = "cp" | |
11 | 11 | ||
12 | 12 | ||
13 | 13 | func proposalKey (proposalId) = makeString(["p", toString(proposalId)], SEP) | |
14 | 14 | ||
15 | 15 | ||
16 | 16 | func unlockTimestampKey (user) = makeString(["ut", toBase58String(user.bytes)], SEP) | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | func userDepositedKey (user) = makeString(["ud", toBase58String(user.bytes)], SEP) | |
20 | 20 | ||
21 | 21 | ||
22 | 22 | func userProposalVoteKey (proposalId,user) = makeString(["up", toString(proposalId), toBase58String(user.bytes)], SEP) | |
23 | 23 | ||
24 | 24 | ||
25 | - | func setUserVote (proposalId,user,votePower) = | |
25 | + | func setUserVote (proposalId,user,votePower) = IntegerEntry(userProposalVoteKey(proposalId, user), votePower) | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func getUserVote (proposalId,user) = match getInteger(userProposalVoteKey(proposalId, user)) { | |
29 | 29 | case i: Int => | |
30 | 30 | i | |
31 | 31 | case _ => | |
32 | 32 | 0 | |
33 | 33 | } | |
34 | 34 | ||
35 | 35 | ||
36 | 36 | func setProposal (id,creator,title,text,timestampCreation,countVotesFor,CountVotesAgainst) = StringEntry(proposalKey(id), makeString_11C([toBase16String(creator.bytes), title, text, toString(timestampCreation), toString(countVotesFor), toString(CountVotesAgainst)], SEP)) | |
37 | 37 | ||
38 | 38 | ||
39 | 39 | func getProposal (id) = { | |
40 | 40 | let savedString = split( match getString(this, proposalKey(id)) { | |
41 | 41 | case s: String => | |
42 | 42 | s | |
43 | 43 | case _ => | |
44 | 44 | throw("proposal not found") | |
45 | 45 | }, SEP) | |
46 | 46 | $Tuple6(Address(fromBase16String(savedString[0])), savedString[1], savedString[2], parseIntValue(savedString[3]), parseIntValue(savedString[4]), parseIntValue(savedString[5])) | |
47 | 47 | } | |
48 | 48 | ||
49 | 49 | ||
50 | 50 | func isPayReputationAsset (i) = if ((size(i.payments) == 1)) | |
51 | 51 | then if ((i.payments[0].assetId == reputationAsset)) | |
52 | 52 | then true | |
53 | 53 | else throw("only reputation assets") | |
54 | 54 | else throw("only 1 payment") | |
55 | 55 | ||
56 | 56 | ||
57 | 57 | func getUnlockTimestamp (user) = match getInteger(this, unlockTimestampKey(user)) { | |
58 | 58 | case a: Int => | |
59 | 59 | a | |
60 | 60 | case _ => | |
61 | 61 | 0 | |
62 | 62 | } | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | func countProposals () = match getInteger(this, countProposalsKey()) { | |
66 | 66 | case a: Int => | |
67 | 67 | a | |
68 | 68 | case _ => | |
69 | 69 | 0 | |
70 | 70 | } | |
71 | 71 | ||
72 | 72 | ||
73 | 73 | func userDepositedReputationAsset (user) = match getInteger(this, userDepositedKey(user)) { | |
74 | 74 | case a: Int => | |
75 | 75 | a | |
76 | 76 | case _ => | |
77 | 77 | 0 | |
78 | 78 | } | |
79 | 79 | ||
80 | 80 | ||
81 | 81 | func isProposalAlive (id) = if (if ((countProposals() > id)) | |
82 | 82 | then ((getProposal(id)._4 + proposalTime) > lastBlock.timestamp) | |
83 | 83 | else false) | |
84 | 84 | then true | |
85 | 85 | else throw("proposal not alive") | |
86 | 86 | ||
87 | 87 | ||
88 | 88 | @Callable(i) | |
89 | 89 | func deposit () = { | |
90 | 90 | let checks = [isPayReputationAsset(i)] | |
91 | 91 | if ((checks == checks)) | |
92 | 92 | then { | |
93 | 93 | let currentAmount = userDepositedReputationAsset(i.caller) | |
94 | 94 | let newAmount = (currentAmount + i.payments[0].amount) | |
95 | 95 | [IntegerEntry(userDepositedKey(i.caller), newAmount)] | |
96 | 96 | } | |
97 | 97 | else throw("onlyReputationAsset") | |
98 | 98 | } | |
99 | 99 | ||
100 | 100 | ||
101 | 101 | ||
102 | 102 | @Callable(i) | |
103 | 103 | func withdraw (amount) = { | |
104 | 104 | let currentKey = toBase58String(i.caller.bytes) | |
105 | 105 | let currentAmount = match getInteger(this, currentKey) { | |
106 | 106 | case a: Int => | |
107 | 107 | a | |
108 | 108 | case _ => | |
109 | 109 | 0 | |
110 | 110 | } | |
111 | 111 | let newAmount = (currentAmount - amount) | |
112 | 112 | if ((0 > amount)) | |
113 | 113 | then throw("Can't withdraw negative amount") | |
114 | 114 | else if ((getUnlockTimestamp(i.caller) > lastBlock.timestamp)) | |
115 | 115 | then throw("Locked") | |
116 | 116 | else if ((0 > newAmount)) | |
117 | 117 | then throw("Not enough balance") | |
118 | 118 | else [IntegerEntry(currentKey, newAmount), ScriptTransfer(i.caller, amount, reputationAsset)] | |
119 | 119 | } | |
120 | 120 | ||
121 | 121 | ||
122 | 122 | ||
123 | 123 | @Callable(i) | |
124 | 124 | func createProposal (title,text) = { | |
125 | 125 | let count = countProposals() | |
126 | 126 | [setProposal(count, i.caller, toBase16String(title), toBase16String(text), lastBlock.timestamp, 0, 0), IntegerEntry(countProposalsKey(), (count + 1))] | |
127 | 127 | } | |
128 | 128 | ||
129 | 129 | ||
130 | 130 | ||
131 | 131 | @Callable(i) | |
132 | 132 | func vote (proposalId,vote) = if (!(isProposalAlive(proposalId))) | |
133 | 133 | then throw("proposalNotAlive") | |
134 | 134 | else { | |
135 | 135 | let proposal = getProposal(proposalId) | |
136 | 136 | let unlockTime = max([(proposal._4 + proposalTime), getUnlockTimestamp(i.caller)]) | |
137 | 137 | let previusVote = getUserVote(proposalId, i.caller) | |
138 | 138 | let votePower = userDepositedReputationAsset(i.caller) | |
139 | 139 | let minusFor = if ((previusVote > 0)) | |
140 | 140 | then previusVote | |
141 | 141 | else 0 | |
142 | 142 | let minusAgainst = if ((0 > previusVote)) | |
143 | 143 | then -(previusVote) | |
144 | 144 | else 0 | |
145 | 145 | let plusFor = if ((vote == true)) | |
146 | 146 | then votePower | |
147 | 147 | else 0 | |
148 | 148 | let plusAgainst = if ((vote == false)) | |
149 | 149 | then votePower | |
150 | 150 | else 0 | |
151 | 151 | [setProposal(proposalId, proposal._1, proposal._2, proposal._3, proposal._4, ((proposal._5 - minusFor) + plusFor), ((proposal._6 - minusAgainst) + plusAgainst)), setUserVote(proposalId, i.caller, if (vote) | |
152 | 152 | then votePower | |
153 | 153 | else -(votePower))] | |
154 | 154 | } | |
155 | 155 | ||
156 | 156 | ||
157 | 157 | @Verifier(tx) | |
158 | 158 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
159 | 159 |
github/deemru/w8io/169f3d6 56.16 ms ◑