tx · 9DeRvmqZWKVaN97arxHdJh2fi6f1q7nkLQprehsCz9E1 3Mwv6cMyrLP5CQ3dTCsheo4kQjLGfKZE5C4: -0.01400000 Waves 2019.07.04 09:35 [570321] smart account 3Mwv6cMyrLP5CQ3dTCsheo4kQjLGfKZE5C4 > SELF 0.00000000 Waves
{ "type": 13, "id": "9DeRvmqZWKVaN97arxHdJh2fi6f1q7nkLQprehsCz9E1", "fee": 1400000, "feeAssetId": null, "timestamp": 1562222138944, "version": 1, "sender": "3Mwv6cMyrLP5CQ3dTCsheo4kQjLGfKZE5C4", "senderPublicKey": "DSnYugobtDLc6RsQn654J1NALWpKRBdyZamm98Xc8ChL", "proofs": [ "647HcFkiNKWzEmfKtoR47WB1TXartaWYHtmr1SeiS2BY2Tf6BKB3jLdnpPTtJYgDVBX1ESXxxE5aGbQoubfAvv9r" ], "script": "base64:AAIDAAAAAAAAAAAAAAAjAAAAAAZWT1RFUlMAAAAAAAAAAAMAAAAABlFVT1JVTQAAAAAAAAAAAgAAAAAGVk9USU5HAgAAAAZ2b3RpbmcAAAAABlJFVkVBTAIAAAAGcmV2ZWFsAAAAAAhGRUFUVVJFRAIAAAAIZmVhdHVyZWQAAAAACERFTElTVEVEAgAAAAhkZWxpc3RlZAAAAAAETk9ORQIAAAAEbm9uZQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABAAAAA2tleQQAAAADbnVtBAAAAAckbWF0Y2gwCQAEGgAAAAIFAAAABHRoaXMFAAAAA2tleQMJAAABAAAAAgUAAAAHJG1hdGNoMAIAAAADSW50BAAAAAFhBQAAAAckbWF0Y2gwBQAAAAFhAAAAAAAAAAAABQAAAANudW0BAAAAC2dldFN0ckJ5S2V5AAAAAQAAAANrZXkEAAAAA3N0cgQAAAAHJG1hdGNoMAkABB0AAAACBQAAAAR0aGlzBQAAAANrZXkDCQAAAQAAAAIFAAAAByRtYXRjaDACAAAABlN0cmluZwQAAAABYQUAAAAHJG1hdGNoMAUAAAABYQUAAAAETk9ORQUAAAADc3RyAQAAAA9nZXRLZXlJdGVtUHJpY2UAAAABAAAABGl0ZW0JAAEsAAAAAgUAAAAEaXRlbQIAAAAGX3ByaWNlAQAAABFnZXRWYWx1ZUl0ZW1QcmljZQAAAAEAAAAEaXRlbQkBAAAADmdldE51bWJlckJ5S2V5AAAAAQkBAAAAD2dldEtleUl0ZW1QcmljZQAAAAEFAAAABGl0ZW0BAAAAFWdldEtleVVzZXJJdGVtQ291bnRlcgAAAAIAAAAEdXNlcgAAAARpdGVtCQABLAAAAAIJAAEsAAAAAgkAASwAAAACBQAAAARpdGVtAgAAAAFfBQAAAAR1c2VyAgAAAARfY250AQAAABdnZXRWYWx1ZVVzZXJJdGVtQ291bnRlcgAAAAIAAAAEdXNlcgAAAARpdGVtCQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAVZ2V0S2V5VXNlckl0ZW1Db3VudGVyAAAAAgUAAAAEdXNlcgUAAAAEaXRlbQEAAAAKZ2V0S2V5SXRlbQAAAAIAAAAIc3VwcGxpZXIAAAAFdGl0bGUJAAEsAAAAAgIAAAAFaXRlbV8JAAJYAAAAAQkAAfcAAAABCQABmwAAAAEJAAEsAAAAAgUAAAAIc3VwcGxpZXIFAAAABXRpdGxlAQAAAA5nZXRLZXlJdGVtRGF0YQAAAAEAAAAEaXRlbQkAASwAAAACBQAAAARpdGVtAgAAAAVfZGF0YQEAAAASZ2V0S2V5SXRlbVN1cHBsaWVyAAAAAQAAAARpdGVtCQABLAAAAAIFAAAABGl0ZW0CAAAABl9vd25lcgEAAAAUZ2V0VmFsdWVJdGVtU3VwcGxpZXIAAAABAAAABGl0ZW0JAQAAAAtnZXRTdHJCeUtleQAAAAEJAQAAABJnZXRLZXlJdGVtU3VwcGxpZXIAAAABBQAAAARpdGVtAQAAABVnZXRLZXlCYWxhbmNlU3VwcGxpZXIAAAABAAAAB2FjY291bnQJAAEsAAAAAgUAAAAHYWNjb3VudAIAAAAIX2JhbGFuY2UBAAAAF2dldFZhbHVlQmFsYW5jZVN1cHBsaWVyAAAAAQAAAAdhY2NvdW50CQEAAAAOZ2V0TnVtYmVyQnlLZXkAAAABCQEAAAAVZ2V0S2V5QmFsYW5jZVN1cHBsaWVyAAAAAQUAAAAHYWNjb3VudAEAAAAMZ2V0S2V5Q29tbWl0AAAAAgAAAARpdGVtAAAABHVzZXIJAAEsAAAAAgkAASwAAAACCQABLAAAAAIFAAAABGl0ZW0CAAAAAV8FAAAABHVzZXICAAAAB19jb21taXQBAAAADmdldFZhbHVlQ29tbWl0AAAAAgAAAARpdGVtAAAABHVzZXIJAQAAAAtnZXRTdHJCeUtleQAAAAEJAQAAAAxnZXRLZXlDb21taXQAAAACBQAAAARpdGVtBQAAAAR1c2VyAQAAABJnZXRLZXlDb21taXRzQ291bnQAAAABAAAABGl0ZW0JAAEsAAAAAgUAAAAEaXRlbQIAAAAHX2NvbWNudAEAAAAUZ2V0VmFsdWVDb21taXRzQ291bnQAAAABAAAABGl0ZW0JAQAAAA5nZXROdW1iZXJCeUtleQAAAAEJAQAAABJnZXRLZXlDb21taXRzQ291bnQAAAABBQAAAARpdGVtAQAAAAxnZXRLZXlSZXZlYWwAAAACAAAABGl0ZW0AAAAEdXNlcgkAASwAAAACCQABLAAAAAIJAAEsAAAAAgUAAAAEaXRlbQIAAAABXwUAAAAEdXNlcgIAAAAHX3JldmVhbAEAAAAOZ2V0VmFsdWVSZXZlYWwAAAACAAAABGl0ZW0AAAAEdXNlcgkBAAAAC2dldFN0ckJ5S2V5AAAAAQkBAAAADGdldEtleVJldmVhbAAAAAIFAAAABGl0ZW0FAAAABHVzZXIBAAAAEGdldEtleUl0ZW1TdGF0dXMAAAABAAAABGl0ZW0JAAEsAAAAAgUAAAAEaXRlbQIAAAAHX3N0YXR1cwEAAAASZ2V0VmFsdWVJdGVtU3RhdHVzAAAAAQAAAARpdGVtCQEAAAALZ2V0U3RyQnlLZXkAAAABCQEAAAAQZ2V0S2V5SXRlbVN0YXR1cwAAAAEFAAAABGl0ZW0BAAAAD2dldEtleVZvdGVDb3VudAAAAAIAAAAEaXRlbQAAAAR2b3RlCQABLAAAAAIJAAEsAAAAAgUAAAAEaXRlbQIAAAAFX3JlczoFAAAABHZvdGUBAAAAEWdldFZhbHVlVm90ZUNvdW50AAAAAgAAAARpdGVtAAAABHZvdGUJAQAAAA5nZXROdW1iZXJCeUtleQAAAAEJAQAAAA9nZXRLZXlWb3RlQ291bnQAAAACBQAAAARpdGVtBQAAAAR2b3RlAAAAAAh2ZXJpZmllcgIAAAAjM013djZjTXlyTFA1Q1EzZFRDc2hlbzRrUWpMR2ZLWkU1QzQAAAAACFZFUklGSUVEAgAAAAh2ZXJpZmllZAAAAAALQkxBQ0tMSVNURUQCAAAACWJsYWNrbGlzdAEAAAAcZ2V0RXh0S2V5SXRlbVdoaXRlTGlzdFN0YXR1cwAAAAEAAAAEaXRlbQkAASwAAAACBQAAAARpdGVtAgAAABBfdmVyaWZpZXJfc3RhdHVzAQAAABNnZXRFeHRBZGRyZXNzT3JhY2xlAAAAAAkBAAAAB2V4dHJhY3QAAAABCQEAAAARYWRkcmVzc0Zyb21TdHJpbmcAAAABBQAAAAh2ZXJpZmllcgEAAAAeZ2V0RXh0VmFsdWVJdGVtV2hpdGVMaXN0U3RhdHVzAAAAAgAAAAZvcmFjbGUAAAAHYWNjb3VudAQAAAADc3RyBAAAAAckbWF0Y2gwCQAEHQAAAAIFAAAABm9yYWNsZQkBAAAAHGdldEV4dEtleUl0ZW1XaGl0ZUxpc3RTdGF0dXMAAAABBQAAAAdhY2NvdW50AwkAAAEAAAACBQAAAAckbWF0Y2gwAgAA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b3VudAUAAAAIdmVyaWZpZXIJAAACAAAAAQIAAAAxb25seSBvcmFjbGUgdmVyaWZpZXIgYXJlIGFibGUgdG8gbWFuYWdlIHdoaXRlbGlzdAMDCQEAAAACIT0AAAACBQAAAAZzdGF0dXMFAAAACFZFUklGSUVECQEAAAACIT0AAAACBQAAAAZzdGF0dXMFAAAAC0JMQUNLTElTVEVEBwkAAAIAAAABAgAAAAx3cm9uZyBzdGF0dXMJAQAAAAhXcml0ZVNldAAAAAEJAARMAAAAAgkBAAAACURhdGFFbnRyeQAAAAIJAQAAABxnZXRFeHRLZXlJdGVtV2hpdGVMaXN0U3RhdHVzAAAAAQUAAAAIc3VwcGxpZXIFAAAABnN0YXR1cwUAAAADbmlsAAAAAWkBAAAAB2FkZEl0ZW0AAAADAAAABXRpdGxlAAAABXByaWNlAAAABGRhdGEEAAAAD3N1cHBsaWVyQWRkcmVzcwkAAlgAAAABCAgFAAAAAWkAAAAGY2FsbGVyAAAABWJ5dGVzBAAAAARpdGVtCQEAAAAKZ2V0S2V5SXRlbQAAAAIFAAAAD3N1cHBsaWVyQWRkcmVzcwUAAAAFdGl0bGUEAAAAEXN1cHBsaWVyV2hpdGVsaXN0CQEAAAAeZ2V0RXh0VmFsdWVJdGVtV2hpdGVMaXN0U3RhdHVzAAAAAgkBAAAAE2dldEV4dEFkZHJlc3NPcmFjbGUAAAAABQAAAA9zdXBwbGllckFkZHJlc3MDCQAAZwAAAAIAAAAAAAAAAAAFAAAABXByaWNlCQAAAgAAAAECAAAALnB1cmNoYXNlIGFtb3VudCBjYW5ub3QgYmUgbGVzcyB0aGFuIGl0ZW0gcHJpY2UDCQEAAAACIT0AAAACCQEAAAAUZ2V0VmFsdWVJdGVtU3VwcGxpZXIAAAABBQAAAARpdGVtBQAAAAROT05FCQAAAgAAAAECAAAAGGFuIGl0ZW0gaXMgYWxyZWFkeSBleGlzdAMJAAAAAAAAAgUAAAARc3VwcGxpZXJXaGl0ZWxpc3QFAAAAC0JMQUNLTElTVEVECQAAAgAAAAECAAAAJ3N1cHBsaWVyJ3MgYWNjb3VudCBoYXMgYmVlbiBibGFja2xpc3RlZAkBAAAACFdyaXRlU2V0AAAAAQkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkBAAAAEmdldEtleUl0ZW1TdXBwbGllcgAAAAEFAAAABGl0ZW0FAAAAD3N1cHBsaWVyQWRkcmVzcwkABEwAAAACCQEAAAAJRGF0YUVudHJ5AAAAAgkBAAAAD2dldEtleUl0ZW1QcmljZQAAAAEFAAAABGl0ZW0FAAAABXByaWNlCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACCQEAAAAOZ2V0S2V5SXRlbURhdGEAAAABBQAAAARpdGVtBQAAAARkYXRhCQAETAAAAAIJAQAAAAlEYXRhRW50cnkAAAACCQEAAAAcZ2V0RXh0S2V5SXRlbVdoaXRlTGlzdFN0YXR1cwAAAAEFAAAAD3N1cHBsaWVyQWRkcmVzcwUAAAARc3VwcGxpZXJXaGl0ZWxpc3QFAAAAA25pbAAAAAAjiAiC", "chainId": 84, "height": 570321, "spentComplexity": 0 } View: original | compacted Prev: 8tQxFkBcgSnn4rw34QYEuzNTyyUJK3Y956toTBLwZYqE Next: none Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | func getExtValueItemWhiteListState (item) = (item + "_verifier_status") | |
4 | + | let VOTERS = 3 | |
5 | + | ||
6 | + | let QUORUM = 2 | |
7 | + | ||
8 | + | let VOTING = "voting" | |
9 | + | ||
10 | + | let REVEAL = "reveal" | |
11 | + | ||
12 | + | let FEATURED = "featured" | |
13 | + | ||
14 | + | let DELISTED = "delisted" | |
15 | + | ||
16 | + | let NONE = "none" | |
17 | + | ||
18 | + | func getNumberByKey (key) = { | |
19 | + | let num = match getInteger(this, key) { | |
20 | + | case a: Int => | |
21 | + | a | |
22 | + | case _ => | |
23 | + | 0 | |
24 | + | } | |
25 | + | num | |
26 | + | } | |
27 | + | ||
28 | + | ||
29 | + | func getStrByKey (key) = { | |
30 | + | let str = match getString(this, key) { | |
31 | + | case a: String => | |
32 | + | a | |
33 | + | case _ => | |
34 | + | NONE | |
35 | + | } | |
36 | + | str | |
37 | + | } | |
38 | + | ||
39 | + | ||
40 | + | func getKeyItemPrice (item) = (item + "_price") | |
41 | + | ||
42 | + | ||
43 | + | func getValueItemPrice (item) = getNumberByKey(getKeyItemPrice(item)) | |
44 | + | ||
45 | + | ||
46 | + | func getKeyUserItemCounter (user,item) = (((item + "_") + user) + "_cnt") | |
47 | + | ||
48 | + | ||
49 | + | func getValueUserItemCounter (user,item) = getNumberByKey(getKeyUserItemCounter(user, item)) | |
50 | + | ||
51 | + | ||
52 | + | func getKeyItem (supplier,title) = ("item_" + toBase58String(sha256(toBytes((supplier + title))))) | |
53 | + | ||
54 | + | ||
55 | + | func getKeyItemData (item) = (item + "_data") | |
56 | + | ||
57 | + | ||
58 | + | func getKeyItemSupplier (item) = (item + "_owner") | |
59 | + | ||
60 | + | ||
61 | + | func getValueItemSupplier (item) = getStrByKey(getKeyItemSupplier(item)) | |
62 | + | ||
63 | + | ||
64 | + | func getKeyBalanceSupplier (account) = (account + "_balance") | |
65 | + | ||
66 | + | ||
67 | + | func getValueBalanceSupplier (account) = getNumberByKey(getKeyBalanceSupplier(account)) | |
68 | + | ||
69 | + | ||
70 | + | func getKeyCommit (item,user) = (((item + "_") + user) + "_commit") | |
71 | + | ||
72 | + | ||
73 | + | func getValueCommit (item,user) = getStrByKey(getKeyCommit(item, user)) | |
74 | + | ||
75 | + | ||
76 | + | func getKeyCommitsCount (item) = (item + "_comcnt") | |
77 | + | ||
78 | + | ||
79 | + | func getValueCommitsCount (item) = getNumberByKey(getKeyCommitsCount(item)) | |
80 | + | ||
81 | + | ||
82 | + | func getKeyReveal (item,user) = (((item + "_") + user) + "_reveal") | |
83 | + | ||
84 | + | ||
85 | + | func getValueReveal (item,user) = getStrByKey(getKeyReveal(item, user)) | |
86 | + | ||
87 | + | ||
88 | + | func getKeyItemStatus (item) = (item + "_status") | |
89 | + | ||
90 | + | ||
91 | + | func getValueItemStatus (item) = getStrByKey(getKeyItemStatus(item)) | |
92 | + | ||
93 | + | ||
94 | + | func getKeyVoteCount (item,vote) = ((item + "_res:") + vote) | |
95 | + | ||
96 | + | ||
97 | + | func getValueVoteCount (item,vote) = getNumberByKey(getKeyVoteCount(item, vote)) | |
5 | 98 | ||
6 | 99 | ||
7 | 100 | let verifier = "3Mwv6cMyrLP5CQ3dTCsheo4kQjLGfKZE5C4" | |
9 | 102 | let VERIFIED = "verified" | |
10 | 103 | ||
11 | 104 | let BLACKLISTED = "blacklist" | |
105 | + | ||
106 | + | func getExtKeyItemWhiteListStatus (item) = (item + "_verifier_status") | |
107 | + | ||
108 | + | ||
109 | + | func getExtAddressOracle () = extract(addressFromString(verifier)) | |
110 | + | ||
111 | + | ||
112 | + | func getExtValueItemWhiteListStatus (oracle,account) = { | |
113 | + | let str = match getString(oracle, getExtKeyItemWhiteListStatus(account)) { | |
114 | + | case a: String => | |
115 | + | a | |
116 | + | case _ => | |
117 | + | NONE | |
118 | + | } | |
119 | + | str | |
120 | + | } | |
121 | + | ||
122 | + | ||
123 | + | @Callable(i) | |
124 | + | func purchase (item) = { | |
125 | + | let pmt = extract(i.payment) | |
126 | + | if (isDefined(pmt.assetId)) | |
127 | + | then throw("WAVES tokens only at the moment") | |
128 | + | else { | |
129 | + | let userAddress = toBase58String(i.caller.bytes) | |
130 | + | let price = getValueItemPrice(item) | |
131 | + | let supplierAddress = getValueItemSupplier(item) | |
132 | + | if ((pmt.amount > price)) | |
133 | + | then throw("purchase amount cannot be less than item price") | |
134 | + | else if ((pmt.amount > price)) | |
135 | + | then throw("purchase amount cannot be higher than item price") | |
136 | + | else if ((supplierAddress == NONE)) | |
137 | + | then throw("supplier does not exist") | |
138 | + | else WriteSet([DataEntry(getKeyUserItemCounter(userAddress, item), (getValueUserItemCounter(userAddress, item) + 1)), DataEntry(getKeyBalanceSupplier(supplierAddress), (getValueBalanceSupplier(supplierAddress) + pmt.amount))]) | |
139 | + | } | |
140 | + | } | |
141 | + | ||
142 | + | ||
143 | + | ||
144 | + | @Callable(i) | |
145 | + | func withdraw () = { | |
146 | + | let supplierAddress = toBase58String(i.caller.bytes) | |
147 | + | let balance = getValueBalanceSupplier(supplierAddress) | |
148 | + | if ((0 >= balance)) | |
149 | + | then throw("insufficient balance") | |
150 | + | else ScriptResult(WriteSet([DataEntry(getKeyBalanceSupplier(supplierAddress), 0)]), TransferSet([ScriptTransfer(addressFromStringValue(supplierAddress), balance, unit)])) | |
151 | + | } | |
152 | + | ||
153 | + | ||
154 | + | ||
155 | + | @Callable(i) | |
156 | + | func voteCommit (item,hash) = { | |
157 | + | let user = toBase58String(i.caller.bytes) | |
158 | + | let commits = getValueCommitsCount(item) | |
159 | + | let status = getValueItemStatus(item) | |
160 | + | if ((commits >= VOTERS)) | |
161 | + | then throw("reached max num of voters") | |
162 | + | else if ((getValueCommit(item, user) != NONE)) | |
163 | + | then throw("user has already participated") | |
164 | + | else if ((getKeyItemSupplier(item) == NONE)) | |
165 | + | then throw("item does not exist") | |
166 | + | else if (if ((status != NONE)) | |
167 | + | then (status != VOTING) | |
168 | + | else false) | |
169 | + | then throw("voting is not possible") | |
170 | + | else WriteSet([DataEntry(getKeyCommit(item, user), hash), DataEntry(getKeyCommitsCount(item), (commits + 1)), DataEntry(getKeyItemStatus(item), if ((commits == VOTERS)) | |
171 | + | then REVEAL | |
172 | + | else VOTING)]) | |
173 | + | } | |
174 | + | ||
175 | + | ||
176 | + | ||
177 | + | @Callable(i) | |
178 | + | func voteReveal (item,vote,salt) = { | |
179 | + | let user = toBase58String(i.caller.bytes) | |
180 | + | let status = getValueItemStatus(item) | |
181 | + | let newVoteCount = (getValueVoteCount(item, vote) + 1) | |
182 | + | if ((toBase58String(sha256(toBytes((vote + salt)))) != getValueCommit(item, user))) | |
183 | + | then throw("reveal data is not valid") | |
184 | + | else if ((VOTERS > getValueCommitsCount(item))) | |
185 | + | then throw("max num of voters hasnt reached yet") | |
186 | + | else if ((getValueReveal(item, user) != NONE)) | |
187 | + | then throw("user has already partcipated") | |
188 | + | else if (if ((status != VOTING)) | |
189 | + | then (status != REVEAL) | |
190 | + | else false) | |
191 | + | then throw("wrong status") | |
192 | + | else if (if ((vote != FEATURED)) | |
193 | + | then (vote != DELISTED) | |
194 | + | else false) | |
195 | + | then throw("wrong vote") | |
196 | + | else if (if ((status == FEATURED)) | |
197 | + | then true | |
198 | + | else (status == DELISTED)) | |
199 | + | then throw("vote has finished") | |
200 | + | else WriteSet([DataEntry(getKeyReveal(item, user), vote), DataEntry(getKeyVoteCount(item, vote), newVoteCount), DataEntry(getKeyItemStatus(item), if ((newVoteCount >= QUORUM)) | |
201 | + | then vote | |
202 | + | else REVEAL)]) | |
203 | + | } | |
204 | + | ||
205 | + | ||
12 | 206 | ||
13 | 207 | @Callable(i) | |
14 | 208 | func setstatus (supplier,status) = { | |
19 | 213 | then (status != BLACKLISTED) | |
20 | 214 | else false) | |
21 | 215 | then throw("wrong status") | |
22 | - | else WriteSet([DataEntry(getExtValueItemWhiteListState(supplier), status)]) | |
216 | + | else WriteSet([DataEntry(getExtKeyItemWhiteListStatus(supplier), status)]) | |
217 | + | } | |
218 | + | ||
219 | + | ||
220 | + | ||
221 | + | @Callable(i) | |
222 | + | func addItem (title,price,data) = { | |
223 | + | let supplierAddress = toBase58String(i.caller.bytes) | |
224 | + | let item = getKeyItem(supplierAddress, title) | |
225 | + | let supplierWhitelist = getExtValueItemWhiteListStatus(getExtAddressOracle(), supplierAddress) | |
226 | + | if ((0 >= price)) | |
227 | + | then throw("purchase amount cannot be less than item price") | |
228 | + | else if ((getValueItemSupplier(item) != NONE)) | |
229 | + | then throw("an item is already exist") | |
230 | + | else if ((supplierWhitelist == BLACKLISTED)) | |
231 | + | then throw("supplier's account has been blacklisted") | |
232 | + | else WriteSet([DataEntry(getKeyItemSupplier(item), supplierAddress), DataEntry(getKeyItemPrice(item), price), DataEntry(getKeyItemData(item), data), DataEntry(getExtKeyItemWhiteListStatus(supplierAddress), supplierWhitelist)]) | |
23 | 233 | } | |
24 | 234 | ||
25 | 235 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 3 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | func getExtValueItemWhiteListState (item) = (item + "_verifier_status") | |
4 | + | let VOTERS = 3 | |
5 | + | ||
6 | + | let QUORUM = 2 | |
7 | + | ||
8 | + | let VOTING = "voting" | |
9 | + | ||
10 | + | let REVEAL = "reveal" | |
11 | + | ||
12 | + | let FEATURED = "featured" | |
13 | + | ||
14 | + | let DELISTED = "delisted" | |
15 | + | ||
16 | + | let NONE = "none" | |
17 | + | ||
18 | + | func getNumberByKey (key) = { | |
19 | + | let num = match getInteger(this, key) { | |
20 | + | case a: Int => | |
21 | + | a | |
22 | + | case _ => | |
23 | + | 0 | |
24 | + | } | |
25 | + | num | |
26 | + | } | |
27 | + | ||
28 | + | ||
29 | + | func getStrByKey (key) = { | |
30 | + | let str = match getString(this, key) { | |
31 | + | case a: String => | |
32 | + | a | |
33 | + | case _ => | |
34 | + | NONE | |
35 | + | } | |
36 | + | str | |
37 | + | } | |
38 | + | ||
39 | + | ||
40 | + | func getKeyItemPrice (item) = (item + "_price") | |
41 | + | ||
42 | + | ||
43 | + | func getValueItemPrice (item) = getNumberByKey(getKeyItemPrice(item)) | |
44 | + | ||
45 | + | ||
46 | + | func getKeyUserItemCounter (user,item) = (((item + "_") + user) + "_cnt") | |
47 | + | ||
48 | + | ||
49 | + | func getValueUserItemCounter (user,item) = getNumberByKey(getKeyUserItemCounter(user, item)) | |
50 | + | ||
51 | + | ||
52 | + | func getKeyItem (supplier,title) = ("item_" + toBase58String(sha256(toBytes((supplier + title))))) | |
53 | + | ||
54 | + | ||
55 | + | func getKeyItemData (item) = (item + "_data") | |
56 | + | ||
57 | + | ||
58 | + | func getKeyItemSupplier (item) = (item + "_owner") | |
59 | + | ||
60 | + | ||
61 | + | func getValueItemSupplier (item) = getStrByKey(getKeyItemSupplier(item)) | |
62 | + | ||
63 | + | ||
64 | + | func getKeyBalanceSupplier (account) = (account + "_balance") | |
65 | + | ||
66 | + | ||
67 | + | func getValueBalanceSupplier (account) = getNumberByKey(getKeyBalanceSupplier(account)) | |
68 | + | ||
69 | + | ||
70 | + | func getKeyCommit (item,user) = (((item + "_") + user) + "_commit") | |
71 | + | ||
72 | + | ||
73 | + | func getValueCommit (item,user) = getStrByKey(getKeyCommit(item, user)) | |
74 | + | ||
75 | + | ||
76 | + | func getKeyCommitsCount (item) = (item + "_comcnt") | |
77 | + | ||
78 | + | ||
79 | + | func getValueCommitsCount (item) = getNumberByKey(getKeyCommitsCount(item)) | |
80 | + | ||
81 | + | ||
82 | + | func getKeyReveal (item,user) = (((item + "_") + user) + "_reveal") | |
83 | + | ||
84 | + | ||
85 | + | func getValueReveal (item,user) = getStrByKey(getKeyReveal(item, user)) | |
86 | + | ||
87 | + | ||
88 | + | func getKeyItemStatus (item) = (item + "_status") | |
89 | + | ||
90 | + | ||
91 | + | func getValueItemStatus (item) = getStrByKey(getKeyItemStatus(item)) | |
92 | + | ||
93 | + | ||
94 | + | func getKeyVoteCount (item,vote) = ((item + "_res:") + vote) | |
95 | + | ||
96 | + | ||
97 | + | func getValueVoteCount (item,vote) = getNumberByKey(getKeyVoteCount(item, vote)) | |
5 | 98 | ||
6 | 99 | ||
7 | 100 | let verifier = "3Mwv6cMyrLP5CQ3dTCsheo4kQjLGfKZE5C4" | |
8 | 101 | ||
9 | 102 | let VERIFIED = "verified" | |
10 | 103 | ||
11 | 104 | let BLACKLISTED = "blacklist" | |
105 | + | ||
106 | + | func getExtKeyItemWhiteListStatus (item) = (item + "_verifier_status") | |
107 | + | ||
108 | + | ||
109 | + | func getExtAddressOracle () = extract(addressFromString(verifier)) | |
110 | + | ||
111 | + | ||
112 | + | func getExtValueItemWhiteListStatus (oracle,account) = { | |
113 | + | let str = match getString(oracle, getExtKeyItemWhiteListStatus(account)) { | |
114 | + | case a: String => | |
115 | + | a | |
116 | + | case _ => | |
117 | + | NONE | |
118 | + | } | |
119 | + | str | |
120 | + | } | |
121 | + | ||
122 | + | ||
123 | + | @Callable(i) | |
124 | + | func purchase (item) = { | |
125 | + | let pmt = extract(i.payment) | |
126 | + | if (isDefined(pmt.assetId)) | |
127 | + | then throw("WAVES tokens only at the moment") | |
128 | + | else { | |
129 | + | let userAddress = toBase58String(i.caller.bytes) | |
130 | + | let price = getValueItemPrice(item) | |
131 | + | let supplierAddress = getValueItemSupplier(item) | |
132 | + | if ((pmt.amount > price)) | |
133 | + | then throw("purchase amount cannot be less than item price") | |
134 | + | else if ((pmt.amount > price)) | |
135 | + | then throw("purchase amount cannot be higher than item price") | |
136 | + | else if ((supplierAddress == NONE)) | |
137 | + | then throw("supplier does not exist") | |
138 | + | else WriteSet([DataEntry(getKeyUserItemCounter(userAddress, item), (getValueUserItemCounter(userAddress, item) + 1)), DataEntry(getKeyBalanceSupplier(supplierAddress), (getValueBalanceSupplier(supplierAddress) + pmt.amount))]) | |
139 | + | } | |
140 | + | } | |
141 | + | ||
142 | + | ||
143 | + | ||
144 | + | @Callable(i) | |
145 | + | func withdraw () = { | |
146 | + | let supplierAddress = toBase58String(i.caller.bytes) | |
147 | + | let balance = getValueBalanceSupplier(supplierAddress) | |
148 | + | if ((0 >= balance)) | |
149 | + | then throw("insufficient balance") | |
150 | + | else ScriptResult(WriteSet([DataEntry(getKeyBalanceSupplier(supplierAddress), 0)]), TransferSet([ScriptTransfer(addressFromStringValue(supplierAddress), balance, unit)])) | |
151 | + | } | |
152 | + | ||
153 | + | ||
154 | + | ||
155 | + | @Callable(i) | |
156 | + | func voteCommit (item,hash) = { | |
157 | + | let user = toBase58String(i.caller.bytes) | |
158 | + | let commits = getValueCommitsCount(item) | |
159 | + | let status = getValueItemStatus(item) | |
160 | + | if ((commits >= VOTERS)) | |
161 | + | then throw("reached max num of voters") | |
162 | + | else if ((getValueCommit(item, user) != NONE)) | |
163 | + | then throw("user has already participated") | |
164 | + | else if ((getKeyItemSupplier(item) == NONE)) | |
165 | + | then throw("item does not exist") | |
166 | + | else if (if ((status != NONE)) | |
167 | + | then (status != VOTING) | |
168 | + | else false) | |
169 | + | then throw("voting is not possible") | |
170 | + | else WriteSet([DataEntry(getKeyCommit(item, user), hash), DataEntry(getKeyCommitsCount(item), (commits + 1)), DataEntry(getKeyItemStatus(item), if ((commits == VOTERS)) | |
171 | + | then REVEAL | |
172 | + | else VOTING)]) | |
173 | + | } | |
174 | + | ||
175 | + | ||
176 | + | ||
177 | + | @Callable(i) | |
178 | + | func voteReveal (item,vote,salt) = { | |
179 | + | let user = toBase58String(i.caller.bytes) | |
180 | + | let status = getValueItemStatus(item) | |
181 | + | let newVoteCount = (getValueVoteCount(item, vote) + 1) | |
182 | + | if ((toBase58String(sha256(toBytes((vote + salt)))) != getValueCommit(item, user))) | |
183 | + | then throw("reveal data is not valid") | |
184 | + | else if ((VOTERS > getValueCommitsCount(item))) | |
185 | + | then throw("max num of voters hasnt reached yet") | |
186 | + | else if ((getValueReveal(item, user) != NONE)) | |
187 | + | then throw("user has already partcipated") | |
188 | + | else if (if ((status != VOTING)) | |
189 | + | then (status != REVEAL) | |
190 | + | else false) | |
191 | + | then throw("wrong status") | |
192 | + | else if (if ((vote != FEATURED)) | |
193 | + | then (vote != DELISTED) | |
194 | + | else false) | |
195 | + | then throw("wrong vote") | |
196 | + | else if (if ((status == FEATURED)) | |
197 | + | then true | |
198 | + | else (status == DELISTED)) | |
199 | + | then throw("vote has finished") | |
200 | + | else WriteSet([DataEntry(getKeyReveal(item, user), vote), DataEntry(getKeyVoteCount(item, vote), newVoteCount), DataEntry(getKeyItemStatus(item), if ((newVoteCount >= QUORUM)) | |
201 | + | then vote | |
202 | + | else REVEAL)]) | |
203 | + | } | |
204 | + | ||
205 | + | ||
12 | 206 | ||
13 | 207 | @Callable(i) | |
14 | 208 | func setstatus (supplier,status) = { | |
15 | 209 | let account = toBase58String(i.caller.bytes) | |
16 | 210 | if ((account != verifier)) | |
17 | 211 | then throw("only oracle verifier are able to manage whitelist") | |
18 | 212 | else if (if ((status != VERIFIED)) | |
19 | 213 | then (status != BLACKLISTED) | |
20 | 214 | else false) | |
21 | 215 | then throw("wrong status") | |
22 | - | else WriteSet([DataEntry(getExtValueItemWhiteListState(supplier), status)]) | |
216 | + | else WriteSet([DataEntry(getExtKeyItemWhiteListStatus(supplier), status)]) | |
217 | + | } | |
218 | + | ||
219 | + | ||
220 | + | ||
221 | + | @Callable(i) | |
222 | + | func addItem (title,price,data) = { | |
223 | + | let supplierAddress = toBase58String(i.caller.bytes) | |
224 | + | let item = getKeyItem(supplierAddress, title) | |
225 | + | let supplierWhitelist = getExtValueItemWhiteListStatus(getExtAddressOracle(), supplierAddress) | |
226 | + | if ((0 >= price)) | |
227 | + | then throw("purchase amount cannot be less than item price") | |
228 | + | else if ((getValueItemSupplier(item) != NONE)) | |
229 | + | then throw("an item is already exist") | |
230 | + | else if ((supplierWhitelist == BLACKLISTED)) | |
231 | + | then throw("supplier's account has been blacklisted") | |
232 | + | else WriteSet([DataEntry(getKeyItemSupplier(item), supplierAddress), DataEntry(getKeyItemPrice(item), price), DataEntry(getKeyItemData(item), data), DataEntry(getExtKeyItemWhiteListStatus(supplierAddress), supplierWhitelist)]) | |
23 | 233 | } | |
24 | 234 | ||
25 | 235 |
github/deemru/w8io/169f3d6 49.50 ms ◑