tx · 4ivE1AGr4tkLf6aj5KdeM1VuUEnLG1yqANHszFQP6thM 3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r: -0.04000000 Waves 2022.01.15 22:59 [1880515] smart account 3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r > SELF 0.00000000 Waves
{ "type": 13, "id": "4ivE1AGr4tkLf6aj5KdeM1VuUEnLG1yqANHszFQP6thM", "fee": 4000000, "feeAssetId": null, "timestamp": 1642276831554, "version": 2, "chainId": 84, "sender": "3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r", "senderPublicKey": "GUHw1jkstNWTs9SX1KM3pMtq9HXjupvxiTd1urNhNoyY", "proofs": [ "mCrWzJXiS1cTNnSfhJBMJc6HSMJZNgWu5DHEy2BCnFJz3zLmZJCyjrUgm99rzkPc56xro77EWQ2NerxDEQeGZSU" ], "script": "base64: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", "height": 1880515, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 61zba1DFGcCSqhAZPKUUZRjm8wwBogJmdm1Txj9svZL2 Next: Cxym8uoY2kWiwWkG1yBzP1Cg6xBF259RnCmfHc7piFto Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let | |
4 | + | let holdingsAddressStr = "3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r" | |
5 | 5 | ||
6 | - | let | |
6 | + | let holdingsPublicKey = base58'GUHw1jkstNWTs9SX1KM3pMtq9HXjupvxiTd1urNhNoyY' | |
7 | 7 | ||
8 | - | let | |
8 | + | let holdingsAddress = addressFromPublicKey(holdingsPublicKey) | |
9 | 9 | ||
10 | - | let | |
10 | + | let transferCostPct = 25 | |
11 | 11 | ||
12 | - | let holdings = "3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r" | |
13 | - | ||
14 | - | let holdingsAddress = Address(fromBase58String(holdings)) | |
15 | - | ||
16 | - | func getBoundCoords (data) = { | |
17 | - | let $t0333355 = data | |
18 | - | let x = $t0333355._1 | |
19 | - | let y = $t0333355._2 | |
20 | - | let gen = $t0333355._3 | |
21 | - | let d = pow(2, 0, (gen - 1), 0, 0, HALFUP) | |
22 | - | let tl = $Tuple2((x - d), (y - d)) | |
23 | - | let tc = $Tuple2(x, (y - d)) | |
24 | - | let tr = $Tuple2((x + d), (y + d)) | |
25 | - | let l = $Tuple2((x - d), y) | |
26 | - | let r = $Tuple2((x + d), y) | |
27 | - | let bl = $Tuple2((x - d), (y + d)) | |
28 | - | let bc = $Tuple2(x, (y + d)) | |
29 | - | let br = $Tuple2((x + d), (y + d)) | |
30 | - | [$Tuple3(tl, tc, l), $Tuple3(tc, tr, r), $Tuple3(l, bl, bc), $Tuple3(r, bc, br)] | |
31 | - | } | |
12 | + | @Callable(i) | |
13 | + | func addOwnerAndAmount (ownerId,assetId,amount) = [StringEntry((("sale_" + assetId) + "_originalOwner"), ownerId), StringEntry((("sale_" + assetId) + "_amount"), amount)] | |
32 | 14 | ||
33 | 15 | ||
34 | - | func checkSquareForEvolve (coords,gen,ownerId) = { | |
35 | - | let $t0788816 = coords | |
36 | - | let xy1 = $t0788816._1 | |
37 | - | let xy2 = $t0788816._2 | |
38 | - | let xy3 = $t0788816._3 | |
39 | - | let xy1Key = (((((toString(xy1._1) + ",") + toString(xy1._2)) + ",") + gen) + "_owner") | |
40 | - | let xy2Key = (((((toString(xy2._1) + ",") + toString(xy2._2)) + ",") + gen) + "_owner") | |
41 | - | let xy3Key = (((((toString(xy3._1) + ",") + toString(xy3._2)) + ",") + gen) + "_owner") | |
42 | - | let xyVal1 = match getString(this, xy1Key) { | |
16 | + | ||
17 | + | @Callable(i) | |
18 | + | func buyFromHoldings (assetId) = { | |
19 | + | let ownerId = match getString(this, (("sale_" + assetId) + "_originalOwner")) { | |
43 | 20 | case _: Unit => | |
44 | 21 | "unset" | |
45 | 22 | case x: String => | |
47 | 24 | case _ => | |
48 | 25 | throw("Match error") | |
49 | 26 | } | |
50 | - | let xyVal2 = match getString(this, xy2Key) { | |
27 | + | let paymentAmount = valueOrElse(i.payments[0].amount, 0) | |
28 | + | let amount = match getString(this, (("sale_" + assetId) + "_amount")) { | |
51 | 29 | case _: Unit => | |
52 | - | | |
30 | + | 0 | |
53 | 31 | case x: String => | |
54 | - | x | |
32 | + | (valueOrElse(parseInt(x), 0) * 100000000) | |
55 | 33 | case _ => | |
56 | 34 | throw("Match error") | |
57 | 35 | } | |
58 | - | let xyVal3 = match getString(this, xy3Key) { | |
59 | - | case _: Unit => | |
60 | - | "unset" | |
61 | - | case x: String => | |
62 | - | x | |
63 | - | case _ => | |
64 | - | throw("Match error") | |
65 | - | } | |
66 | - | if (if ((xyVal1 == ownerId)) | |
67 | - | then (xyVal2 == ownerId) | |
68 | - | else false) | |
69 | - | then (xyVal3 == ownerId) | |
70 | - | else false | |
36 | + | if ((ownerId == "unset")) | |
37 | + | then throw("Original owner not found ") | |
38 | + | else if (if ((amount == 0)) | |
39 | + | then true | |
40 | + | else (amount > paymentAmount)) | |
41 | + | then throw(((("Payment and amount do not match. This assets costs " + toString(amount)) + "but you sent ") + toString(paymentAmount))) | |
42 | + | else { | |
43 | + | let transfer = [ScriptTransfer(i.caller, 1, fromBase58String(assetId))] | |
44 | + | if ((ownerId != holdingsAddressStr)) | |
45 | + | then { | |
46 | + | let amountToRemainInHoldings = (paymentAmount * (transferCostPct / 1000)) | |
47 | + | let amountToTransferToOwner = (paymentAmount - amountToRemainInHoldings) | |
48 | + | let ownerAddress = Address(fromBase58String(ownerId)) | |
49 | + | (transfer ++ [ScriptTransfer(ownerAddress, amountToTransferToOwner, unit)]) | |
50 | + | } | |
51 | + | else transfer | |
52 | + | } | |
71 | 53 | } | |
72 | 54 | ||
73 | 55 | ||
74 | - | func getXyReturn (xy,gen) = { | |
75 | - | let $t014921507 = xy | |
76 | - | let x = $t014921507._1 | |
77 | - | let y = $t014921507._2 | |
78 | - | $Tuple3(x, y, (gen + 1)) | |
79 | - | } | |
80 | - | ||
81 | - | ||
82 | - | func getXy (xyg,ownerId) = { | |
83 | - | let checkList = getBoundCoords(xyg) | |
84 | - | let $t016231644 = xyg | |
85 | - | let x = $t016231644._1 | |
86 | - | let y = $t016231644._2 | |
87 | - | let gen = $t016231644._3 | |
88 | - | let genStr = toString(gen) | |
89 | - | if (checkSquareForEvolve(checkList[0], genStr, ownerId)) | |
90 | - | then getXyReturn(checkList[0]._1, gen) | |
91 | - | else if (checkSquareForEvolve(checkList[1], genStr, ownerId)) | |
92 | - | then getXyReturn(checkList[1]._1, gen) | |
93 | - | else if (checkSquareForEvolve(checkList[2], genStr, ownerId)) | |
94 | - | then getXyReturn(checkList[2]._1, gen) | |
95 | - | else if (checkSquareForEvolve(checkList[3], genStr, ownerId)) | |
96 | - | then getXyReturn(checkList[3]._1, gen) | |
97 | - | else xyg | |
98 | - | } | |
99 | - | ||
100 | - | ||
101 | - | func checkForEvolve (xyg,ownerId) = { | |
102 | - | let $t022912312 = xyg | |
103 | - | let x = $t022912312._1 | |
104 | - | let y = $t022912312._2 | |
105 | - | let gen = $t022912312._3 | |
106 | - | let p1 = getXy(xyg, ownerId) | |
107 | - | if ((p1._3 == gen)) | |
108 | - | then p1 | |
109 | - | else { | |
110 | - | let p2 = getXy(p1, ownerId) | |
111 | - | if ((p2._3 == p1._3)) | |
112 | - | then p2 | |
113 | - | else { | |
114 | - | let p3 = getXy(p2, ownerId) | |
115 | - | if ((p3._3 == p2._3)) | |
116 | - | then p3 | |
117 | - | else { | |
118 | - | let p4 = getXy(p3, ownerId) | |
119 | - | if ((p4._3 == p3._3)) | |
120 | - | then p4 | |
121 | - | else { | |
122 | - | let p5 = getXy(p4, ownerId) | |
123 | - | if ((p5._3 == p4._3)) | |
124 | - | then p5 | |
125 | - | else { | |
126 | - | let p6 = getXy(p5, ownerId) | |
127 | - | if ((p6._3 == p5._3)) | |
128 | - | then p6 | |
129 | - | else { | |
130 | - | let p7 = getXy(p6, ownerId) | |
131 | - | if ((p7._3 == p6._3)) | |
132 | - | then p7 | |
133 | - | else { | |
134 | - | let p8 = getXy(p7, ownerId) | |
135 | - | if ((p8._3 == p7._3)) | |
136 | - | then p8 | |
137 | - | else { | |
138 | - | let p9 = getXy(p8, ownerId) | |
139 | - | if ((p9._3 == p8._3)) | |
140 | - | then p9 | |
141 | - | else getXy(getXy(p9, ownerId), ownerId) | |
142 | - | } | |
143 | - | } | |
144 | - | } | |
145 | - | } | |
146 | - | } | |
147 | - | } | |
148 | - | } | |
149 | - | } | |
150 | - | } | |
151 | - | ||
152 | - | ||
153 | - | func claimSquare (x,y,ownerId,transactionId) = { | |
154 | - | let $t033653462 = getXy($Tuple3(parseIntValue(x), parseIntValue(y), 1), ownerId) | |
155 | - | let resolvedX = $t033653462._1 | |
156 | - | let resolvedY = $t033653462._2 | |
157 | - | let resolvedGen = $t033653462._3 | |
158 | - | let resolvedXStr = toString(resolvedX) | |
159 | - | let resolvedYStr = toString(resolvedY) | |
160 | - | let resolvedGenStr = toString(resolvedGen) | |
161 | - | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
162 | - | let assetUrl = ((nftDomain + transactionId) + ".png") | |
163 | - | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
164 | - | let assetId = calculateAssetId(asset) | |
165 | - | let gen = resolvedGenStr | |
166 | - | let dataKeyPrefix = ((assetName + ",") + gen) | |
167 | - | $Tuple4(asset, assetId, assetUrl, dataKeyPrefix) | |
168 | - | } | |
169 | - | ||
170 | - | ||
171 | - | @Callable(i) | |
172 | - | func purchase (x,y) = { | |
173 | - | let ownerId = toBase58String(i.caller.bytes) | |
174 | - | let transactionId = toBase58String(i.transactionId) | |
175 | - | let $t040944184 = claimSquare(x, y, ownerId, transactionId) | |
176 | - | let asset = $t040944184._1 | |
177 | - | let assetId = $t040944184._2 | |
178 | - | let assetUrl = $t040944184._3 | |
179 | - | let dataKeyPrefix = $t040944184._4 | |
180 | - | [asset, StringEntry((dataKeyPrefix + "_assetId"), toBase58String(assetId)), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), StringEntry(transactionId, dataKeyPrefix), ScriptTransfer(i.caller, 1, assetId)] | |
181 | - | } | |
182 | - | ||
183 | - | ||
184 | - | ||
185 | - | @Callable(i) | |
186 | - | func autoBuy (x,y) = { | |
187 | - | let ownerId = toBase58String(holdingsAddress.bytes) | |
188 | - | let transactionId = toBase58String(i.transactionId) | |
189 | - | let $t046334723 = claimSquare(x, y, ownerId, transactionId) | |
190 | - | let asset = $t046334723._1 | |
191 | - | let assetId = $t046334723._2 | |
192 | - | let assetUrl = $t046334723._3 | |
193 | - | let dataKeyPrefix = $t046334723._4 | |
194 | - | let assetIdStr = toBase58String(assetId) | |
195 | - | let res = invoke(holdingsAddress, "addOwnerAndAmount", [ownerId, assetIdStr, "2"], [AttachedPayment(unit, 0)]) | |
196 | - | if ((res == res)) | |
197 | - | then [asset, StringEntry((dataKeyPrefix + "_assetId"), assetIdStr), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), StringEntry((("sale_" + assetIdStr) + "_originalOwner"), ownerId), IntegerEntry((("sale_" + assetIdStr) + "_amount"), 2), StringEntry(transactionId, dataKeyPrefix), ScriptTransfer(holdingsAddress, 1, assetId)] | |
198 | - | else throw("Strict value is not equal to itself.") | |
199 | - | } | |
200 | - | ||
201 | - | ||
202 | - | ||
203 | - | @Callable(i) | |
204 | - | func putForSale (assetId,amount) = { | |
205 | - | let ownerId = toBase58String(i.caller.bytes) | |
206 | - | let res = invoke(holdingsAddress, "addOwnerAndAmount", [ownerId, assetId, amount], [AttachedPayment(unit, 0)]) | |
207 | - | if ((res == res)) | |
208 | - | then [StringEntry((("sale_" + assetId) + "_originalOwner"), ownerId), StringEntry((("sale_" + assetId) + "_amount"), amount), ScriptTransfer(holdingsAddress, 1, fromBase58String(assetId))] | |
209 | - | else throw("Strict value is not equal to itself.") | |
210 | - | } | |
211 | - | ||
212 | - | ||
213 | - | ||
214 | - | @Callable(i) | |
215 | - | func finalizeSale (assetId,ownerId) = { | |
216 | - | let assetData = match assetInfo(fromBase58String(assetId)) { | |
217 | - | case ass: Asset => | |
218 | - | ass | |
219 | - | case _ => | |
220 | - | throw("Asset not found") | |
221 | - | } | |
222 | - | let assetName = assetData.name | |
223 | - | let xPart = split(assetName, ",") | |
224 | - | let restPart = split(xPart[1], " ") | |
225 | - | let x = match xPart[0] { | |
226 | - | case s: String => | |
227 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'x'") | |
228 | - | case _ => | |
229 | - | throw("'x' not found") | |
230 | - | } | |
231 | - | let y = match restPart[0] { | |
232 | - | case s: String => | |
233 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'y'") | |
234 | - | case _ => | |
235 | - | throw("'y' not found") | |
236 | - | } | |
237 | - | let gen = match restPart[2] { | |
238 | - | case s: String => | |
239 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'gen'") | |
240 | - | case _ => | |
241 | - | throw("'gen' not found") | |
242 | - | } | |
243 | - | let xStr = toString(x) | |
244 | - | let yStr = toString(y) | |
245 | - | let genStr = toString(gen) | |
246 | - | let $t065516614 = getXy($Tuple3(x, y, gen), ownerId) | |
247 | - | let parsedX = $t065516614._1 | |
248 | - | let parsedY = $t065516614._2 | |
249 | - | let parsedGen = $t065516614._3 | |
250 | - | let returnList = nil | |
251 | - | if ((parsedGen == gen)) | |
252 | - | then { | |
253 | - | let dataKey = ((((xStr + ",") + yStr) + ",") + genStr) | |
254 | - | $Tuple2([StringEntry((dataKey + "_owner"), ownerId), StringEntry((("sale_" + assetId) + "_originalOwner"), ""), IntegerEntry((("sale_" + assetId) + "_amount"), 0)], dataKey) | |
255 | - | } | |
256 | - | else { | |
257 | - | let transactionId = toBase58String(i.transactionId) | |
258 | - | let $t069977100 = claimSquare(xStr, yStr, ownerId, transactionId) | |
259 | - | let asset = $t069977100._1 | |
260 | - | let evolvedAssetId = $t069977100._2 | |
261 | - | let assetUrl = $t069977100._3 | |
262 | - | let dataKeyPrefix = $t069977100._4 | |
263 | - | let dataKey = dataKeyPrefix | |
264 | - | $Tuple2([asset, StringEntry((dataKey + "_assetId"), toBase58String(evolvedAssetId)), StringEntry((dataKey + "_asset"), assetUrl), StringEntry((dataKey + "_owner"), ownerId), StringEntry(transactionId, dataKey), ScriptTransfer(Address(fromBase58String(ownerId)), 1, fromBase58String(assetId))], dataKey) | |
265 | - | } | |
266 | - | } | |
267 | - | ||
56 | + | @Verifier(tx) | |
57 | + | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
268 | 58 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let | |
4 | + | let holdingsAddressStr = "3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r" | |
5 | 5 | ||
6 | - | let | |
6 | + | let holdingsPublicKey = base58'GUHw1jkstNWTs9SX1KM3pMtq9HXjupvxiTd1urNhNoyY' | |
7 | 7 | ||
8 | - | let | |
8 | + | let holdingsAddress = addressFromPublicKey(holdingsPublicKey) | |
9 | 9 | ||
10 | - | let | |
10 | + | let transferCostPct = 25 | |
11 | 11 | ||
12 | - | let holdings = "3N9R7u449Z1b76QpJp9u3gzPjMYQYnp3V7r" | |
13 | - | ||
14 | - | let holdingsAddress = Address(fromBase58String(holdings)) | |
15 | - | ||
16 | - | func getBoundCoords (data) = { | |
17 | - | let $t0333355 = data | |
18 | - | let x = $t0333355._1 | |
19 | - | let y = $t0333355._2 | |
20 | - | let gen = $t0333355._3 | |
21 | - | let d = pow(2, 0, (gen - 1), 0, 0, HALFUP) | |
22 | - | let tl = $Tuple2((x - d), (y - d)) | |
23 | - | let tc = $Tuple2(x, (y - d)) | |
24 | - | let tr = $Tuple2((x + d), (y + d)) | |
25 | - | let l = $Tuple2((x - d), y) | |
26 | - | let r = $Tuple2((x + d), y) | |
27 | - | let bl = $Tuple2((x - d), (y + d)) | |
28 | - | let bc = $Tuple2(x, (y + d)) | |
29 | - | let br = $Tuple2((x + d), (y + d)) | |
30 | - | [$Tuple3(tl, tc, l), $Tuple3(tc, tr, r), $Tuple3(l, bl, bc), $Tuple3(r, bc, br)] | |
31 | - | } | |
12 | + | @Callable(i) | |
13 | + | func addOwnerAndAmount (ownerId,assetId,amount) = [StringEntry((("sale_" + assetId) + "_originalOwner"), ownerId), StringEntry((("sale_" + assetId) + "_amount"), amount)] | |
32 | 14 | ||
33 | 15 | ||
34 | - | func checkSquareForEvolve (coords,gen,ownerId) = { | |
35 | - | let $t0788816 = coords | |
36 | - | let xy1 = $t0788816._1 | |
37 | - | let xy2 = $t0788816._2 | |
38 | - | let xy3 = $t0788816._3 | |
39 | - | let xy1Key = (((((toString(xy1._1) + ",") + toString(xy1._2)) + ",") + gen) + "_owner") | |
40 | - | let xy2Key = (((((toString(xy2._1) + ",") + toString(xy2._2)) + ",") + gen) + "_owner") | |
41 | - | let xy3Key = (((((toString(xy3._1) + ",") + toString(xy3._2)) + ",") + gen) + "_owner") | |
42 | - | let xyVal1 = match getString(this, xy1Key) { | |
16 | + | ||
17 | + | @Callable(i) | |
18 | + | func buyFromHoldings (assetId) = { | |
19 | + | let ownerId = match getString(this, (("sale_" + assetId) + "_originalOwner")) { | |
43 | 20 | case _: Unit => | |
44 | 21 | "unset" | |
45 | 22 | case x: String => | |
46 | 23 | x | |
47 | 24 | case _ => | |
48 | 25 | throw("Match error") | |
49 | 26 | } | |
50 | - | let xyVal2 = match getString(this, xy2Key) { | |
27 | + | let paymentAmount = valueOrElse(i.payments[0].amount, 0) | |
28 | + | let amount = match getString(this, (("sale_" + assetId) + "_amount")) { | |
51 | 29 | case _: Unit => | |
52 | - | | |
30 | + | 0 | |
53 | 31 | case x: String => | |
54 | - | x | |
32 | + | (valueOrElse(parseInt(x), 0) * 100000000) | |
55 | 33 | case _ => | |
56 | 34 | throw("Match error") | |
57 | 35 | } | |
58 | - | let xyVal3 = match getString(this, xy3Key) { | |
59 | - | case _: Unit => | |
60 | - | "unset" | |
61 | - | case x: String => | |
62 | - | x | |
63 | - | case _ => | |
64 | - | throw("Match error") | |
65 | - | } | |
66 | - | if (if ((xyVal1 == ownerId)) | |
67 | - | then (xyVal2 == ownerId) | |
68 | - | else false) | |
69 | - | then (xyVal3 == ownerId) | |
70 | - | else false | |
36 | + | if ((ownerId == "unset")) | |
37 | + | then throw("Original owner not found ") | |
38 | + | else if (if ((amount == 0)) | |
39 | + | then true | |
40 | + | else (amount > paymentAmount)) | |
41 | + | then throw(((("Payment and amount do not match. This assets costs " + toString(amount)) + "but you sent ") + toString(paymentAmount))) | |
42 | + | else { | |
43 | + | let transfer = [ScriptTransfer(i.caller, 1, fromBase58String(assetId))] | |
44 | + | if ((ownerId != holdingsAddressStr)) | |
45 | + | then { | |
46 | + | let amountToRemainInHoldings = (paymentAmount * (transferCostPct / 1000)) | |
47 | + | let amountToTransferToOwner = (paymentAmount - amountToRemainInHoldings) | |
48 | + | let ownerAddress = Address(fromBase58String(ownerId)) | |
49 | + | (transfer ++ [ScriptTransfer(ownerAddress, amountToTransferToOwner, unit)]) | |
50 | + | } | |
51 | + | else transfer | |
52 | + | } | |
71 | 53 | } | |
72 | 54 | ||
73 | 55 | ||
74 | - | func getXyReturn (xy,gen) = { | |
75 | - | let $t014921507 = xy | |
76 | - | let x = $t014921507._1 | |
77 | - | let y = $t014921507._2 | |
78 | - | $Tuple3(x, y, (gen + 1)) | |
79 | - | } | |
80 | - | ||
81 | - | ||
82 | - | func getXy (xyg,ownerId) = { | |
83 | - | let checkList = getBoundCoords(xyg) | |
84 | - | let $t016231644 = xyg | |
85 | - | let x = $t016231644._1 | |
86 | - | let y = $t016231644._2 | |
87 | - | let gen = $t016231644._3 | |
88 | - | let genStr = toString(gen) | |
89 | - | if (checkSquareForEvolve(checkList[0], genStr, ownerId)) | |
90 | - | then getXyReturn(checkList[0]._1, gen) | |
91 | - | else if (checkSquareForEvolve(checkList[1], genStr, ownerId)) | |
92 | - | then getXyReturn(checkList[1]._1, gen) | |
93 | - | else if (checkSquareForEvolve(checkList[2], genStr, ownerId)) | |
94 | - | then getXyReturn(checkList[2]._1, gen) | |
95 | - | else if (checkSquareForEvolve(checkList[3], genStr, ownerId)) | |
96 | - | then getXyReturn(checkList[3]._1, gen) | |
97 | - | else xyg | |
98 | - | } | |
99 | - | ||
100 | - | ||
101 | - | func checkForEvolve (xyg,ownerId) = { | |
102 | - | let $t022912312 = xyg | |
103 | - | let x = $t022912312._1 | |
104 | - | let y = $t022912312._2 | |
105 | - | let gen = $t022912312._3 | |
106 | - | let p1 = getXy(xyg, ownerId) | |
107 | - | if ((p1._3 == gen)) | |
108 | - | then p1 | |
109 | - | else { | |
110 | - | let p2 = getXy(p1, ownerId) | |
111 | - | if ((p2._3 == p1._3)) | |
112 | - | then p2 | |
113 | - | else { | |
114 | - | let p3 = getXy(p2, ownerId) | |
115 | - | if ((p3._3 == p2._3)) | |
116 | - | then p3 | |
117 | - | else { | |
118 | - | let p4 = getXy(p3, ownerId) | |
119 | - | if ((p4._3 == p3._3)) | |
120 | - | then p4 | |
121 | - | else { | |
122 | - | let p5 = getXy(p4, ownerId) | |
123 | - | if ((p5._3 == p4._3)) | |
124 | - | then p5 | |
125 | - | else { | |
126 | - | let p6 = getXy(p5, ownerId) | |
127 | - | if ((p6._3 == p5._3)) | |
128 | - | then p6 | |
129 | - | else { | |
130 | - | let p7 = getXy(p6, ownerId) | |
131 | - | if ((p7._3 == p6._3)) | |
132 | - | then p7 | |
133 | - | else { | |
134 | - | let p8 = getXy(p7, ownerId) | |
135 | - | if ((p8._3 == p7._3)) | |
136 | - | then p8 | |
137 | - | else { | |
138 | - | let p9 = getXy(p8, ownerId) | |
139 | - | if ((p9._3 == p8._3)) | |
140 | - | then p9 | |
141 | - | else getXy(getXy(p9, ownerId), ownerId) | |
142 | - | } | |
143 | - | } | |
144 | - | } | |
145 | - | } | |
146 | - | } | |
147 | - | } | |
148 | - | } | |
149 | - | } | |
150 | - | } | |
151 | - | ||
152 | - | ||
153 | - | func claimSquare (x,y,ownerId,transactionId) = { | |
154 | - | let $t033653462 = getXy($Tuple3(parseIntValue(x), parseIntValue(y), 1), ownerId) | |
155 | - | let resolvedX = $t033653462._1 | |
156 | - | let resolvedY = $t033653462._2 | |
157 | - | let resolvedGen = $t033653462._3 | |
158 | - | let resolvedXStr = toString(resolvedX) | |
159 | - | let resolvedYStr = toString(resolvedY) | |
160 | - | let resolvedGenStr = toString(resolvedGen) | |
161 | - | let assetName = ((resolvedXStr + ",") + resolvedYStr) | |
162 | - | let assetUrl = ((nftDomain + transactionId) + ".png") | |
163 | - | let asset = Issue(((assetName + " Gen ") + resolvedGenStr), assetUrl, 1, 0, false) | |
164 | - | let assetId = calculateAssetId(asset) | |
165 | - | let gen = resolvedGenStr | |
166 | - | let dataKeyPrefix = ((assetName + ",") + gen) | |
167 | - | $Tuple4(asset, assetId, assetUrl, dataKeyPrefix) | |
168 | - | } | |
169 | - | ||
170 | - | ||
171 | - | @Callable(i) | |
172 | - | func purchase (x,y) = { | |
173 | - | let ownerId = toBase58String(i.caller.bytes) | |
174 | - | let transactionId = toBase58String(i.transactionId) | |
175 | - | let $t040944184 = claimSquare(x, y, ownerId, transactionId) | |
176 | - | let asset = $t040944184._1 | |
177 | - | let assetId = $t040944184._2 | |
178 | - | let assetUrl = $t040944184._3 | |
179 | - | let dataKeyPrefix = $t040944184._4 | |
180 | - | [asset, StringEntry((dataKeyPrefix + "_assetId"), toBase58String(assetId)), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), StringEntry(transactionId, dataKeyPrefix), ScriptTransfer(i.caller, 1, assetId)] | |
181 | - | } | |
182 | - | ||
183 | - | ||
184 | - | ||
185 | - | @Callable(i) | |
186 | - | func autoBuy (x,y) = { | |
187 | - | let ownerId = toBase58String(holdingsAddress.bytes) | |
188 | - | let transactionId = toBase58String(i.transactionId) | |
189 | - | let $t046334723 = claimSquare(x, y, ownerId, transactionId) | |
190 | - | let asset = $t046334723._1 | |
191 | - | let assetId = $t046334723._2 | |
192 | - | let assetUrl = $t046334723._3 | |
193 | - | let dataKeyPrefix = $t046334723._4 | |
194 | - | let assetIdStr = toBase58String(assetId) | |
195 | - | let res = invoke(holdingsAddress, "addOwnerAndAmount", [ownerId, assetIdStr, "2"], [AttachedPayment(unit, 0)]) | |
196 | - | if ((res == res)) | |
197 | - | then [asset, StringEntry((dataKeyPrefix + "_assetId"), assetIdStr), StringEntry((dataKeyPrefix + "_asset"), assetUrl), StringEntry((dataKeyPrefix + "_owner"), ownerId), StringEntry((("sale_" + assetIdStr) + "_originalOwner"), ownerId), IntegerEntry((("sale_" + assetIdStr) + "_amount"), 2), StringEntry(transactionId, dataKeyPrefix), ScriptTransfer(holdingsAddress, 1, assetId)] | |
198 | - | else throw("Strict value is not equal to itself.") | |
199 | - | } | |
200 | - | ||
201 | - | ||
202 | - | ||
203 | - | @Callable(i) | |
204 | - | func putForSale (assetId,amount) = { | |
205 | - | let ownerId = toBase58String(i.caller.bytes) | |
206 | - | let res = invoke(holdingsAddress, "addOwnerAndAmount", [ownerId, assetId, amount], [AttachedPayment(unit, 0)]) | |
207 | - | if ((res == res)) | |
208 | - | then [StringEntry((("sale_" + assetId) + "_originalOwner"), ownerId), StringEntry((("sale_" + assetId) + "_amount"), amount), ScriptTransfer(holdingsAddress, 1, fromBase58String(assetId))] | |
209 | - | else throw("Strict value is not equal to itself.") | |
210 | - | } | |
211 | - | ||
212 | - | ||
213 | - | ||
214 | - | @Callable(i) | |
215 | - | func finalizeSale (assetId,ownerId) = { | |
216 | - | let assetData = match assetInfo(fromBase58String(assetId)) { | |
217 | - | case ass: Asset => | |
218 | - | ass | |
219 | - | case _ => | |
220 | - | throw("Asset not found") | |
221 | - | } | |
222 | - | let assetName = assetData.name | |
223 | - | let xPart = split(assetName, ",") | |
224 | - | let restPart = split(xPart[1], " ") | |
225 | - | let x = match xPart[0] { | |
226 | - | case s: String => | |
227 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'x'") | |
228 | - | case _ => | |
229 | - | throw("'x' not found") | |
230 | - | } | |
231 | - | let y = match restPart[0] { | |
232 | - | case s: String => | |
233 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'y'") | |
234 | - | case _ => | |
235 | - | throw("'y' not found") | |
236 | - | } | |
237 | - | let gen = match restPart[2] { | |
238 | - | case s: String => | |
239 | - | valueOrErrorMessage(parseInt(s), "Could not parse 'gen'") | |
240 | - | case _ => | |
241 | - | throw("'gen' not found") | |
242 | - | } | |
243 | - | let xStr = toString(x) | |
244 | - | let yStr = toString(y) | |
245 | - | let genStr = toString(gen) | |
246 | - | let $t065516614 = getXy($Tuple3(x, y, gen), ownerId) | |
247 | - | let parsedX = $t065516614._1 | |
248 | - | let parsedY = $t065516614._2 | |
249 | - | let parsedGen = $t065516614._3 | |
250 | - | let returnList = nil | |
251 | - | if ((parsedGen == gen)) | |
252 | - | then { | |
253 | - | let dataKey = ((((xStr + ",") + yStr) + ",") + genStr) | |
254 | - | $Tuple2([StringEntry((dataKey + "_owner"), ownerId), StringEntry((("sale_" + assetId) + "_originalOwner"), ""), IntegerEntry((("sale_" + assetId) + "_amount"), 0)], dataKey) | |
255 | - | } | |
256 | - | else { | |
257 | - | let transactionId = toBase58String(i.transactionId) | |
258 | - | let $t069977100 = claimSquare(xStr, yStr, ownerId, transactionId) | |
259 | - | let asset = $t069977100._1 | |
260 | - | let evolvedAssetId = $t069977100._2 | |
261 | - | let assetUrl = $t069977100._3 | |
262 | - | let dataKeyPrefix = $t069977100._4 | |
263 | - | let dataKey = dataKeyPrefix | |
264 | - | $Tuple2([asset, StringEntry((dataKey + "_assetId"), toBase58String(evolvedAssetId)), StringEntry((dataKey + "_asset"), assetUrl), StringEntry((dataKey + "_owner"), ownerId), StringEntry(transactionId, dataKey), ScriptTransfer(Address(fromBase58String(ownerId)), 1, fromBase58String(assetId))], dataKey) | |
265 | - | } | |
266 | - | } | |
267 | - | ||
56 | + | @Verifier(tx) | |
57 | + | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
268 | 58 |
github/deemru/w8io/169f3d6 64.84 ms ◑