tx · EimoFtcNNyPzTdYy5SuXEASYAii5yUfiSuDZLcgxtv2s 3MtV1AQ8fEPk76tjKgvrufuMe5aA3q4TviQ: -0.10000000 Waves 2020.12.23 02:37 [1320571] smart account 3MtV1AQ8fEPk76tjKgvrufuMe5aA3q4TviQ > SELF 0.00000000 Waves
{ "type": 13, "id": "EimoFtcNNyPzTdYy5SuXEASYAii5yUfiSuDZLcgxtv2s", "fee": 10000000, "feeAssetId": null, "timestamp": 1608680192721, "version": 2, "chainId": 84, "sender": "3MtV1AQ8fEPk76tjKgvrufuMe5aA3q4TviQ", "senderPublicKey": "3Fjao2FW1JXSPd5EkP7C3uerW18HYacYsaMYALFMGA6N", "proofs": [ "3vuS8mz5xg36yvouEx7Ud5cwLWTTKycJ7JoVesEhksfWbVtFTyjhgHdQRaa4qJBe4GfaTdvmcRcfAYErZTsmLjRz" ], "script": "base64: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", "height": 1320571, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DFjsWBWc2vuQUfQTm6KMTWyXWJMTrvRhTFG6YVw3bg2P Next: 5JMLbzcqnmmtqBK9veP9MAzYsqu4JGRgA74djsD9ZNQ7 Diff:
Old | New | Differences | |
---|---|---|---|
82 | 82 | } | |
83 | 83 | ||
84 | 84 | ||
85 | + | func isVotingDisable (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) != "voting_started") | |
86 | + | ||
87 | + | ||
88 | + | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
89 | + | ||
90 | + | ||
85 | 91 | func getVoteValue (s) = if ((s == "like")) | |
86 | 92 | then 1 | |
87 | 93 | else if ((s == "dislike")) | |
88 | 94 | then -1 | |
89 | 95 | else throw("you need to vote with 'like' or 'dislike' value") | |
90 | - | ||
91 | - | ||
92 | - | func isVotingDisable (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) != "voting_started") | |
93 | - | ||
94 | - | ||
95 | - | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func startWorkConditions (taskId,address) = if ((getStringValue(this, (("tasks_" + taskId) + "_status")) != "approved")) | |
102 | 102 | else true | |
103 | 103 | ||
104 | 104 | ||
105 | + | func addRewardConditions (taskId,reward,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
106 | + | then throw("voting was already started, so the reward amount cannot be changed") | |
107 | + | else if ((toString(address) != getStringValue(this, (("tasks_" + taskId) + "_leader")))) | |
108 | + | then throw("team leader only") | |
109 | + | else true | |
110 | + | ||
111 | + | ||
112 | + | func voteForTaskProposalConditions (taskId,i) = if (!(canMemberVote(i))) | |
113 | + | then throw("you can't vote") | |
114 | + | else if (isVotingDisable(taskId)) | |
115 | + | then throw("voting is closed or not started") | |
116 | + | else if (!((tryGetInteger(((("tasks_" + taskId) + "_voted_") + toString(i.caller))) == 0))) | |
117 | + | then throw("you have already voted") | |
118 | + | else true | |
119 | + | ||
120 | + | ||
105 | 121 | @Callable(i) | |
106 | 122 | func addTask (title,link) = WriteSet([DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_title"), title), DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_link"), link), DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_leader"), toString(i.caller))]) | |
107 | 123 | ||
108 | 124 | ||
109 | 125 | ||
110 | 126 | @Callable(i) | |
111 | - | func addReward (taskId,reward) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
112 | - | then throw("voting was already started, so the reward amount cannot be changed") | |
113 | - | else if ((toString(i.caller) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
114 | - | then throw("team leader only") | |
115 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
127 | + | func addReward (taskId,reward) = if (addRewardConditions(taskId, reward, i.caller)) | |
128 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
129 | + | else throw("сhecking progress is not passed") | |
116 | 130 | ||
117 | 131 | ||
118 | 132 | ||
124 | 138 | ||
125 | 139 | ||
126 | 140 | @Callable(i) | |
127 | - | func voteForTaskProposal (taskId,voteValueString) = if (!(canMemberVote(i))) | |
128 | - | then throw("you can't vote") | |
129 | - | else if (isVotingDisable(taskId)) | |
130 | - | then throw("voting is closed or not started") | |
131 | - | else { | |
132 | - | let voteValue = getVoteValue(voteValueString) | |
133 | - | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
134 | - | let previousVote = tryGetInteger(voteKey) | |
135 | - | if (!((previousVote == 0))) | |
136 | - | then throw("you have already voted") | |
137 | - | else { | |
138 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
139 | - | let votingState = tryGetInteger(votingKey) | |
140 | - | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
141 | - | let votesAmountState = (tryGetInteger(votingKey) + 1) | |
142 | - | let newVotingState = (votingState + voteValue) | |
143 | - | WriteSet([DataEntry(votingKey, newVotingState), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
144 | - | } | |
145 | - | } | |
141 | + | func voteForTaskProposal (taskId,voteValueString) = if (voteForTaskProposalConditions(taskId, i)) | |
142 | + | then { | |
143 | + | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
144 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
145 | + | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
146 | + | let voteValue = getVoteValue(voteValueString) | |
147 | + | let votingState = tryGetInteger(votingKey) | |
148 | + | let votesAmountState = (tryGetInteger(votesAmountKey) + 1) | |
149 | + | WriteSet([DataEntry(votingKey, (votingState + voteValue)), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
150 | + | } | |
151 | + | else throw("сhecking progress is not passed") | |
146 | 152 | ||
147 | 153 | ||
148 | 154 | ||
168 | 174 | ||
169 | 175 | ||
170 | 176 | @Callable(i) | |
171 | - | func startWork (taskId) = { | |
172 | - | let tests = startWorkConditions(taskId, i.caller) | |
173 | - | if (startWorkConditions(taskId, i.caller)) | |
174 | - | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started"), DataEntry((("tasks_" + taskId) + "_tests"), tests)]) | |
175 | - | else throw("сhecking progress is not passed") | |
176 | - | } | |
177 | + | func startWork (taskId) = if (startWorkConditions(taskId, i.caller)) | |
178 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
179 | + | else throw("сhecking progress is not passed") | |
177 | 180 | ||
178 | 181 | ||
179 | 182 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let QUORUM = 1 | |
5 | 5 | ||
6 | 6 | func tryGetInteger (key) = { | |
7 | 7 | let val = match getInteger(this, key) { | |
8 | 8 | case b: Int => | |
9 | 9 | b | |
10 | 10 | case _ => | |
11 | 11 | 0 | |
12 | 12 | } | |
13 | 13 | val | |
14 | 14 | } | |
15 | 15 | ||
16 | 16 | ||
17 | 17 | func tryGetString (key) = { | |
18 | 18 | let val = match getString(this, key) { | |
19 | 19 | case b: String => | |
20 | 20 | b | |
21 | 21 | case _ => | |
22 | 22 | "" | |
23 | 23 | } | |
24 | 24 | val | |
25 | 25 | } | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | let mainContract = addressFromStringValue("3MwRzi2BmqZZXWrCGCwcRQLsnic2Aod6zhS") | |
29 | 29 | ||
30 | 30 | func getGroup () = { | |
31 | 31 | let val = match getString(mainContract, "working_group_members") { | |
32 | 32 | case b: String => | |
33 | 33 | b | |
34 | 34 | case _ => | |
35 | 35 | "" | |
36 | 36 | } | |
37 | 37 | val | |
38 | 38 | } | |
39 | 39 | ||
40 | 40 | ||
41 | 41 | func getMembers () = { | |
42 | 42 | let val = match getString(mainContract, "dao_members") { | |
43 | 43 | case b: String => | |
44 | 44 | b | |
45 | 45 | case _ => | |
46 | 46 | "" | |
47 | 47 | } | |
48 | 48 | val | |
49 | 49 | } | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | func getDAOSize () = { | |
53 | 53 | let val = match getInteger(mainContract, "dao_size") { | |
54 | 54 | case b: Int => | |
55 | 55 | b | |
56 | 56 | case _ => | |
57 | 57 | 0 | |
58 | 58 | } | |
59 | 59 | val | |
60 | 60 | } | |
61 | 61 | ||
62 | 62 | ||
63 | 63 | func isGroupMember (a) = { | |
64 | 64 | let val = match getInteger(mainContract, (("working_group_member_" + toString(a)) + "_weight")) { | |
65 | 65 | case b: Int => | |
66 | 66 | b | |
67 | 67 | case _ => | |
68 | 68 | 0 | |
69 | 69 | } | |
70 | 70 | (val > 0) | |
71 | 71 | } | |
72 | 72 | ||
73 | 73 | ||
74 | 74 | func canMemberVote (i) = { | |
75 | 75 | let val = match getInteger(mainContract, (("dao_member_" + toString(i.caller)) + "_weight")) { | |
76 | 76 | case b: Int => | |
77 | 77 | b | |
78 | 78 | case _ => | |
79 | 79 | 0 | |
80 | 80 | } | |
81 | 81 | (val > 0) | |
82 | 82 | } | |
83 | 83 | ||
84 | 84 | ||
85 | + | func isVotingDisable (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) != "voting_started") | |
86 | + | ||
87 | + | ||
88 | + | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
89 | + | ||
90 | + | ||
85 | 91 | func getVoteValue (s) = if ((s == "like")) | |
86 | 92 | then 1 | |
87 | 93 | else if ((s == "dislike")) | |
88 | 94 | then -1 | |
89 | 95 | else throw("you need to vote with 'like' or 'dislike' value") | |
90 | - | ||
91 | - | ||
92 | - | func isVotingDisable (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) != "voting_started") | |
93 | - | ||
94 | - | ||
95 | - | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
96 | 96 | ||
97 | 97 | ||
98 | 98 | func startWorkConditions (taskId,address) = if ((getStringValue(this, (("tasks_" + taskId) + "_status")) != "approved")) | |
99 | 99 | then throw("the task is not approved") | |
100 | 100 | else if ((toString(address) != getStringValue(this, (("tasks_" + taskId) + "_leader")))) | |
101 | 101 | then throw("team leader only") | |
102 | 102 | else true | |
103 | 103 | ||
104 | 104 | ||
105 | + | func addRewardConditions (taskId,reward,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
106 | + | then throw("voting was already started, so the reward amount cannot be changed") | |
107 | + | else if ((toString(address) != getStringValue(this, (("tasks_" + taskId) + "_leader")))) | |
108 | + | then throw("team leader only") | |
109 | + | else true | |
110 | + | ||
111 | + | ||
112 | + | func voteForTaskProposalConditions (taskId,i) = if (!(canMemberVote(i))) | |
113 | + | then throw("you can't vote") | |
114 | + | else if (isVotingDisable(taskId)) | |
115 | + | then throw("voting is closed or not started") | |
116 | + | else if (!((tryGetInteger(((("tasks_" + taskId) + "_voted_") + toString(i.caller))) == 0))) | |
117 | + | then throw("you have already voted") | |
118 | + | else true | |
119 | + | ||
120 | + | ||
105 | 121 | @Callable(i) | |
106 | 122 | func addTask (title,link) = WriteSet([DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_title"), title), DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_link"), link), DataEntry((("tasks_" + toBase58String(i.transactionId)) + "_leader"), toString(i.caller))]) | |
107 | 123 | ||
108 | 124 | ||
109 | 125 | ||
110 | 126 | @Callable(i) | |
111 | - | func addReward (taskId,reward) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
112 | - | then throw("voting was already started, so the reward amount cannot be changed") | |
113 | - | else if ((toString(i.caller) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
114 | - | then throw("team leader only") | |
115 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
127 | + | func addReward (taskId,reward) = if (addRewardConditions(taskId, reward, i.caller)) | |
128 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
129 | + | else throw("сhecking progress is not passed") | |
116 | 130 | ||
117 | 131 | ||
118 | 132 | ||
119 | 133 | @Callable(i) | |
120 | 134 | func initTaskVoting (taskId) = if (!(isGroupMember(i.caller))) | |
121 | 135 | then throw("grants working group access only") | |
122 | 136 | else WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "voting_started")]) | |
123 | 137 | ||
124 | 138 | ||
125 | 139 | ||
126 | 140 | @Callable(i) | |
127 | - | func voteForTaskProposal (taskId,voteValueString) = if (!(canMemberVote(i))) | |
128 | - | then throw("you can't vote") | |
129 | - | else if (isVotingDisable(taskId)) | |
130 | - | then throw("voting is closed or not started") | |
131 | - | else { | |
132 | - | let voteValue = getVoteValue(voteValueString) | |
133 | - | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
134 | - | let previousVote = tryGetInteger(voteKey) | |
135 | - | if (!((previousVote == 0))) | |
136 | - | then throw("you have already voted") | |
137 | - | else { | |
138 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
139 | - | let votingState = tryGetInteger(votingKey) | |
140 | - | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
141 | - | let votesAmountState = (tryGetInteger(votingKey) + 1) | |
142 | - | let newVotingState = (votingState + voteValue) | |
143 | - | WriteSet([DataEntry(votingKey, newVotingState), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
144 | - | } | |
145 | - | } | |
141 | + | func voteForTaskProposal (taskId,voteValueString) = if (voteForTaskProposalConditions(taskId, i)) | |
142 | + | then { | |
143 | + | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
144 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
145 | + | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
146 | + | let voteValue = getVoteValue(voteValueString) | |
147 | + | let votingState = tryGetInteger(votingKey) | |
148 | + | let votesAmountState = (tryGetInteger(votesAmountKey) + 1) | |
149 | + | WriteSet([DataEntry(votingKey, (votingState + voteValue)), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
150 | + | } | |
151 | + | else throw("сhecking progress is not passed") | |
146 | 152 | ||
147 | 153 | ||
148 | 154 | ||
149 | 155 | @Callable(i) | |
150 | 156 | func finishTaskProposalVoting (taskId) = if (isQuorumAchieved(taskId)) | |
151 | 157 | then throw((("more than " + toString(QUORUM)) + "% members have to vote before finishing the voting")) | |
152 | 158 | else if (!(isGroupMember(i.caller))) | |
153 | 159 | then throw("grants working group access only") | |
154 | 160 | else { | |
155 | 161 | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
156 | 162 | let votingState = tryGetInteger(votingKey) | |
157 | 163 | if ((votingState > 0)) | |
158 | 164 | then { | |
159 | 165 | let votingResult = "approved" | |
160 | 166 | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
161 | 167 | } | |
162 | 168 | else { | |
163 | 169 | let votingResult = "rejected" | |
164 | 170 | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
165 | 171 | } | |
166 | 172 | } | |
167 | 173 | ||
168 | 174 | ||
169 | 175 | ||
170 | 176 | @Callable(i) | |
171 | - | func startWork (taskId) = { | |
172 | - | let tests = startWorkConditions(taskId, i.caller) | |
173 | - | if (startWorkConditions(taskId, i.caller)) | |
174 | - | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started"), DataEntry((("tasks_" + taskId) + "_tests"), tests)]) | |
175 | - | else throw("сhecking progress is not passed") | |
176 | - | } | |
177 | + | func startWork (taskId) = if (startWorkConditions(taskId, i.caller)) | |
178 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
179 | + | else throw("сhecking progress is not passed") | |
177 | 180 | ||
178 | 181 | ||
179 | 182 | ||
180 | 183 | @Callable(i) | |
181 | 184 | func rejectTask (taskId) = if (!(isGroupMember(i.caller))) | |
182 | 185 | then throw("grants working group access only") | |
183 | 186 | else WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "rejected")]) | |
184 | 187 | ||
185 | 188 | ||
186 | 189 | ||
187 | 190 | @Callable(i) | |
188 | 191 | func acceptWorkResult (taskId,reportLink) = if (!(isGroupMember(i.caller))) | |
189 | 192 | then throw("grants working group access only") | |
190 | 193 | else { | |
191 | 194 | let rewardAmount = tryGetInteger((("tasks_" + taskId) + "_reward")) | |
192 | 195 | let teamAddress = getStringValue(this, (("tasks_" + taskId) + "_leader")) | |
193 | 196 | ScriptResult(WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_finished"), DataEntry((("tasks_" + taskId) + "_report"), reportLink)]), TransferSet([ScriptTransfer(addressFromStringValue(teamAddress), rewardAmount, unit)])) | |
194 | 197 | } | |
195 | 198 | ||
196 | 199 |
github/deemru/w8io/3ef1775 341.35 ms ◑