tx · 4iZyHkmu2beq3hsnxQokWURA3za1JssNxNDvDvwMUYU4 3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox: -0.01000000 Waves 2022.10.17 15:58 [2276406] smart account 3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox > SELF 0.00000000 Waves
{ "type": 13, "id": "4iZyHkmu2beq3hsnxQokWURA3za1JssNxNDvDvwMUYU4", "fee": 1000000, "feeAssetId": null, "timestamp": 1666011552191, "version": 2, "chainId": 84, "sender": "3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox", "senderPublicKey": "3wSv69WqTiGQVZxyv9hfHfPvXTxrKrWFutonxuaf24vp", "proofs": [ "4ak1XhvAFGfsuE5uqp9g2BcuNwDYE8GFciEra4KYWjcrWUWfBHa21Jr8esGoR1T6XM7hnnGZsowG85kH8pWfbzBi" ], "script": "base64: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", "height": 2276406, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6zBwn2CVJLQXFzoCB9KXzkUAG6qPHkCKq2D3vvp3RZ2Y Next: HkDNBXfjFVKxzGhwRmqFYnfDFHWmXb99ssUdTLCS5HSJ Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let ownerAddress = base58'3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox' | |
5 | 5 | ||
6 | - | let ownerAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
6 | + | let nftAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb' | |
7 | + | ||
8 | + | let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR' | |
9 | + | ||
10 | + | let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY' | |
11 | + | ||
12 | + | let nftAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
7 | 13 | ||
8 | 14 | let kGlobalCounter = "GLOBAL_COUNTER" | |
9 | 15 | ||
10 | 16 | let feePercent = 5 | |
17 | + | ||
18 | + | let artefactsFeePercent = 20 | |
11 | 19 | ||
12 | 20 | func tryGetInteger (key) = { | |
13 | 21 | let val = match getInteger(this, key) { | |
42 | 50 | func getGlobalCounter () = tryGetInteger(kGlobalCounter) | |
43 | 51 | ||
44 | 52 | ||
45 | - | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address( | |
53 | + | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress))) | |
46 | 54 | then "ART" | |
47 | 55 | else { | |
48 | 56 | let asset1 = match getString(Address(ownerAddress), toBase58String(assetId)) { | |
54 | 62 | if ((asset1 != "")) | |
55 | 63 | then asset1 | |
56 | 64 | else { | |
57 | - | let asset2 = match getString(Address( | |
65 | + | let asset2 = match getString(Address(nftAddress), toBase58String(assetId)) { | |
58 | 66 | case c: String => | |
59 | 67 | c | |
60 | 68 | case _ => | |
67 | 75 | } | |
68 | 76 | ||
69 | 77 | ||
70 | - | @Callable(i) | |
71 | - | func additem (nft_name,nft_owner,nft_dAppAddress,nft_type,nft_tags,startPrice,instantPrice,description,nft_onSell) = { | |
72 | - | let globalCounter = getGlobalCounter() | |
73 | - | let additemId = (toBase58String(i.transactionId) + toString(globalCounter)) | |
74 | - | let pmt = value(i.payments[0]) | |
75 | - | let assetId = value(pmt.assetId) | |
76 | - | let asset = getAssetGenotype(assetId) | |
77 | - | if ((asset == "")) | |
78 | - | then throw("") | |
79 | - | else [StringEntry((("additem_" + additemId) + "_status"), "open"), BooleanEntry((("additem_" + additemId) + "_nft_onSell"), (nft_onSell == "true")), IntegerEntry(kGlobalCounter, (globalCounter + 1)), StringEntry((("additem_" + toBase58String(assetId)) + "_last"), additemId), StringEntry((("additem_" + additemId) + "_assetGen"), asset), StringEntry((("additem_" + additemId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("additem_" + additemId) + "_startedAt"), lastBlock.timestamp), StringEntry((("additem_" + additemId) + "_owner"), toString(i.originCaller)), StringEntry((("additem_" + additemId) + "_nft_name"), nft_name), StringEntry((("additem_" + additemId) + "_nft_owner"), nft_owner), IntegerEntry((("additem_" + additemId) + "_nft_dAppAddress"), nft_dAppAddress), StringEntry((("additem_" + additemId) + "_nft_type"), nft_type), StringEntry((("additem_" + additemId) + "_nft_tags"), nft_tags), StringEntry((("additem_" + additemId) + "_description"), description), IntegerEntry((("additem_" + additemId) + "_startPrice"), startPrice), BooleanEntry((("additem_" + additemId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(ownerAddress))), IntegerEntry((("additem_" + additemId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_additem_") + additemId) + "_lockedNFT"), toBase58String(assetId))] | |
78 | + | func getBidCancelResults (nftId,bidId) = { | |
79 | + | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftartSell")) | |
80 | + | let paymentAssetId = if ((isnftart == true)) | |
81 | + | then nftAssetId | |
82 | + | 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)] | |
80 | 87 | } | |
81 | 88 | ||
82 | 89 | ||
83 | - | @Verifier(tx) | |
84 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
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" | |
110 | + | else "WAVES" | |
111 | + | let pmt = value(i.payments[0]) | |
112 | + | let amount = pmt.amount | |
113 | + | let assetId = tryGetString((("nft_" + nftId) + "_assetId")) | |
114 | + | let bidId = toBase58String(i.transactionId) | |
115 | + | let nftStatus = tryGetString((("nft_" + nftId) + "_status")) | |
116 | + | let finalFee = if ((tryGetBoolean((("nft_" + nftId) + "_isArtefact")) == true)) | |
117 | + | then artefactsFeePercent | |
118 | + | else feePercent | |
119 | + | if ((pmt.assetId != paymentAssetId)) | |
120 | + | then throw((("nft does only support " + paymentAssetName) + " payments.")) | |
121 | + | else if ((nftStatus != "open")) | |
122 | + | then throw("nft is closed. You cannot place a bid.") | |
123 | + | else { | |
124 | + | let instantPrice = tryGetInteger((("nft_" + nftId) + "_instantPrice")) | |
125 | + | if ((instantPrice > amount)) | |
126 | + | then throw(("For instant purchase you need to pay at least " + toString(instantPrice))) | |
127 | + | else { | |
128 | + | let nftOwner = tryGetString((("nft_" + nftId) + "_owner")) | |
129 | + | let recordPrice = tryGetInteger((assetId + "_recordPrice")) | |
130 | + | let newRecordPrice = max([recordPrice, amount]) | |
131 | + | [StringEntry((("nft_" + nftId) + "_status"), "finished"), IntegerEntry((("nft_" + nftId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"nftId\": \"" + nftId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + nftOwner) + "_nft_") + nftId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("nft_" + nftId) + "_assetId")))), ScriptTransfer(addressFromStringValue(nftOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(amount, finalFee, 100), paymentAssetId)] | |
132 | + | } | |
133 | + | } | |
134 | + | } | |
135 | + | ||
85 | 136 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let ownerAddress = base58'3MtWYHeMrDBXUmBKtXWFq8eBv3p7X7k2fox' | |
5 | 5 | ||
6 | - | let ownerAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
6 | + | let nftAddress = base58'3PDVuU45H7Eh5dmtNbnRNRStGwULA7NY6Hb' | |
7 | + | ||
8 | + | let artefactsAddress = base58'3P5E9xamcWoymiqLx8ZdmR7o4fJSRMGp1WR' | |
9 | + | ||
10 | + | let feeAggregator = base58'3P6AobNbcQ3ZjcRY37mJPKN8PP9Giz8kgeY' | |
11 | + | ||
12 | + | let nftAssetId = base58'C1iWsKGqLwjHUndiQ7iXpdmPum9PeCDFfyXBdJJosDRS' | |
7 | 13 | ||
8 | 14 | let kGlobalCounter = "GLOBAL_COUNTER" | |
9 | 15 | ||
10 | 16 | let feePercent = 5 | |
17 | + | ||
18 | + | let artefactsFeePercent = 20 | |
11 | 19 | ||
12 | 20 | func tryGetInteger (key) = { | |
13 | 21 | let val = match getInteger(this, key) { | |
14 | 22 | case b: Int => | |
15 | 23 | b | |
16 | 24 | case _ => | |
17 | 25 | 0 | |
18 | 26 | } | |
19 | 27 | val | |
20 | 28 | } | |
21 | 29 | ||
22 | 30 | ||
23 | 31 | func tryGetString (key) = { | |
24 | 32 | let val = match getString(this, key) { | |
25 | 33 | case b: String => | |
26 | 34 | b | |
27 | 35 | case _ => | |
28 | 36 | "" | |
29 | 37 | } | |
30 | 38 | val | |
31 | 39 | } | |
32 | 40 | ||
33 | 41 | ||
34 | 42 | func tryGetBoolean (key) = match getBoolean(this, key) { | |
35 | 43 | case b: Boolean => | |
36 | 44 | b | |
37 | 45 | case _ => | |
38 | 46 | false | |
39 | 47 | } | |
40 | 48 | ||
41 | 49 | ||
42 | 50 | func getGlobalCounter () = tryGetInteger(kGlobalCounter) | |
43 | 51 | ||
44 | 52 | ||
45 | - | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address( | |
53 | + | func getAssetGenotype (assetId) = if ((value(assetInfo(assetId)).issuer == Address(artefactsAddress))) | |
46 | 54 | then "ART" | |
47 | 55 | else { | |
48 | 56 | let asset1 = match getString(Address(ownerAddress), toBase58String(assetId)) { | |
49 | 57 | case b: String => | |
50 | 58 | b | |
51 | 59 | case _ => | |
52 | 60 | "" | |
53 | 61 | } | |
54 | 62 | if ((asset1 != "")) | |
55 | 63 | then asset1 | |
56 | 64 | else { | |
57 | - | let asset2 = match getString(Address( | |
65 | + | let asset2 = match getString(Address(nftAddress), toBase58String(assetId)) { | |
58 | 66 | case c: String => | |
59 | 67 | c | |
60 | 68 | case _ => | |
61 | 69 | "" | |
62 | 70 | } | |
63 | 71 | if ((asset2 != "")) | |
64 | 72 | then asset2 | |
65 | 73 | else "" | |
66 | 74 | } | |
67 | 75 | } | |
68 | 76 | ||
69 | 77 | ||
70 | - | @Callable(i) | |
71 | - | func additem (nft_name,nft_owner,nft_dAppAddress,nft_type,nft_tags,startPrice,instantPrice,description,nft_onSell) = { | |
72 | - | let globalCounter = getGlobalCounter() | |
73 | - | let additemId = (toBase58String(i.transactionId) + toString(globalCounter)) | |
74 | - | let pmt = value(i.payments[0]) | |
75 | - | let assetId = value(pmt.assetId) | |
76 | - | let asset = getAssetGenotype(assetId) | |
77 | - | if ((asset == "")) | |
78 | - | then throw("") | |
79 | - | else [StringEntry((("additem_" + additemId) + "_status"), "open"), BooleanEntry((("additem_" + additemId) + "_nft_onSell"), (nft_onSell == "true")), IntegerEntry(kGlobalCounter, (globalCounter + 1)), StringEntry((("additem_" + toBase58String(assetId)) + "_last"), additemId), StringEntry((("additem_" + additemId) + "_assetGen"), asset), StringEntry((("additem_" + additemId) + "_assetId"), toBase58String(assetId)), IntegerEntry((("additem_" + additemId) + "_startedAt"), lastBlock.timestamp), StringEntry((("additem_" + additemId) + "_owner"), toString(i.originCaller)), StringEntry((("additem_" + additemId) + "_nft_name"), nft_name), StringEntry((("additem_" + additemId) + "_nft_owner"), nft_owner), IntegerEntry((("additem_" + additemId) + "_nft_dAppAddress"), nft_dAppAddress), StringEntry((("additem_" + additemId) + "_nft_type"), nft_type), StringEntry((("additem_" + additemId) + "_nft_tags"), nft_tags), StringEntry((("additem_" + additemId) + "_description"), description), IntegerEntry((("additem_" + additemId) + "_startPrice"), startPrice), BooleanEntry((("additem_" + additemId) + "_isArtefact"), (value(assetInfo(assetId)).issuer == Address(ownerAddress))), IntegerEntry((("additem_" + additemId) + "_instantPrice"), instantPrice), StringEntry((((("address_" + toString(i.originCaller)) + "_additem_") + additemId) + "_lockedNFT"), toBase58String(assetId))] | |
78 | + | func getBidCancelResults (nftId,bidId) = { | |
79 | + | let isnftart = tryGetBoolean((("nft_" + nftId) + "_nftartSell")) | |
80 | + | let paymentAssetId = if ((isnftart == true)) | |
81 | + | then nftAssetId | |
82 | + | 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)] | |
80 | 87 | } | |
81 | 88 | ||
82 | 89 | ||
83 | - | @Verifier(tx) | |
84 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
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" | |
110 | + | else "WAVES" | |
111 | + | let pmt = value(i.payments[0]) | |
112 | + | let amount = pmt.amount | |
113 | + | let assetId = tryGetString((("nft_" + nftId) + "_assetId")) | |
114 | + | let bidId = toBase58String(i.transactionId) | |
115 | + | let nftStatus = tryGetString((("nft_" + nftId) + "_status")) | |
116 | + | let finalFee = if ((tryGetBoolean((("nft_" + nftId) + "_isArtefact")) == true)) | |
117 | + | then artefactsFeePercent | |
118 | + | else feePercent | |
119 | + | if ((pmt.assetId != paymentAssetId)) | |
120 | + | then throw((("nft does only support " + paymentAssetName) + " payments.")) | |
121 | + | else if ((nftStatus != "open")) | |
122 | + | then throw("nft is closed. You cannot place a bid.") | |
123 | + | else { | |
124 | + | let instantPrice = tryGetInteger((("nft_" + nftId) + "_instantPrice")) | |
125 | + | if ((instantPrice > amount)) | |
126 | + | then throw(("For instant purchase you need to pay at least " + toString(instantPrice))) | |
127 | + | else { | |
128 | + | let nftOwner = tryGetString((("nft_" + nftId) + "_owner")) | |
129 | + | let recordPrice = tryGetInteger((assetId + "_recordPrice")) | |
130 | + | let newRecordPrice = max([recordPrice, amount]) | |
131 | + | [StringEntry((("nft_" + nftId) + "_status"), "finished"), IntegerEntry((("nft_" + nftId) + "_finalPrice"), amount), IntegerEntry((assetId + "_recordPrice"), newRecordPrice), StringEntry((((("assetId_" + assetId) + "_bid_") + bidId) + "_data"), (((((("{\"nftId\": \"" + nftId) + "\", \"author\": \"") + toString(i.originCaller)) + "\", \"amount\": \"") + toString(amount)) + "\", \"status\": \"finished\"}")), DeleteEntry((((("address_" + nftOwner) + "_nft_") + nftId) + "_lockedNFT")), ScriptTransfer(i.originCaller, 1, fromBase58String(getStringValue(this, (("nft_" + nftId) + "_assetId")))), ScriptTransfer(addressFromStringValue(nftOwner), fraction(amount, (100 - finalFee), 100), paymentAssetId), ScriptTransfer(Address(feeAggregator), fraction(amount, finalFee, 100), paymentAssetId)] | |
132 | + | } | |
133 | + | } | |
134 | + | } | |
135 | + | ||
85 | 136 |
github/deemru/w8io/169f3d6 34.27 ms ◑![]()