tx · Eq3cjaSrZ8dGipmGjKWAqPCdp6zhKHeXvBrG9sSecYWt

3MtVYGt1cJJB8g21cvSzJScK3hxUi9JHdcN:  -0.01400000 Waves

2021.12.23 14:15 [1846832] smart account 3MtVYGt1cJJB8g21cvSzJScK3hxUi9JHdcN > SELF 0.00000000 Waves

{ "type": 13, "id": "Eq3cjaSrZ8dGipmGjKWAqPCdp6zhKHeXvBrG9sSecYWt", "fee": 1400000, "feeAssetId": null, "timestamp": 1640258200116, "version": 2, "chainId": 84, "sender": "3MtVYGt1cJJB8g21cvSzJScK3hxUi9JHdcN", "senderPublicKey": "65qdY9G3EVQgF1GhvrT6rw2zPmUsFirt9Kjm5q5fdJvu", "proofs": [ "7Wvjrd9JicqdcMaH4wDXdhr7gq2wn6nKkmivTwXdcVHAXSTvEJgBZZptE5nPa44eioVdfC4WMGVaHTavLnzCThp" ], "script": "base64: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", "height": 1846832, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: FTEkwSbc8XAmWnCF4EFZgraG1amBjypGcxDuTJRiAdgE Next: HhQdsLCqEXJzjkMrS3NU4BBDob1vAYhxwWvJgjcC3UEa Diff:
OldNewDifferences
11 {-# STDLIB_VERSION 5 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
4-let incubatorAddress = base58'3PEktVux2RhchSN63DsDo4b4mz4QqzKSeDv'
4+let NFTIssuerAddress = base58'3N992tjd7EWM6dSHrdVjjjuJrLD4koNztZ9'
55
6-let breederAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb'
6+let eggAssetId = base58'2cf6jyVG19oHU79R8iHfqFEesjstr3e7nSYEUhb2WagB'
77
8-let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR'
9-
10-let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY'
11-
12-let eggAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS'
13-
14-let kGlobalCounter = "GLOBAL_COUNTER"
8+let collectorAddress = base58'3MpADDQFqadaCADNH9JDMQAGw9WEaMcymVU'
159
1610 let feePercent = 5
1711
4741 }
4842
4943
50-func getGlobalCounter () = tryGetInteger(kGlobalCounter)
51-
52-
53-func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress)))
54- then "ART"
55- else {
56- let asset1 = match getString(Address(incubatorAddress), toBase58String(assetId)) {
57- case b: String =>
58- b
59- case _ =>
60- ""
61- }
62- if ((asset1 != ""))
63- then asset1
64- else {
65- let asset2 = match getString(Address(breederAddress), toBase58String(assetId)) {
66- case c: String =>
67- c
68- case _ =>
69- ""
70- }
71- if ((asset2 != ""))
72- then asset2
73- else ""
74- }
75- }
76-
77-
7844 func getBidCancelResults (auctionId,bidId) = {
7945 let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
8046 let paymentAssetId = if ((isEggSell == true))
8753 }
8854
8955
56+func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(NFTIssuerAddress)))
57+ then "ART"
58+ else ""
59+
60+
9061 @Callable(i)
9162 func initAuction (startPrice,instantPrice,description,eggSell) = {
92- let globalCounter = getGlobalCounter()
93- let auctionId = (toBase58String(i.transactionId) + toString(globalCounter))
63+ let auctionId = toBase58String(i.transactionId)
9464 let pmt = value(i.payments[0])
9565 let assetId = value(pmt.assetId)
9666 let asset = getAssetGenotype(assetId)
9767 if ((asset == ""))
9868 then throw("You can only sell an NFT-duck created in incubator or breeder")
99- else [StringEntry((("auction_" + auctionId) + "_status"), "open"), BooleanEntry((("auction_" + auctionId) + "_eggSell"), (eggSell == "true")), IntegerEntry(kGlobalCounter, (globalCounter + 1)), StringEntry((("auction_" + toBase58String(assetId)) + "_last"), auctionId), StringEntry((("auction_" + auctionId) + "_assetGen"), asset), StringEntry((("auction_" + auctionId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("auction_" + auctionId) + "_startedAt"), lastBlock.timestamp), StringEntry((("auction_" + auctionId) + "_owner"), toString(i.originCaller)), StringEntry((("auction_" + auctionId) + "_description"), description), IntegerEntry((("auction_" + auctionId) + "_startPrice"), startPrice), BooleanEntry((("auction_" + auctionId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(artefactsAddress))), IntegerEntry((("auction_" + auctionId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_lockedNFT"), toBase58String(assetId))]
69+ else [StringEntry((("auction_" + auctionId) + "_status"), "open"), BooleanEntry((("auction_" + auctionId) + "_eggSell"), (eggSell == "true")), StringEntry((("auction_" + toBase58String(assetId)) + "_last"), auctionId), StringEntry((("auction_" + auctionId) + "_assetGen"), asset), StringEntry((("auction_" + auctionId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("auction_" + auctionId) + "_startedAt"), lastBlock.timestamp), StringEntry((("auction_" + auctionId) + "_owner"), toString(i.originCaller)), StringEntry((("auction_" + auctionId) + "_description"), description), IntegerEntry((("auction_" + auctionId) + "_startPrice"), startPrice), BooleanEntry((("auction_" + auctionId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(NFTIssuerAddress))), IntegerEntry((("auction_" + auctionId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_lockedNFT"), toBase58String(assetId))]
70+ }
71+
72+
73+
74+@Callable(i)
75+func placeBid (auctionId) = {
76+ let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
77+ let paymentAssetId = if ((isEggSell == true))
78+ then eggAssetId
79+ else unit
80+ let paymentAssetName = if ((isEggSell == true))
81+ then "EGG"
82+ else "WAVES"
83+ let pmt = value(i.payments[0])
84+ let amount = pmt.amount
85+ let bidId = toBase58String(i.transactionId)
86+ let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
87+ if ((pmt.assetId != paymentAssetId))
88+ then throw((("Auction does only support " + paymentAssetName) + " payments."))
89+ else {
90+ let minPrice = tryGetInteger((("auction_" + auctionId) + "_startPrice"))
91+ if ((minPrice > amount))
92+ then throw(("The minimal initial price is set as " + toString(minPrice)))
93+ else [StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"), toString(i.originCaller)), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"open\"}")), IntegerEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"), amount), StringEntry(((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_bid_") + bidId), assetId), StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "open")]
94+ }
95+ }
96+
97+
98+
99+@Callable(i)
100+func acceptBid (auctionId,bidId) = {
101+ let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
102+ let paymentAssetId = if ((isEggSell == true))
103+ then eggAssetId
104+ else unit
105+ let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
106+ let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
107+ let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
108+ let bidStatus = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"))
109+ let assetId = tryGetString((("auction_" + auctionId) + "_assetId"))
110+ let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true))
111+ then artefactsFeePercent
112+ else feePercent
113+ if ((toString(i.originCaller) != auctionOwner))
114+ then throw("Only allowed to auction owner")
115+ else if ((bidStatus != "open"))
116+ then throw("Bid was cancelled and cannot be accepted")
117+ else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
118+ then throw("Auction was closed")
119+ else {
120+ let recordPrice = tryGetInteger((assetId + "_recordPrice"))
121+ let newRecordPrice = max([recordPrice, bidAmount])
122+[StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "finished"), StringEntry((("auction_" + auctionId) + "_status"), "finished"), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"finished\"}")), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), bidAmount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), DeleteEntry(((((("address_" + bidAuthor) + "_auction_") + auctionId) + "_bid_") + bidId)), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.caller, fraction(bidAmount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(collectorAddress), fraction(bidAmount, finalFee, 100), paymentAssetId), ScriptTransfer(addressFromStringValue(bidAuthor), 1, fromBase58String(assetId))]
123+ }
124+ }
125+
126+
127+
128+@Callable(i)
129+func cancelBid (auctionId,bidId) = {
130+ let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
131+ let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
132+ let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
133+ if ((toString(i.originCaller) != bidAuthor))
134+ then throw("Only allowed to the bid author")
135+ else if ((tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status")) != "open"))
136+ then throw("bid is not open")
137+ else getBidCancelResults(auctionId, bidId)
100138 }
101139
102140
142180 let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
143181 let recordPrice = tryGetInteger((assetId + "_recordPrice"))
144182 let newRecordPrice = max([recordPrice, amount])
145-[StringEntry((("auction_" + auctionId) + "_status"), "finished"), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("auction_" + auctionId) + "_assetId")))), ScriptTransfer(addressFromStringValue(auctionOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(amount, finalFee, 100), paymentAssetId)]
183+[StringEntry((("auction_" + auctionId) + "_status"), "finished"), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("auction_" + auctionId) + "_assetId")))), ScriptTransfer(addressFromStringValue(auctionOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(collectorAddress), fraction(amount, finalFee, 100), paymentAssetId)]
146184 }
147185 }
148- }
149-
150-
151-
152-@Callable(i)
153-func placeBid (auctionId) = {
154- let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
155- let paymentAssetId = if ((isEggSell == true))
156- then eggAssetId
157- else unit
158- let paymentAssetName = if ((isEggSell == true))
159- then "EGG"
160- else "WAVES"
161- let pmt = value(i.payments[0])
162- let amount = pmt.amount
163- let bidId = toBase58String(i.transactionId)
164- let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
165- if ((pmt.assetId != paymentAssetId))
166- then throw((("Auction does only support " + paymentAssetName) + " payments."))
167- else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
168- then throw("Auction was closed")
169- else {
170- let minPrice = tryGetInteger((("auction_" + auctionId) + "_startPrice"))
171- if ((minPrice > amount))
172- then throw(("The minimal initial price is set as " + toString(minPrice)))
173- else [StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"), toString(i.originCaller)), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"open\"}")), IntegerEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"), amount), StringEntry(((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_bid_") + bidId), assetId), StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "open")]
174- }
175- }
176-
177-
178-
179-@Callable(i)
180-func cancelBid (auctionId,bidId) = {
181- let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
182- let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
183- let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
184- if ((toString(i.originCaller) != bidAuthor))
185- then throw("Only allowed to the bid author")
186- else if ((tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status")) != "open"))
187- then throw("bid is not open")
188- else getBidCancelResults(auctionId, bidId)
189- }
190-
191-
192-
193-@Callable(i)
194-func cancelOutdatedBid (auctionId,bidId) = throw("to be released")
195-
196-
197-
198-@Callable(i)
199-func acceptBid (auctionId,bidId) = {
200- let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
201- let paymentAssetId = if ((isEggSell == true))
202- then eggAssetId
203- else unit
204- let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
205- let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
206- let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
207- let bidStatus = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"))
208- let assetId = tryGetString((("auction_" + auctionId) + "_assetId"))
209- let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true))
210- then artefactsFeePercent
211- else feePercent
212- if ((toString(i.originCaller) != auctionOwner))
213- then throw("Only allowed to auction owner")
214- else if ((bidStatus != "open"))
215- then throw("Bid was cancelled and cannot be accepted")
216- else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
217- then throw("Auction was closed")
218- else {
219- let recordPrice = tryGetInteger((assetId + "_recordPrice"))
220- let newRecordPrice = max([recordPrice, bidAmount])
221-[StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "finished"), StringEntry((("auction_" + auctionId) + "_status"), "finished"), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"finished\"}")), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), bidAmount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), DeleteEntry(((((("address_" + bidAuthor) + "_auction_") + auctionId) + "_bid_") + bidId)), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.caller, fraction(bidAmount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(bidAmount, finalFee, 100), paymentAssetId), ScriptTransfer(addressFromStringValue(bidAuthor), 1, fromBase58String(assetId))]
222- }
223186 }
224187
225188
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 5 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
4-let incubatorAddress = base58'3PEktVux2RhchSN63DsDo4b4mz4QqzKSeDv'
4+let NFTIssuerAddress = base58'3N992tjd7EWM6dSHrdVjjjuJrLD4koNztZ9'
55
6-let breederAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb'
6+let eggAssetId = base58'2cf6jyVG19oHU79R8iHfqFEesjstr3e7nSYEUhb2WagB'
77
8-let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR'
9-
10-let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY'
11-
12-let eggAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS'
13-
14-let kGlobalCounter = "GLOBAL_COUNTER"
8+let collectorAddress = base58'3MpADDQFqadaCADNH9JDMQAGw9WEaMcymVU'
159
1610 let feePercent = 5
1711
1812 let artefactsFeePercent = 20
1913
2014 func tryGetInteger (key) = {
2115 let val = match getInteger(this, key) {
2216 case b: Int =>
2317 b
2418 case _ =>
2519 0
2620 }
2721 val
2822 }
2923
3024
3125 func tryGetString (key) = {
3226 let val = match getString(this, key) {
3327 case b: String =>
3428 b
3529 case _ =>
3630 ""
3731 }
3832 val
3933 }
4034
4135
4236 func tryGetBoolean (key) = match getBoolean(this, key) {
4337 case b: Boolean =>
4438 b
4539 case _ =>
4640 false
4741 }
4842
4943
50-func getGlobalCounter () = tryGetInteger(kGlobalCounter)
51-
52-
53-func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress)))
54- then "ART"
55- else {
56- let asset1 = match getString(Address(incubatorAddress), toBase58String(assetId)) {
57- case b: String =>
58- b
59- case _ =>
60- ""
61- }
62- if ((asset1 != ""))
63- then asset1
64- else {
65- let asset2 = match getString(Address(breederAddress), toBase58String(assetId)) {
66- case c: String =>
67- c
68- case _ =>
69- ""
70- }
71- if ((asset2 != ""))
72- then asset2
73- else ""
74- }
75- }
76-
77-
7844 func getBidCancelResults (auctionId,bidId) = {
7945 let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
8046 let paymentAssetId = if ((isEggSell == true))
8147 then eggAssetId
8248 else unit
8349 let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
8450 let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
8551 let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
8652 [StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + bidAuthor) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"cancelled\"}")), StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "cancelled"), DeleteEntry(((((("address_" + bidAuthor) + "_auction_") + auctionId) + "_bid_") + bidId)), ScriptTransfer(Address(fromBase58String(bidAuthor)), bidAmount, paymentAssetId)]
8753 }
8854
8955
56+func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(NFTIssuerAddress)))
57+ then "ART"
58+ else ""
59+
60+
9061 @Callable(i)
9162 func initAuction (startPrice,instantPrice,description,eggSell) = {
92- let globalCounter = getGlobalCounter()
93- let auctionId = (toBase58String(i.transactionId) + toString(globalCounter))
63+ let auctionId = toBase58String(i.transactionId)
9464 let pmt = value(i.payments[0])
9565 let assetId = value(pmt.assetId)
9666 let asset = getAssetGenotype(assetId)
9767 if ((asset == ""))
9868 then throw("You can only sell an NFT-duck created in incubator or breeder")
99- else [StringEntry((("auction_" + auctionId) + "_status"), "open"), BooleanEntry((("auction_" + auctionId) + "_eggSell"), (eggSell == "true")), IntegerEntry(kGlobalCounter, (globalCounter + 1)), StringEntry((("auction_" + toBase58String(assetId)) + "_last"), auctionId), StringEntry((("auction_" + auctionId) + "_assetGen"), asset), StringEntry((("auction_" + auctionId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("auction_" + auctionId) + "_startedAt"), lastBlock.timestamp), StringEntry((("auction_" + auctionId) + "_owner"), toString(i.originCaller)), StringEntry((("auction_" + auctionId) + "_description"), description), IntegerEntry((("auction_" + auctionId) + "_startPrice"), startPrice), BooleanEntry((("auction_" + auctionId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(artefactsAddress))), IntegerEntry((("auction_" + auctionId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_lockedNFT"), toBase58String(assetId))]
69+ else [StringEntry((("auction_" + auctionId) + "_status"), "open"), BooleanEntry((("auction_" + auctionId) + "_eggSell"), (eggSell == "true")), StringEntry((("auction_" + toBase58String(assetId)) + "_last"), auctionId), StringEntry((("auction_" + auctionId) + "_assetGen"), asset), StringEntry((("auction_" + auctionId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("auction_" + auctionId) + "_startedAt"), lastBlock.timestamp), StringEntry((("auction_" + auctionId) + "_owner"), toString(i.originCaller)), StringEntry((("auction_" + auctionId) + "_description"), description), IntegerEntry((("auction_" + auctionId) + "_startPrice"), startPrice), BooleanEntry((("auction_" + auctionId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(NFTIssuerAddress))), IntegerEntry((("auction_" + auctionId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_lockedNFT"), toBase58String(assetId))]
70+ }
71+
72+
73+
74+@Callable(i)
75+func placeBid (auctionId) = {
76+ let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
77+ let paymentAssetId = if ((isEggSell == true))
78+ then eggAssetId
79+ else unit
80+ let paymentAssetName = if ((isEggSell == true))
81+ then "EGG"
82+ else "WAVES"
83+ let pmt = value(i.payments[0])
84+ let amount = pmt.amount
85+ let bidId = toBase58String(i.transactionId)
86+ let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
87+ if ((pmt.assetId != paymentAssetId))
88+ then throw((("Auction does only support " + paymentAssetName) + " payments."))
89+ else {
90+ let minPrice = tryGetInteger((("auction_" + auctionId) + "_startPrice"))
91+ if ((minPrice > amount))
92+ then throw(("The minimal initial price is set as " + toString(minPrice)))
93+ else [StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"), toString(i.originCaller)), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"open\"}")), IntegerEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"), amount), StringEntry(((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_bid_") + bidId), assetId), StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "open")]
94+ }
95+ }
96+
97+
98+
99+@Callable(i)
100+func acceptBid (auctionId,bidId) = {
101+ let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
102+ let paymentAssetId = if ((isEggSell == true))
103+ then eggAssetId
104+ else unit
105+ let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
106+ let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
107+ let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
108+ let bidStatus = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"))
109+ let assetId = tryGetString((("auction_" + auctionId) + "_assetId"))
110+ let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true))
111+ then artefactsFeePercent
112+ else feePercent
113+ if ((toString(i.originCaller) != auctionOwner))
114+ then throw("Only allowed to auction owner")
115+ else if ((bidStatus != "open"))
116+ then throw("Bid was cancelled and cannot be accepted")
117+ else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
118+ then throw("Auction was closed")
119+ else {
120+ let recordPrice = tryGetInteger((assetId + "_recordPrice"))
121+ let newRecordPrice = max([recordPrice, bidAmount])
122+[StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "finished"), StringEntry((("auction_" + auctionId) + "_status"), "finished"), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"finished\"}")), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), bidAmount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), DeleteEntry(((((("address_" + bidAuthor) + "_auction_") + auctionId) + "_bid_") + bidId)), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.caller, fraction(bidAmount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(collectorAddress), fraction(bidAmount, finalFee, 100), paymentAssetId), ScriptTransfer(addressFromStringValue(bidAuthor), 1, fromBase58String(assetId))]
123+ }
124+ }
125+
126+
127+
128+@Callable(i)
129+func cancelBid (auctionId,bidId) = {
130+ let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
131+ let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
132+ let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
133+ if ((toString(i.originCaller) != bidAuthor))
134+ then throw("Only allowed to the bid author")
135+ else if ((tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status")) != "open"))
136+ then throw("bid is not open")
137+ else getBidCancelResults(auctionId, bidId)
100138 }
101139
102140
103141
104142 @Callable(i)
105143 func cancelAuction (auctionId) = {
106144 let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
107145 if ((toString(i.originCaller) != auctionOwner))
108146 then throw("Only allowed to auction owner")
109147 else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
110148 then throw("auction is close")
111149 else [StringEntry((("auction_" + auctionId) + "_status"), "cancelled"), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("auction_" + auctionId) + "_assetId"))))]
112150 }
113151
114152
115153
116154 @Callable(i)
117155 func instantBuy (auctionId) = {
118156 let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
119157 let paymentAssetId = if ((isEggSell == true))
120158 then eggAssetId
121159 else unit
122160 let paymentAssetName = if ((isEggSell == true))
123161 then "EGG"
124162 else "WAVES"
125163 let pmt = value(i.payments[0])
126164 let amount = pmt.amount
127165 let assetId = tryGetString((("auction_" + auctionId) + "_assetId"))
128166 let bidId = toBase58String(i.transactionId)
129167 let auctionStatus = tryGetString((("auction_" + auctionId) + "_status"))
130168 let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true))
131169 then artefactsFeePercent
132170 else feePercent
133171 if ((pmt.assetId != paymentAssetId))
134172 then throw((("Auction does only support " + paymentAssetName) + " payments."))
135173 else if ((auctionStatus != "open"))
136174 then throw("Auction is closed. You cannot place a bid.")
137175 else {
138176 let instantPrice = tryGetInteger((("auction_" + auctionId) + "_instantPrice"))
139177 if ((instantPrice > amount))
140178 then throw(("For instant purchase you need to pay at least " + toString(instantPrice)))
141179 else {
142180 let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
143181 let recordPrice = tryGetInteger((assetId + "_recordPrice"))
144182 let newRecordPrice = max([recordPrice, amount])
145-[StringEntry((("auction_" + auctionId) + "_status"), "finished"), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("auction_" + auctionId) + "_assetId")))), ScriptTransfer(addressFromStringValue(auctionOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(amount, finalFee, 100), paymentAssetId)]
183+[StringEntry((("auction_" + auctionId) + "_status"), "finished"), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("auction_" + auctionId) + "_assetId")))), ScriptTransfer(addressFromStringValue(auctionOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(collectorAddress), fraction(amount, finalFee, 100), paymentAssetId)]
146184 }
147185 }
148- }
149-
150-
151-
152-@Callable(i)
153-func placeBid (auctionId) = {
154- let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
155- let paymentAssetId = if ((isEggSell == true))
156- then eggAssetId
157- else unit
158- let paymentAssetName = if ((isEggSell == true))
159- then "EGG"
160- else "WAVES"
161- let pmt = value(i.payments[0])
162- let amount = pmt.amount
163- let bidId = toBase58String(i.transactionId)
164- let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
165- if ((pmt.assetId != paymentAssetId))
166- then throw((("Auction does only support " + paymentAssetName) + " payments."))
167- else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
168- then throw("Auction was closed")
169- else {
170- let minPrice = tryGetInteger((("auction_" + auctionId) + "_startPrice"))
171- if ((minPrice > amount))
172- then throw(("The minimal initial price is set as " + toString(minPrice)))
173- else [StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"), toString(i.originCaller)), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"open\"}")), IntegerEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"), amount), StringEntry(((((("address_" + toString(i.originCaller)) + "_auction_") + auctionId) + "_bid_") + bidId), assetId), StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "open")]
174- }
175- }
176-
177-
178-
179-@Callable(i)
180-func cancelBid (auctionId,bidId) = {
181- let assetId = getStringValue(this, (("auction_" + auctionId) + "_assetId"))
182- let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
183- let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
184- if ((toString(i.originCaller) != bidAuthor))
185- then throw("Only allowed to the bid author")
186- else if ((tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status")) != "open"))
187- then throw("bid is not open")
188- else getBidCancelResults(auctionId, bidId)
189- }
190-
191-
192-
193-@Callable(i)
194-func cancelOutdatedBid (auctionId,bidId) = throw("to be released")
195-
196-
197-
198-@Callable(i)
199-func acceptBid (auctionId,bidId) = {
200- let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell"))
201- let paymentAssetId = if ((isEggSell == true))
202- then eggAssetId
203- else unit
204- let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner"))
205- let bidAuthor = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_author"))
206- let bidAmount = tryGetInteger((((("auction_" + auctionId) + "_bid_") + bidId) + "_amount"))
207- let bidStatus = tryGetString((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"))
208- let assetId = tryGetString((("auction_" + auctionId) + "_assetId"))
209- let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true))
210- then artefactsFeePercent
211- else feePercent
212- if ((toString(i.originCaller) != auctionOwner))
213- then throw("Only allowed to auction owner")
214- else if ((bidStatus != "open"))
215- then throw("Bid was cancelled and cannot be accepted")
216- else if ((tryGetString((("auction_" + auctionId) + "_status")) != "open"))
217- then throw("Auction was closed")
218- else {
219- let recordPrice = tryGetInteger((assetId + "_recordPrice"))
220- let newRecordPrice = max([recordPrice, bidAmount])
221-[StringEntry((((("auction_" + auctionId) + "_bid_") + bidId) + "_status"), "finished"), StringEntry((("auction_" + auctionId) + "_status"), "finished"), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"auctionId\": \"" + auctionId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"finished\"}")), IntegerEntry((("auction_" + auctionId) + "_finalPrice"), bidAmount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), DeleteEntry(((((("address_" + bidAuthor) + "_auction_") + auctionId) + "_bid_") + bidId)), DeleteEntry((((("address_" + auctionOwner) + "_auction_") + auctionId) + "_lockedNFT")), ScriptTransfer(i.caller, fraction(bidAmount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(bidAmount, finalFee, 100), paymentAssetId), ScriptTransfer(addressFromStringValue(bidAuthor), 1, fromBase58String(assetId))]
222- }
223186 }
224187
225188
226189 @Verifier(tx)
227190 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
228191

github/deemru/w8io/03bedc9 
54.61 ms