tx · FafG5DvVanaRDEkCksLGrm7X1z6BKffizJEzQtzvwLwr 3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD: -0.01000000 Waves 2023.07.30 13:43 [2688500] smart account 3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD > SELF 0.00000000 Waves
{ "type": 13, "id": "FafG5DvVanaRDEkCksLGrm7X1z6BKffizJEzQtzvwLwr", "fee": 1000000, "feeAssetId": null, "timestamp": 1690713889320, "version": 2, "chainId": 84, "sender": "3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD", "senderPublicKey": "G6PnkMn8MpXBkNwsQKMn1o1V7EKMgZyHCJRdFMQuouBC", "proofs": [ "3dW76QbV8P1DLHr34zGvhbtruxQwVPPej5pLYkF1JyR6NR1xDhN7cJw4SdxLrXgsEWnHssHWxQXZzcJgXKnRFkfJ" ], "script": "base64:BgIJCAISABIDCgEBBwAQY29udHJhY3RGaWxlTmFtZQICcDEAA1NFUAIBXwAIa2Fzc2V0SWQCB0Fzc2V0SUQACWtuZXdUb2tlbgIFVG9rZW4BCmtleUFzc2V0SUQACQC5CQIJAMwIAgICJXMJAMwIAgIHYXNzZXRJRAUDbmlsBQNTRVABB3dyYXBFcnIBA21zZwkAuQkCCQDMCAIFEGNvbnRyYWN0RmlsZU5hbWUJAMwIAgIBOgkAzAgCBQNtc2cFA25pbAIAAQh0aHJvd0VycgEDbXNnCQACAQkBB3dyYXBFcnIBBQNtc2cCAWkBDXRva2VuSXNzdWFuY2UABARuYW1lAghQUkFDVElDRQQLZGVzY3JpcHRpb24CCjE6MTAgd2F2ZXMECHF1YW50aXR5AICt4gQECGRlY2ltYWxzAAMEC2lzc3VlX3Rva2VuCQDCCAUFBG5hbWUFC2Rlc2NyaXB0aW9uBQhxdWFudGl0eQUIZGVjaW1hbHMGBAdhc3NldElkCQC4CAEFC2lzc3VlX3Rva2VuCQDMCAIFC2lzc3VlX3Rva2VuCQDMCAIJAQtCaW5hcnlFbnRyeQIFCGthc3NldElkBQdhc3NldElkCQDMCAIJAQtTdHJpbmdFbnRyeQIFCWtuZXdUb2tlbggFC2lzc3VlX3Rva2VuBG5hbWUFA25pbAFpAQhidXlUb2tlbgEIcXVhbnRpdHkECndhdmVzT3JFcnIJAAACCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFBHVuaXQEB2Fzc2V0SWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkBEUBleHRyTmF0aXZlKDEwNTIpAgUEdGhpcwUIa2Fzc2V0SWQCIWlkINGC0L7QutC10L3QsCDQvdC1INC90LDQudC00LXQvQQNcGF5bWVudEFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQEC3Rva2VuX3ByaWNlAKCNBgQKYW1vdW50X2R1ZQkAaAIFC3Rva2VuX3ByaWNlBQhxdWFudGl0eQQHcGF5bWVudAQHJG1hdGNoMAkAkQMCCAUBaQhwYXltZW50cwAAAwkAAQIFByRtYXRjaDACD0F0dGFjaGVkUGF5bWVudAQBcAUHJG1hdGNoMAUBcAkAAgECFlNlbmQgZXhhY3RseSAwLjEgV0FWRVMDCQECIT0CBQp3YXZlc09yRXJyBgkBCHRocm93RXJyAQIr0J/Qu9Cw0YLQtdC2INC00L7Qu9C20LXQvSDQsdGL0YLRjCDQsiBXQVZFUwMJAQIhPQIFDXBheW1lbnRBbW91bnQFCmFtb3VudF9kdWUJAQh0aHJvd0VycgECMtCd0LXQv9GA0LDQstC40LvRjNC90LDRjyDRgdGD0LzQvNCwINC/0LvQsNGC0LXQttCwCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUIcXVhbnRpdHkFB2Fzc2V0SWQFA25pbABtxCtL", "height": 2688500, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2rewbW6DzYJ2m9TpMftnNiHdzay3kRDrHkuiiVbaMkQh Next: 3BXHgiykf8xd4NT2DwiZ8jjdxbgmsDCXKaXQH8TcvzGF Diff:
Old | New | Differences | |
---|---|---|---|
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let contractFileName = "p1" | |
5 | 5 | ||
6 | - | let token_address = Address(base58'3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD') | |
7 | - | ||
8 | - | let SEP = " " | |
6 | + | let SEP = "_" | |
9 | 7 | ||
10 | 8 | let kassetId = "AssetID" | |
11 | 9 | ||
12 | - | func keyMsg () = makeString(["%s", "Переданное сообщение: "], SEP) | |
13 | - | ||
10 | + | let knewToken = "Token" | |
14 | 11 | ||
15 | 12 | func keyAssetID () = makeString(["%s", "assetID"], SEP) | |
16 | 13 | ||
22 | 19 | ||
23 | 20 | ||
24 | 21 | @Callable(i) | |
25 | - | func message (msg) = { | |
26 | - | let words = split(msg, SEP) | |
27 | - | let wordCount = size(words) | |
28 | - | let getAssetID = getStringValue(token_address, kassetId) | |
29 | - | let toBytes_assetID = toBytes(getAssetID) | |
30 | - | let payment = i.payments[0] | |
31 | - | let payment_amount = i.payments[0].amount | |
32 | - | if ((payment_amount != wordCount)) | |
33 | - | then throwErr("Кол-во слов != кол-ву токенов") | |
34 | - | else if ((toBytes_assetID == i.payments[0].assetId)) | |
35 | - | then throwErr("Платеж должен быть равен количеству слов в переданном сообщении") | |
36 | - | else [StringEntry(kassetId, getAssetID), StringEntry(keyMsg(), msg)] | |
22 | + | func tokenIssuance () = { | |
23 | + | let name = "PRACTICE" | |
24 | + | let description = "1:10 waves" | |
25 | + | let quantity = 10000000 | |
26 | + | let decimals = 3 | |
27 | + | let issue_token = Issue(name, description, quantity, decimals, true) | |
28 | + | let assetId = calculateAssetId(issue_token) | |
29 | + | [issue_token, BinaryEntry(kassetId, assetId), StringEntry(knewToken, issue_token.name)] | |
37 | 30 | } | |
38 | 31 | ||
39 | 32 | ||
40 | - | @Verifier(tx) | |
41 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
33 | + | ||
34 | + | @Callable(i) | |
35 | + | func buyToken (quantity) = { | |
36 | + | let wavesOrErr = (i.payments[0].assetId == unit) | |
37 | + | let assetId = valueOrErrorMessage(getBinaryValue(this, kassetId), "id токена не найден") | |
38 | + | let paymentAmount = i.payments[0].amount | |
39 | + | let token_price = 100000 | |
40 | + | let amount_due = (token_price * quantity) | |
41 | + | let payment = match i.payments[0] { | |
42 | + | case p: AttachedPayment => | |
43 | + | p | |
44 | + | case _ => | |
45 | + | throw("Send exactly 0.1 WAVES") | |
46 | + | } | |
47 | + | if ((wavesOrErr != true)) | |
48 | + | then throwErr("Платеж должен быть в WAVES") | |
49 | + | else if ((paymentAmount != amount_due)) | |
50 | + | then throwErr("Неправильная сумма платежа") | |
51 | + | else [ScriptTransfer(i.caller, quantity, assetId)] | |
52 | + | } | |
53 | + | ||
42 | 54 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let contractFileName = "p1" | |
5 | 5 | ||
6 | - | let token_address = Address(base58'3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD') | |
7 | - | ||
8 | - | let SEP = " " | |
6 | + | let SEP = "_" | |
9 | 7 | ||
10 | 8 | let kassetId = "AssetID" | |
11 | 9 | ||
12 | - | func keyMsg () = makeString(["%s", "Переданное сообщение: "], SEP) | |
13 | - | ||
10 | + | let knewToken = "Token" | |
14 | 11 | ||
15 | 12 | func keyAssetID () = makeString(["%s", "assetID"], SEP) | |
16 | 13 | ||
17 | 14 | ||
18 | 15 | func wrapErr (msg) = makeString([contractFileName, ":", msg], "") | |
19 | 16 | ||
20 | 17 | ||
21 | 18 | func throwErr (msg) = throw(wrapErr(msg)) | |
22 | 19 | ||
23 | 20 | ||
24 | 21 | @Callable(i) | |
25 | - | func message (msg) = { | |
26 | - | let words = split(msg, SEP) | |
27 | - | let wordCount = size(words) | |
28 | - | let getAssetID = getStringValue(token_address, kassetId) | |
29 | - | let toBytes_assetID = toBytes(getAssetID) | |
30 | - | let payment = i.payments[0] | |
31 | - | let payment_amount = i.payments[0].amount | |
32 | - | if ((payment_amount != wordCount)) | |
33 | - | then throwErr("Кол-во слов != кол-ву токенов") | |
34 | - | else if ((toBytes_assetID == i.payments[0].assetId)) | |
35 | - | then throwErr("Платеж должен быть равен количеству слов в переданном сообщении") | |
36 | - | else [StringEntry(kassetId, getAssetID), StringEntry(keyMsg(), msg)] | |
22 | + | func tokenIssuance () = { | |
23 | + | let name = "PRACTICE" | |
24 | + | let description = "1:10 waves" | |
25 | + | let quantity = 10000000 | |
26 | + | let decimals = 3 | |
27 | + | let issue_token = Issue(name, description, quantity, decimals, true) | |
28 | + | let assetId = calculateAssetId(issue_token) | |
29 | + | [issue_token, BinaryEntry(kassetId, assetId), StringEntry(knewToken, issue_token.name)] | |
37 | 30 | } | |
38 | 31 | ||
39 | 32 | ||
40 | - | @Verifier(tx) | |
41 | - | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
33 | + | ||
34 | + | @Callable(i) | |
35 | + | func buyToken (quantity) = { | |
36 | + | let wavesOrErr = (i.payments[0].assetId == unit) | |
37 | + | let assetId = valueOrErrorMessage(getBinaryValue(this, kassetId), "id токена не найден") | |
38 | + | let paymentAmount = i.payments[0].amount | |
39 | + | let token_price = 100000 | |
40 | + | let amount_due = (token_price * quantity) | |
41 | + | let payment = match i.payments[0] { | |
42 | + | case p: AttachedPayment => | |
43 | + | p | |
44 | + | case _ => | |
45 | + | throw("Send exactly 0.1 WAVES") | |
46 | + | } | |
47 | + | if ((wavesOrErr != true)) | |
48 | + | then throwErr("Платеж должен быть в WAVES") | |
49 | + | else if ((paymentAmount != amount_due)) | |
50 | + | then throwErr("Неправильная сумма платежа") | |
51 | + | else [ScriptTransfer(i.caller, quantity, assetId)] | |
52 | + | } | |
53 | + | ||
42 | 54 |
github/deemru/w8io/169f3d6 24.55 ms ◑