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:
OldNewDifferences
33 {-# CONTENT_TYPE DAPP #-}
44 let contractFileName = "p1"
55
6-let token_address = Address(base58'3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD')
7-
8-let SEP = " "
6+let SEP = "_"
97
108 let kassetId = "AssetID"
119
12-func keyMsg () = makeString(["%s", "Переданное сообщение: "], SEP)
13-
10+let knewToken = "Token"
1411
1512 func keyAssetID () = makeString(["%s", "assetID"], SEP)
1613
2219
2320
2421 @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)]
3730 }
3831
3932
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+
4254
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let contractFileName = "p1"
55
6-let token_address = Address(base58'3MwPF8FWd4fYohy6CXXB6wtjbRRvqFpxmdD')
7-
8-let SEP = " "
6+let SEP = "_"
97
108 let kassetId = "AssetID"
119
12-func keyMsg () = makeString(["%s", "Переданное сообщение: "], SEP)
13-
10+let knewToken = "Token"
1411
1512 func keyAssetID () = makeString(["%s", "assetID"], SEP)
1613
1714
1815 func wrapErr (msg) = makeString([contractFileName, ":", msg], "")
1916
2017
2118 func throwErr (msg) = throw(wrapErr(msg))
2219
2320
2421 @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)]
3730 }
3831
3932
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+
4254

github/deemru/w8io/873ac7e 
25.84 ms