tx · 4kFkxgCq9cH4JJ4Tf8fWtFPgJggedSSFmhfZr445SVLW 3N6QtvE15KN8rsW1jkBe1kz8xJHdmhNsYnG: -0.10000000 Waves 2020.12.25 04:12 [1323530] smart account 3N6QtvE15KN8rsW1jkBe1kz8xJHdmhNsYnG > SELF 0.00000000 Waves
{ "type": 13, "id": "4kFkxgCq9cH4JJ4Tf8fWtFPgJggedSSFmhfZr445SVLW", "fee": 10000000, "feeAssetId": null, "timestamp": 1608858796991, "version": 2, "chainId": 84, "sender": "3N6QtvE15KN8rsW1jkBe1kz8xJHdmhNsYnG", "senderPublicKey": "58FMGdemwEpJ3ryCQkCqTQ7y2r5KhqvcD2PEGsiNxzx2", "proofs": [ "5t54Q7uoG4kZxdFxeeJV8ee9GgjjYXJR4hWrX62kqajefoek8A6Fjn353acmYbDcoLA89UBFnjzmRQr5fwdVw9pN" ], "script": "base64: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", "height": 1323530, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2P2yrs1DQpgMBZVvEjCfmuXvdbLPzANCBWHs6c8X6L8w Next: 9C3rhVxfZu2DPxzbgvBzV4ys7tSaafXfhKj7bRpuvCgn Diff:
Old | New | Differences | |
---|---|---|---|
25 | 25 | } | |
26 | 26 | ||
27 | 27 | ||
28 | - | let mainContract = addressFromStringValue(" | |
28 | + | let mainContract = addressFromStringValue("3NCGXdprrsBp9rzrGna68MmfJXQ7fcinF7o") | |
29 | 29 | ||
30 | 30 | func getGroup () = { | |
31 | 31 | let val = match getString(mainContract, "working_group_members") { | |
82 | 82 | } | |
83 | 83 | ||
84 | 84 | ||
85 | + | func isVotingDisable (taskId) = (tryGetString((("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")) | |
89 | 95 | else throw("you need to vote with 'like' or 'dislike' value") | |
90 | 96 | ||
91 | 97 | ||
92 | - | func isVotingLive (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) == "voting_started") | |
98 | + | func initTaskVotingConditions (taskId,address) = if (!(isGroupMember(address))) | |
99 | + | then throw("grants working group access only") | |
100 | + | else if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
101 | + | then throw("task is not new") | |
102 | + | else true | |
93 | 103 | ||
94 | 104 | ||
95 | - | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
105 | + | func startWorkConditions (taskId,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "approved")) | |
106 | + | then throw("the task is not approved") | |
107 | + | else if ((toString(address) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
108 | + | then throw("team leader only") | |
109 | + | else true | |
110 | + | ||
111 | + | ||
112 | + | func addRewardConditions (taskId,reward,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
113 | + | then throw("voting was already started, so the reward amount cannot be changed") | |
114 | + | else if ((toString(address) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
115 | + | then throw("team leader only") | |
116 | + | else true | |
117 | + | ||
118 | + | ||
119 | + | func voteForTaskProposalConditions (taskId,i) = if (!(canMemberVote(i))) | |
120 | + | then throw("you can't vote") | |
121 | + | else if (isVotingDisable(taskId)) | |
122 | + | then throw("voting is closed or not started") | |
123 | + | else if (!((tryGetInteger(((("tasks_" + taskId) + "_voted_") + toString(i.caller))) == 0))) | |
124 | + | then throw("you have already voted") | |
125 | + | else true | |
126 | + | ||
127 | + | ||
128 | + | func finishTaskProposalVotingConditions (taskId,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "voting_started")) | |
129 | + | then throw("voting is not active") | |
130 | + | else if (isQuorumAchieved(taskId)) | |
131 | + | then throw((("more than " + toString(QUORUM)) + "% members have to vote before finishing the voting")) | |
132 | + | else if (!(isGroupMember(address))) | |
133 | + | then throw("grants working group access only") | |
134 | + | else true | |
135 | + | ||
136 | + | ||
137 | + | func acceptWorkResultConditions (address) = if (!(isGroupMember(address))) | |
138 | + | then throw("grants working group access only") | |
139 | + | else true | |
96 | 140 | ||
97 | 141 | ||
98 | 142 | @Callable(i) | |
101 | 145 | ||
102 | 146 | ||
103 | 147 | @Callable(i) | |
104 | - | func addReward (taskId,reward) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
105 | - | then throw("voting was already started, so the reward amount cannot be changed") | |
106 | - | else if ((toString(i.caller) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
107 | - | then throw("team leader only") | |
108 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
148 | + | func addReward (taskId,reward) = if (addRewardConditions(taskId, reward, i.caller)) | |
149 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
150 | + | else throw("checks are not passed") | |
109 | 151 | ||
110 | 152 | ||
111 | 153 | ||
112 | 154 | @Callable(i) | |
113 | - | func initTaskVoting (taskId) = if ( | |
114 | - | then | |
115 | - | else | |
155 | + | func initTaskVoting (taskId) = if (initTaskVotingConditions(taskId, i.caller)) | |
156 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "voting_started")]) | |
157 | + | else throw("checks are not passed") | |
116 | 158 | ||
117 | 159 | ||
118 | 160 | ||
119 | 161 | @Callable(i) | |
120 | - | func voteForTaskProposal (taskId,voteValueString) = if (!(canMemberVote(i))) | |
121 | - | then throw("you can't vote") | |
122 | - | else if (isVotingLive(taskId)) | |
123 | - | then throw("voting is closed or not started") | |
124 | - | else { | |
125 | - | let voteValue = getVoteValue(voteValueString) | |
126 | - | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
127 | - | let previousVote = tryGetInteger(voteKey) | |
128 | - | if (!((previousVote == 0))) | |
129 | - | then throw("you have already voted") | |
130 | - | else { | |
131 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
132 | - | let votingState = tryGetInteger(votingKey) | |
133 | - | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
134 | - | let votesAmountState = (tryGetInteger(votingKey) + 1) | |
135 | - | let newVotingState = (votingState + voteValue) | |
136 | - | WriteSet([DataEntry(votingKey, newVotingState), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
137 | - | } | |
138 | - | } | |
162 | + | func voteForTaskProposal (taskId,voteValueString) = if (voteForTaskProposalConditions(taskId, i)) | |
163 | + | then { | |
164 | + | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
165 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
166 | + | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
167 | + | let voteValue = getVoteValue(voteValueString) | |
168 | + | let votingState = tryGetInteger(votingKey) | |
169 | + | let votesAmountState = (tryGetInteger(votesAmountKey) + 1) | |
170 | + | WriteSet([DataEntry(votingKey, (votingState + voteValue)), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
171 | + | } | |
172 | + | else throw("checks are not passed") | |
139 | 173 | ||
140 | 174 | ||
141 | 175 | ||
142 | 176 | @Callable(i) | |
143 | - | func finishTaskProposalVoting (taskId) = if (isQuorumAchieved(taskId)) | |
144 | - | then throw((("more than " + toString(QUORUM)) + "% members have to vote before finishing the voting")) | |
145 | - | else if (!(isGroupMember(i.caller))) | |
146 | - | then throw("grants working group access only") | |
147 | - | else { | |
148 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
149 | - | let votingState = tryGetInteger(votingKey) | |
150 | - | if ((votingState > 0)) | |
151 | - | then { | |
152 | - | let votingResult = "approved" | |
153 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
154 | - | } | |
155 | - | else { | |
156 | - | let votingResult = "rejected" | |
157 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
158 | - | } | |
159 | - | } | |
177 | + | func finishTaskProposalVoting (taskId) = if (finishTaskProposalVotingConditions(taskId, i.caller)) | |
178 | + | then { | |
179 | + | let statusKey = (("tasks_" + taskId) + "_status") | |
180 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
181 | + | WriteSet([DataEntry(statusKey, if ((tryGetInteger(votingKey) > 0)) | |
182 | + | then "approved" | |
183 | + | else "rejected")]) | |
184 | + | } | |
185 | + | else throw("checks are not passed") | |
160 | 186 | ||
161 | 187 | ||
162 | 188 | ||
163 | 189 | @Callable(i) | |
164 | - | func startWork (taskId) = { | |
165 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
166 | - | if ((toString(i.caller) != getStringValue(this, (("tasks_" + taskId) + "_leader")))) | |
167 | - | then throw("team leader only") | |
168 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
169 | - | } | |
190 | + | func startWork (taskId) = if (startWorkConditions(taskId, i.caller)) | |
191 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
192 | + | else throw("checks are not passed") | |
170 | 193 | ||
171 | 194 | ||
172 | 195 | ||
173 | 196 | @Callable(i) | |
174 | - | func rejectTask (taskId) = if (!(isGroupMember(i.caller))) | |
175 | - | then throw("grants working group access only") | |
176 | - | else { | |
177 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
178 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "rejected")]) | |
179 | - | } | |
197 | + | func rejectTask (taskId) = if (isGroupMember(i.caller)) | |
198 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "rejected")]) | |
199 | + | else throw("grants working group access only") | |
180 | 200 | ||
181 | 201 | ||
182 | 202 | ||
183 | 203 | @Callable(i) | |
184 | - | func acceptWorkResult (taskId,reportLink) = if (!(isGroupMember(i.caller))) | |
185 | - | then throw("grants working group access only") | |
186 | - | else { | |
204 | + | func acceptWorkResult (taskId,reportLink) = if (acceptWorkResultConditions(i.caller)) | |
205 | + | then { | |
187 | 206 | let rewardAmount = tryGetInteger((("tasks_" + taskId) + "_reward")) | |
188 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
189 | 207 | let teamAddress = getStringValue(this, (("tasks_" + taskId) + "_leader")) | |
190 | - | ScriptResult(WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_finished"), DataEntry((( | |
208 | + | ScriptResult(WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_finished"), DataEntry((("tasks_" + taskId) + "_report"), reportLink)]), TransferSet([ScriptTransfer(addressFromStringValue(teamAddress), rewardAmount, unit)])) | |
191 | 209 | } | |
210 | + | else throw("grants working group access only") | |
192 | 211 | ||
193 | 212 |
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 | - | let mainContract = addressFromStringValue(" | |
28 | + | let mainContract = addressFromStringValue("3NCGXdprrsBp9rzrGna68MmfJXQ7fcinF7o") | |
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) = (tryGetString((("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 | 96 | ||
91 | 97 | ||
92 | - | func isVotingLive (taskId) = (getStringValue(this, (("tasks_" + taskId) + "_status")) == "voting_started") | |
98 | + | func initTaskVotingConditions (taskId,address) = if (!(isGroupMember(address))) | |
99 | + | then throw("grants working group access only") | |
100 | + | else if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
101 | + | then throw("task is not new") | |
102 | + | else true | |
93 | 103 | ||
94 | 104 | ||
95 | - | func isQuorumAchieved (taskId) = (QUORUM > ((tryGetInteger((("tasks_" + taskId) + "_voting_amount")) * 100) / getDAOSize())) | |
105 | + | func startWorkConditions (taskId,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "approved")) | |
106 | + | then throw("the task is not approved") | |
107 | + | else if ((toString(address) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
108 | + | then throw("team leader only") | |
109 | + | else true | |
110 | + | ||
111 | + | ||
112 | + | func addRewardConditions (taskId,reward,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
113 | + | then throw("voting was already started, so the reward amount cannot be changed") | |
114 | + | else if ((toString(address) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
115 | + | then throw("team leader only") | |
116 | + | else true | |
117 | + | ||
118 | + | ||
119 | + | func voteForTaskProposalConditions (taskId,i) = if (!(canMemberVote(i))) | |
120 | + | then throw("you can't vote") | |
121 | + | else if (isVotingDisable(taskId)) | |
122 | + | then throw("voting is closed or not started") | |
123 | + | else if (!((tryGetInteger(((("tasks_" + taskId) + "_voted_") + toString(i.caller))) == 0))) | |
124 | + | then throw("you have already voted") | |
125 | + | else true | |
126 | + | ||
127 | + | ||
128 | + | func finishTaskProposalVotingConditions (taskId,address) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "voting_started")) | |
129 | + | then throw("voting is not active") | |
130 | + | else if (isQuorumAchieved(taskId)) | |
131 | + | then throw((("more than " + toString(QUORUM)) + "% members have to vote before finishing the voting")) | |
132 | + | else if (!(isGroupMember(address))) | |
133 | + | then throw("grants working group access only") | |
134 | + | else true | |
135 | + | ||
136 | + | ||
137 | + | func acceptWorkResultConditions (address) = if (!(isGroupMember(address))) | |
138 | + | then throw("grants working group access only") | |
139 | + | else true | |
96 | 140 | ||
97 | 141 | ||
98 | 142 | @Callable(i) | |
99 | 143 | 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))]) | |
100 | 144 | ||
101 | 145 | ||
102 | 146 | ||
103 | 147 | @Callable(i) | |
104 | - | func addReward (taskId,reward) = if ((tryGetString((("tasks_" + taskId) + "_status")) != "")) | |
105 | - | then throw("voting was already started, so the reward amount cannot be changed") | |
106 | - | else if ((toString(i.caller) != tryGetString((("tasks_" + taskId) + "_leader")))) | |
107 | - | then throw("team leader only") | |
108 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
148 | + | func addReward (taskId,reward) = if (addRewardConditions(taskId, reward, i.caller)) | |
149 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_reward"), reward)]) | |
150 | + | else throw("checks are not passed") | |
109 | 151 | ||
110 | 152 | ||
111 | 153 | ||
112 | 154 | @Callable(i) | |
113 | - | func initTaskVoting (taskId) = if ( | |
114 | - | then | |
115 | - | else | |
155 | + | func initTaskVoting (taskId) = if (initTaskVotingConditions(taskId, i.caller)) | |
156 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "voting_started")]) | |
157 | + | else throw("checks are not passed") | |
116 | 158 | ||
117 | 159 | ||
118 | 160 | ||
119 | 161 | @Callable(i) | |
120 | - | func voteForTaskProposal (taskId,voteValueString) = if (!(canMemberVote(i))) | |
121 | - | then throw("you can't vote") | |
122 | - | else if (isVotingLive(taskId)) | |
123 | - | then throw("voting is closed or not started") | |
124 | - | else { | |
125 | - | let voteValue = getVoteValue(voteValueString) | |
126 | - | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
127 | - | let previousVote = tryGetInteger(voteKey) | |
128 | - | if (!((previousVote == 0))) | |
129 | - | then throw("you have already voted") | |
130 | - | else { | |
131 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
132 | - | let votingState = tryGetInteger(votingKey) | |
133 | - | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
134 | - | let votesAmountState = (tryGetInteger(votingKey) + 1) | |
135 | - | let newVotingState = (votingState + voteValue) | |
136 | - | WriteSet([DataEntry(votingKey, newVotingState), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
137 | - | } | |
138 | - | } | |
162 | + | func voteForTaskProposal (taskId,voteValueString) = if (voteForTaskProposalConditions(taskId, i)) | |
163 | + | then { | |
164 | + | let voteKey = ((("tasks_" + taskId) + "_voted_") + toString(i.caller)) | |
165 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
166 | + | let votesAmountKey = (("tasks_" + taskId) + "_voting_amount") | |
167 | + | let voteValue = getVoteValue(voteValueString) | |
168 | + | let votingState = tryGetInteger(votingKey) | |
169 | + | let votesAmountState = (tryGetInteger(votesAmountKey) + 1) | |
170 | + | WriteSet([DataEntry(votingKey, (votingState + voteValue)), DataEntry(voteKey, voteValue), DataEntry(votesAmountKey, votesAmountState)]) | |
171 | + | } | |
172 | + | else throw("checks are not passed") | |
139 | 173 | ||
140 | 174 | ||
141 | 175 | ||
142 | 176 | @Callable(i) | |
143 | - | func finishTaskProposalVoting (taskId) = if (isQuorumAchieved(taskId)) | |
144 | - | then throw((("more than " + toString(QUORUM)) + "% members have to vote before finishing the voting")) | |
145 | - | else if (!(isGroupMember(i.caller))) | |
146 | - | then throw("grants working group access only") | |
147 | - | else { | |
148 | - | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
149 | - | let votingState = tryGetInteger(votingKey) | |
150 | - | if ((votingState > 0)) | |
151 | - | then { | |
152 | - | let votingResult = "approved" | |
153 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
154 | - | } | |
155 | - | else { | |
156 | - | let votingResult = "rejected" | |
157 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), votingResult)]) | |
158 | - | } | |
159 | - | } | |
177 | + | func finishTaskProposalVoting (taskId) = if (finishTaskProposalVotingConditions(taskId, i.caller)) | |
178 | + | then { | |
179 | + | let statusKey = (("tasks_" + taskId) + "_status") | |
180 | + | let votingKey = (("tasks_" + taskId) + "_voting_state") | |
181 | + | WriteSet([DataEntry(statusKey, if ((tryGetInteger(votingKey) > 0)) | |
182 | + | then "approved" | |
183 | + | else "rejected")]) | |
184 | + | } | |
185 | + | else throw("checks are not passed") | |
160 | 186 | ||
161 | 187 | ||
162 | 188 | ||
163 | 189 | @Callable(i) | |
164 | - | func startWork (taskId) = { | |
165 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
166 | - | if ((toString(i.caller) != getStringValue(this, (("tasks_" + taskId) + "_leader")))) | |
167 | - | then throw("team leader only") | |
168 | - | else WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
169 | - | } | |
190 | + | func startWork (taskId) = if (startWorkConditions(taskId, i.caller)) | |
191 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_started")]) | |
192 | + | else throw("checks are not passed") | |
170 | 193 | ||
171 | 194 | ||
172 | 195 | ||
173 | 196 | @Callable(i) | |
174 | - | func rejectTask (taskId) = if (!(isGroupMember(i.caller))) | |
175 | - | then throw("grants working group access only") | |
176 | - | else { | |
177 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
178 | - | WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "rejected")]) | |
179 | - | } | |
197 | + | func rejectTask (taskId) = if (isGroupMember(i.caller)) | |
198 | + | then WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "rejected")]) | |
199 | + | else throw("grants working group access only") | |
180 | 200 | ||
181 | 201 | ||
182 | 202 | ||
183 | 203 | @Callable(i) | |
184 | - | func acceptWorkResult (taskId,reportLink) = if (!(isGroupMember(i.caller))) | |
185 | - | then throw("grants working group access only") | |
186 | - | else { | |
204 | + | func acceptWorkResult (taskId,reportLink) = if (acceptWorkResultConditions(i.caller)) | |
205 | + | then { | |
187 | 206 | let rewardAmount = tryGetInteger((("tasks_" + taskId) + "_reward")) | |
188 | - | let teamIdentifier = getStringValue(this, (("tasks_" + taskId) + "_performer")) | |
189 | 207 | let teamAddress = getStringValue(this, (("tasks_" + taskId) + "_leader")) | |
190 | - | ScriptResult(WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_finished"), DataEntry((( | |
208 | + | ScriptResult(WriteSet([DataEntry((("tasks_" + taskId) + "_status"), "work_finished"), DataEntry((("tasks_" + taskId) + "_report"), reportLink)]), TransferSet([ScriptTransfer(addressFromStringValue(teamAddress), rewardAmount, unit)])) | |
191 | 209 | } | |
210 | + | else throw("grants working group access only") | |
192 | 211 | ||
193 | 212 |
github/deemru/w8io/3ef1775 54.78 ms ◑