tx · 9NrjDBUi2rYoToHx9WyhtGYRF1bMuVVtBCVMPJhGDXBv 3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox: -0.01000000 Waves 2022.10.28 12:24 [2292082] smart account 3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox > SELF 0.00000000 Waves
{ "type": 13, "id": "9NrjDBUi2rYoToHx9WyhtGYRF1bMuVVtBCVMPJhGDXBv", "fee": 1000000, "feeAssetId": null, "timestamp": 1666949130661, "version": 2, "chainId": 84, "sender": "3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox", "senderPublicKey": "3wSv69WqTiGQVZxyv9hfHfPvXTxrKrWFutonxuaf24vp", "proofs": [ "5LKUvfAbuD2gRgqQnYaLX58aDzDhFmbVjdga1bW6qMVZTbrdkaQwQZqSsutfM29DXCrkqewoxC7W46rkdhJSNS3K" ], "script": "base64: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", "height": 2292082, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: HkDNBXfjFVKxzGhwRmqFYnfDFHWmXb99ssUdTLCS5HSJ Next: 8Yhj12dxuzW1G6yk8AF1XegtZrraRqAFukgvPUgBqSzP Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let | |
4 | + | let incubatorAddress = base58'3PEktVux2RhchSN63DsDo4b4mz4QqzKSeDv' | |
5 | 5 | ||
6 | - | let | |
6 | + | let breederAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb' | |
7 | 7 | ||
8 | 8 | let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR' | |
9 | 9 | ||
10 | 10 | let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY' | |
11 | 11 | ||
12 | - | let | |
12 | + | let eggAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
13 | 13 | ||
14 | 14 | let kGlobalCounter = "GLOBAL_COUNTER" | |
15 | 15 | ||
53 | 53 | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress))) | |
54 | 54 | then "ART" | |
55 | 55 | else { | |
56 | - | let asset1 = match getString(Address( | |
56 | + | let asset1 = match getString(Address(incubatorAddress), toBase58String(assetId)) { | |
57 | 57 | case b: String => | |
58 | 58 | b | |
59 | 59 | case _ => | |
62 | 62 | if ((asset1 != "")) | |
63 | 63 | then asset1 | |
64 | 64 | else { | |
65 | - | let asset2 = match getString(Address( | |
65 | + | let asset2 = match getString(Address(breederAddress), toBase58String(assetId)) { | |
66 | 66 | case c: String => | |
67 | 67 | c | |
68 | 68 | case _ => | |
75 | 75 | } | |
76 | 76 | ||
77 | 77 | ||
78 | - | func getBidCancelResults (nftId,bidId) = { | |
79 | - | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftartSell")) | |
80 | - | let paymentAssetId = if ((isnftart == true)) | |
81 | - | then nftAssetId | |
78 | + | @Callable(i) | |
79 | + | func instantBuy (auctionId) = { | |
80 | + | let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell")) | |
81 | + | let paymentAssetId = if ((isEggSell == true)) | |
82 | + | then eggAssetId | |
82 | 83 | else unit | |
83 | - | let assetId = getStringValue(this, (("nft_" + nftId) + "_assetId")) | |
84 | - | let bidAuthor = tryGetString((((("nft_" + nftId) + "_bid_") + bidId) + "_author")) | |
85 | - | let bidAmount = tryGetInteger((((("nft_" + nftId) + "_bid_") + bidId) + "_amount")) | |
86 | - | [StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"nftId\": \"" + nftId) + "\", \"author\": \"") + bidAuthor) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"cancelled\"}")), StringEntry((((("nft_" + nftId) + "_bid_") + bidId) + "_status"), "cancelled"), DeleteEntry(((((("address_" + bidAuthor) + "_nft_") + nftId) + "_bid_") + bidId)), ScriptTransfer(Address(fromBase58String(bidAuthor)), bidAmount, paymentAssetId)] | |
87 | - | } | |
88 | - | ||
89 | - | ||
90 | - | @Callable(i) | |
91 | - | func cancelnft (nftId) = { | |
92 | - | let nftOwner = tryGetString((("nft_" + nftId) + "_owner")) | |
93 | - | if ((toString(i.originCaller) != nftOwner)) | |
94 | - | then throw("Only allowed to nft owner") | |
95 | - | else if ((tryGetString((("nft_" + nftId) + "_status")) != "open")) | |
96 | - | then throw("nft is close") | |
97 | - | else [StringEntry((("nft_" + nftId) + "_status"), "cancelled"), DeleteEntry((((("address_" + nftOwner) + "_nft_") + nftId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("nft_" + nftId) + "_assetId"))))] | |
98 | - | } | |
99 | - | ||
100 | - | ||
101 | - | ||
102 | - | @Callable(i) | |
103 | - | func nftBuy (nftId) = { | |
104 | - | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftart")) | |
105 | - | let paymentAssetId = if ((isnftart == true)) | |
106 | - | then nftAssetId | |
107 | - | else unit | |
108 | - | let paymentAssetName = if ((isnftart == true)) | |
109 | - | then "nftart" | |
84 | + | let paymentAssetName = if ((isEggSell == true)) | |
85 | + | then "EGG" | |
110 | 86 | else "WAVES" | |
111 | 87 | let pmt = value(i.payments[0]) | |
112 | 88 | let amount = pmt.amount | |
113 | - | let assetId = tryGetString(((" | |
89 | + | let assetId = tryGetString((("auction_" + auctionId) + "_assetId")) | |
114 | 90 | let bidId = toBase58String(i.transactionId) | |
115 | - | let | |
116 | - | let finalFee = if ((tryGetBoolean(((" | |
91 | + | let auctionStatus = tryGetString((("auction_" + auctionId) + "_status")) | |
92 | + | let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true)) | |
117 | 93 | then artefactsFeePercent | |
118 | 94 | else feePercent | |
119 | 95 | if ((pmt.assetId != paymentAssetId)) | |
120 | - | then throw(((" | |
121 | - | else if (( | |
122 | - | then throw(" | |
96 | + | then throw((("Auction does only support " + paymentAssetName) + " payments.")) | |
97 | + | else if ((auctionStatus != "open")) | |
98 | + | then throw("Auction is closed. You cannot place a bid.") | |
123 | 99 | else { | |
124 | - | let instantPrice = tryGetInteger(((" | |
100 | + | let instantPrice = tryGetInteger((("auction_" + auctionId) + "_instantPrice")) | |
125 | 101 | if ((instantPrice > amount)) | |
126 | 102 | then throw(("For instant purchase you need to pay at least " + toString(instantPrice))) | |
127 | 103 | else { | |
128 | - | let | |
104 | + | let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner")) | |
129 | 105 | let recordPrice = tryGetInteger((assetId + "_recordPrice")) | |
130 | 106 | let newRecordPrice = max([recordPrice, amount]) | |
131 | - | [StringEntry(((" | |
107 | + | [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)] | |
132 | 108 | } | |
133 | 109 | } | |
134 | 110 | } |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let | |
4 | + | let incubatorAddress = base58'3PEktVux2RhchSN63DsDo4b4mz4QqzKSeDv' | |
5 | 5 | ||
6 | - | let | |
6 | + | let breederAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb' | |
7 | 7 | ||
8 | 8 | let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR' | |
9 | 9 | ||
10 | 10 | let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY' | |
11 | 11 | ||
12 | - | let | |
12 | + | let eggAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
13 | 13 | ||
14 | 14 | let kGlobalCounter = "GLOBAL_COUNTER" | |
15 | 15 | ||
16 | 16 | let feePercent = 5 | |
17 | 17 | ||
18 | 18 | let artefactsFeePercent = 20 | |
19 | 19 | ||
20 | 20 | func tryGetInteger (key) = { | |
21 | 21 | let val = match getInteger(this, key) { | |
22 | 22 | case b: Int => | |
23 | 23 | b | |
24 | 24 | case _ => | |
25 | 25 | 0 | |
26 | 26 | } | |
27 | 27 | val | |
28 | 28 | } | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | func tryGetString (key) = { | |
32 | 32 | let val = match getString(this, key) { | |
33 | 33 | case b: String => | |
34 | 34 | b | |
35 | 35 | case _ => | |
36 | 36 | "" | |
37 | 37 | } | |
38 | 38 | val | |
39 | 39 | } | |
40 | 40 | ||
41 | 41 | ||
42 | 42 | func tryGetBoolean (key) = match getBoolean(this, key) { | |
43 | 43 | case b: Boolean => | |
44 | 44 | b | |
45 | 45 | case _ => | |
46 | 46 | false | |
47 | 47 | } | |
48 | 48 | ||
49 | 49 | ||
50 | 50 | func getGlobalCounter () = tryGetInteger(kGlobalCounter) | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress))) | |
54 | 54 | then "ART" | |
55 | 55 | else { | |
56 | - | let asset1 = match getString(Address( | |
56 | + | let asset1 = match getString(Address(incubatorAddress), toBase58String(assetId)) { | |
57 | 57 | case b: String => | |
58 | 58 | b | |
59 | 59 | case _ => | |
60 | 60 | "" | |
61 | 61 | } | |
62 | 62 | if ((asset1 != "")) | |
63 | 63 | then asset1 | |
64 | 64 | else { | |
65 | - | let asset2 = match getString(Address( | |
65 | + | let asset2 = match getString(Address(breederAddress), toBase58String(assetId)) { | |
66 | 66 | case c: String => | |
67 | 67 | c | |
68 | 68 | case _ => | |
69 | 69 | "" | |
70 | 70 | } | |
71 | 71 | if ((asset2 != "")) | |
72 | 72 | then asset2 | |
73 | 73 | else "" | |
74 | 74 | } | |
75 | 75 | } | |
76 | 76 | ||
77 | 77 | ||
78 | - | func getBidCancelResults (nftId,bidId) = { | |
79 | - | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftartSell")) | |
80 | - | let paymentAssetId = if ((isnftart == true)) | |
81 | - | then nftAssetId | |
78 | + | @Callable(i) | |
79 | + | func instantBuy (auctionId) = { | |
80 | + | let isEggSell = tryGetBoolean((("auction_" + auctionId) + "_eggSell")) | |
81 | + | let paymentAssetId = if ((isEggSell == true)) | |
82 | + | then eggAssetId | |
82 | 83 | else unit | |
83 | - | let assetId = getStringValue(this, (("nft_" + nftId) + "_assetId")) | |
84 | - | let bidAuthor = tryGetString((((("nft_" + nftId) + "_bid_") + bidId) + "_author")) | |
85 | - | let bidAmount = tryGetInteger((((("nft_" + nftId) + "_bid_") + bidId) + "_amount")) | |
86 | - | [StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"nftId\": \"" + nftId) + "\", \"author\": \"") + bidAuthor) + "\", \"amount\": \"") + toString(bidAmount)) + "\", \"status\": \"cancelled\"}")), StringEntry((((("nft_" + nftId) + "_bid_") + bidId) + "_status"), "cancelled"), DeleteEntry(((((("address_" + bidAuthor) + "_nft_") + nftId) + "_bid_") + bidId)), ScriptTransfer(Address(fromBase58String(bidAuthor)), bidAmount, paymentAssetId)] | |
87 | - | } | |
88 | - | ||
89 | - | ||
90 | - | @Callable(i) | |
91 | - | func cancelnft (nftId) = { | |
92 | - | let nftOwner = tryGetString((("nft_" + nftId) + "_owner")) | |
93 | - | if ((toString(i.originCaller) != nftOwner)) | |
94 | - | then throw("Only allowed to nft owner") | |
95 | - | else if ((tryGetString((("nft_" + nftId) + "_status")) != "open")) | |
96 | - | then throw("nft is close") | |
97 | - | else [StringEntry((("nft_" + nftId) + "_status"), "cancelled"), DeleteEntry((((("address_" + nftOwner) + "_nft_") + nftId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("nft_" + nftId) + "_assetId"))))] | |
98 | - | } | |
99 | - | ||
100 | - | ||
101 | - | ||
102 | - | @Callable(i) | |
103 | - | func nftBuy (nftId) = { | |
104 | - | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftart")) | |
105 | - | let paymentAssetId = if ((isnftart == true)) | |
106 | - | then nftAssetId | |
107 | - | else unit | |
108 | - | let paymentAssetName = if ((isnftart == true)) | |
109 | - | then "nftart" | |
84 | + | let paymentAssetName = if ((isEggSell == true)) | |
85 | + | then "EGG" | |
110 | 86 | else "WAVES" | |
111 | 87 | let pmt = value(i.payments[0]) | |
112 | 88 | let amount = pmt.amount | |
113 | - | let assetId = tryGetString(((" | |
89 | + | let assetId = tryGetString((("auction_" + auctionId) + "_assetId")) | |
114 | 90 | let bidId = toBase58String(i.transactionId) | |
115 | - | let | |
116 | - | let finalFee = if ((tryGetBoolean(((" | |
91 | + | let auctionStatus = tryGetString((("auction_" + auctionId) + "_status")) | |
92 | + | let finalFee = if ((tryGetBoolean((("auction_" + auctionId) + "_isArtefact")) == true)) | |
117 | 93 | then artefactsFeePercent | |
118 | 94 | else feePercent | |
119 | 95 | if ((pmt.assetId != paymentAssetId)) | |
120 | - | then throw(((" | |
121 | - | else if (( | |
122 | - | then throw(" | |
96 | + | then throw((("Auction does only support " + paymentAssetName) + " payments.")) | |
97 | + | else if ((auctionStatus != "open")) | |
98 | + | then throw("Auction is closed. You cannot place a bid.") | |
123 | 99 | else { | |
124 | - | let instantPrice = tryGetInteger(((" | |
100 | + | let instantPrice = tryGetInteger((("auction_" + auctionId) + "_instantPrice")) | |
125 | 101 | if ((instantPrice > amount)) | |
126 | 102 | then throw(("For instant purchase you need to pay at least " + toString(instantPrice))) | |
127 | 103 | else { | |
128 | - | let | |
104 | + | let auctionOwner = tryGetString((("auction_" + auctionId) + "_owner")) | |
129 | 105 | let recordPrice = tryGetInteger((assetId + "_recordPrice")) | |
130 | 106 | let newRecordPrice = max([recordPrice, amount]) | |
131 | - | [StringEntry(((" | |
107 | + | [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)] | |
132 | 108 | } | |
133 | 109 | } | |
134 | 110 | } | |
135 | 111 | ||
136 | 112 |
github/deemru/w8io/873ac7e 52.18 ms ◑