tx · DPvgSzfCShv6xop9XBz7Jqxk5QXBvskfdGEWnFWtAgTZ 3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp: -0.01000000 Waves 2024.02.22 16:08 [2987486] smart account 3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp > SELF 0.00000000 Waves
{ "type": 13, "id": "DPvgSzfCShv6xop9XBz7Jqxk5QXBvskfdGEWnFWtAgTZ", "fee": 1000000, "feeAssetId": null, "timestamp": 1708607402860, "version": 2, "chainId": 84, "sender": "3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp", "senderPublicKey": "C5DMu2JvfbtJnPu4pyFYhyyeaYRS1RsnRnsgNFnkL55E", "proofs": [ "2xzS5sXcRFiFYjkEpqVatpDcuqTGN8RVFQaev9JFJ4dyu27hibGostfQCRVJQkSws49TULTuNe9U3NMgz6DLg3fb" ], "script": "base64:BgIGCAISABIAAwAHRUFUSF9JRAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgdFQVRIX0lEAApGZWVBZGRyZXNzAQAACmRldkFkZHJlc3MBAAIBaQEOSXNzdWVFQVRIVG9rZW4ABAVhc3NldAkAwwgHAgRFQVRIAvMBRUFUSCBpcyBhIGRpZ2l0YWwgdG9rZW4gYmFja2VkIGJ5IGEgMToxIHJlc2VydmUgb2YgV2F2ZXMgdG9rZW5zLCBtZWFuaW5nIGZvciBldmVyeSBFQVRIIHRva2VuIGluIGNpcmN1bGF0aW9uLCB0aGVyZSBpcyBvbmUgV2F2ZXMgdG9rZW4gaGVsZCBpbiBzZWN1cmUgcmVzZXJ2ZS4gVGhpcyByZXNlcnZlIG1vZGVsIGFpbXMgdG8gZ3VhcmFudGVlIHRoZSBzdGFiaWxpdHkgYW5kIHRyYW5zcGFyZW5jeSBvZiBFQVRIJ3MgdmFsdWUuAAEACAYFBHVuaXQAAAQHYXNzZXRJZAkAuAgBBQVhc3NldAQMY2hlY2tIYXJkQ2FwCQELdmFsdWVPckVsc2UCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAgtFQVRISGFyZENhcAAAAwkAAAIFDGNoZWNrSGFyZENhcAAACQDMCAIFBWFzc2V0CQDMCAIJAQRCdXJuAgUHYXNzZXRJZAABCQDMCAIJAQtTdHJpbmdFbnRyeQICB0VBVEhfSUQJANgEAQUHYXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgIKRUFUSC9XQVZFUwCgjQYJAMwIAgkBDEludGVnZXJFbnRyeQICC0VBVEhIYXJkQ2FwAICA6YOx3hYFA25pbAkAAgECGFRva2VuIGlzIEFscmVhZHkgSXNzdWVkLgFpAQlJc3N1ZUVBVEgABANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQKY3VycmVudEtleQkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBAxQcmljZVBlckVBVEgJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMCCkVBVEgvV0FWRVMEC0VBVEhIYXJkQ2FwCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAgtFQVRISGFyZENhcAQNTmV3RUFUSFRvVXNlcgkAawMAoI0GCAUDcG10BmFtb3VudAUMUHJpY2VQZXJFQVRIBBJQcmV2aW91c0lzc3VlZEVBVEgJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMCElRvdGFsX0lzc3VlZF9FQVRIOgQPVG90YWxJc3N1ZWRFQVRICQBkAgUSUHJldmlvdXNJc3N1ZWRFQVRIBQ1OZXdFQVRIVG9Vc2VyBA5QZW5kaW5nTWludGluZwkAZQIFC0VBVEhIYXJkQ2FwBQ9Ub3RhbElzc3VlZEVBVEgEGFByZXZpb3VzRUFUSFJlc2VydmVWYWx1ZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIcVG90YWxfRUFUSF9SZXNlcnZlX0luX1dBVkVTOgQQRUFUSFJlc2VydmVWYWx1ZQkAZAIFGFByZXZpb3VzRUFUSFJlc2VydmVWYWx1ZQgFA3BtdAZhbW91bnQEF1ByZXZpb3VzRUFUSEJhY2t1cFByaWNlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAhtFQVRIX0JhY2t1cF9WYWx1ZV9Jbl9XQVZFUzoED0VBVEhCYWNrdXBQcmljZQkAawMAoI0GBRBFQVRIUmVzZXJ2ZVZhbHVlBQ9Ub3RhbElzc3VlZEVBVEgDCQEJaXNEZWZpbmVkAQgFA3BtdAdhc3NldElkCQACAQIuSW5jb3JyZWN0IGFzc2V0IGF0dGFjaGVkLCBwbGVhc2UgYXR0YWNoIFdBVkVTLgMJAGYCAMCWsQIIBQNwbXQGYW1vdW50CQACAQI1UGxlYXNlIEF0dGFjaCBtaW5pbXVtIDAuMDUgV0FWRVMgVG8gSXNzdWUgRUFUSCBBc3NldC4DCQBmAgUPVG90YWxJc3N1ZWRFQVRIBQtFQVRISGFyZENhcAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICL0VBVEggTWludGluZyBpcyBhYm91dCB0byByZWFjaCB0aGUgSGFyZCBDYXAgb2YgCQCkAwEFC0VBVEhIYXJkQ2FwAjAvMTBeOCBFQVRILiBQbGVhc2UgUmVkdWNlIHlvdXIgTWludGluZyBPcmRlciBieSAJAKQDAQUOUGVuZGluZ01pbnRpbmcCCCBvciBwdXQgCQCkAwEJAGUCBQtFQVRISGFyZENhcAUSUHJldmlvdXNJc3N1ZWRFQVRIAgUvMTBeOAkAzAgCCQEMSW50ZWdlckVudHJ5AgISVG90YWxfSXNzdWVkX0VBVEg6BQ9Ub3RhbElzc3VlZEVBVEgJAMwIAgkBDEludGVnZXJFbnRyeQICFUJhbGFuY2VfTWludGluZ19FQVRIOgUOUGVuZGluZ01pbnRpbmcJAMwIAgkBDEludGVnZXJFbnRyeQICHFRvdGFsX0VBVEhfUmVzZXJ2ZV9Jbl9XQVZFUzoFEEVBVEhSZXNlcnZlVmFsdWUJAMwIAgkBDEludGVnZXJFbnRyeQICG0VBVEhfQmFja3VwX1ZhbHVlX0luX1dBVkVTOgUPRUFUSEJhY2t1cFByaWNlCQDMCAIJAQtTdHJpbmdFbnRyeQICB21lc3NhZ2UCJjxoMT5FQVRIIElzc3VlZCBTdWNjZXNzZnVsbHkhPC9oMT48YnI+CQDMCAIJAQdSZWlzc3VlAwUHRUFUSF9JRAUNTmV3RUFUSFRvVXNlcgYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyCQBpAgkAaAIFDU5ld0VBVEhUb1VzZXIA3gcA6AcFB0VBVEhfSUQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkApwgBBQpGZWVBZGRyZXNzCQBpAgkAaAIFDU5ld0VBVEhUb1VzZXIACQDoBwUHRUFUSF9JRAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQCnCAEFCmRldkFkZHJlc3MJAGkCCQBoAgUNTmV3RUFUSFRvVXNlcgABAOgHBQdFQVRIX0lEBQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V59ja4PA==", "height": 2987486, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 45GC5VWTCDFpw1wLXy3ucN4JUae7kYqoZyPXVaoVDMmo Next: bB5ChiEUfmPxumG5H1dnuQBt4cYnPSd4mVJtELzxZ6n Diff:
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let EATH_ID = fromBase58String(getStringValue(this, "EATH_ID")) | |
5 | + | ||
6 | + | let FeeAddress = base58'' | |
7 | + | ||
8 | + | let devAddress = base58'' | |
9 | + | ||
10 | + | @Callable(i) | |
11 | + | func IssueEATHToken () = { | |
12 | + | let asset = Issue("EATH", "EATH is a digital token backed by a 1:1 reserve of Waves tokens, meaning for every EATH token in circulation, there is one Waves token held in secure reserve. This reserve model aims to guarantee the stability and transparency of EATH's value.", 1, 8, true, unit, 0) | |
13 | + | let assetId = calculateAssetId(asset) | |
14 | + | let checkHardCap = valueOrElse(getIntegerValue(this, "EATHHardCap"), 0) | |
15 | + | if ((checkHardCap == 0)) | |
16 | + | then [asset, Burn(assetId, 1), StringEntry("EATH_ID", toBase58String(assetId)), IntegerEntry("EATH/WAVES", 100000), IntegerEntry("EATHHardCap", 100000000000000)] | |
17 | + | else throw("Token is Already Issued.") | |
18 | + | } | |
19 | + | ||
4 | 20 | ||
5 | 21 | ||
6 | 22 | @Callable(i) | |
7 | 23 | func IssueEATH () = { | |
8 | - | let asset = Issue("EATH", "EATH is a digital token backed by a 1:1 reserve of Waves tokens, meaning for every EATH token in circulation, there is one Waves token held in secure reserve. This reserve model aims to guarantee the stability and transparency of EATH's value.", 1, 8, true, unit, 0) | |
9 | - | let assetId = calculateAssetId(asset) | |
10 | - | [asset, Burn(assetId, 1), StringEntry("EATH_ID", toBase58String(assetId)), IntegerEntry("EATH/WAVES", 100000), IntegerEntry("EATHHardCap", 100000000000000)] | |
24 | + | let pmt = value(i.payments[0]) | |
25 | + | let currentKey = toBase58String(i.caller.bytes) | |
26 | + | let PricePerEATH = getIntegerValue(this, "EATH/WAVES") | |
27 | + | let EATHHardCap = getIntegerValue(this, "EATHHardCap") | |
28 | + | let NewEATHToUser = fraction(100000, pmt.amount, PricePerEATH) | |
29 | + | let PreviousIssuedEATH = getIntegerValue(this, "Total_Issued_EATH:") | |
30 | + | let TotalIssuedEATH = (PreviousIssuedEATH + NewEATHToUser) | |
31 | + | let PendingMinting = (EATHHardCap - TotalIssuedEATH) | |
32 | + | let PreviousEATHReserveValue = getIntegerValue(this, "Total_EATH_Reserve_In_WAVES:") | |
33 | + | let EATHReserveValue = (PreviousEATHReserveValue + pmt.amount) | |
34 | + | let PreviousEATHBackupPrice = getIntegerValue(this, "EATH_Backup_Value_In_WAVES:") | |
35 | + | let EATHBackupPrice = fraction(100000, EATHReserveValue, TotalIssuedEATH) | |
36 | + | if (isDefined(pmt.assetId)) | |
37 | + | then throw("Incorrect asset attached, please attach WAVES.") | |
38 | + | else if ((5000000 > pmt.amount)) | |
39 | + | then throw("Please Attach minimum 0.05 WAVES To Issue EATH Asset.") | |
40 | + | else if ((TotalIssuedEATH > EATHHardCap)) | |
41 | + | then throw((((((("EATH Minting is about to reach the Hard Cap of " + toString(EATHHardCap)) + "/10^8 EATH. Please Reduce your Minting Order by ") + toString(PendingMinting)) + " or put ") + toString((EATHHardCap - PreviousIssuedEATH))) + "/10^8")) | |
42 | + | else [IntegerEntry("Total_Issued_EATH:", TotalIssuedEATH), IntegerEntry("Balance_Minting_EATH:", PendingMinting), IntegerEntry("Total_EATH_Reserve_In_WAVES:", EATHReserveValue), IntegerEntry("EATH_Backup_Value_In_WAVES:", EATHBackupPrice), StringEntry("message", "<h1>EATH Issued Successfully!</h1><br>"), Reissue(EATH_ID, NewEATHToUser, true), ScriptTransfer(i.caller, ((NewEATHToUser * 990) / 1000), EATH_ID), ScriptTransfer(addressFromPublicKey(FeeAddress), ((NewEATHToUser * 9) / 1000), EATH_ID), ScriptTransfer(addressFromPublicKey(devAddress), ((NewEATHToUser * 1) / 1000), EATH_ID)] | |
11 | 43 | } | |
12 | 44 | ||
13 | 45 |
Old | New | Differences | |
---|---|---|---|
1 | - | {-# STDLIB_VERSION | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let EATH_ID = fromBase58String(getStringValue(this, "EATH_ID")) | |
5 | + | ||
6 | + | let FeeAddress = base58'' | |
7 | + | ||
8 | + | let devAddress = base58'' | |
9 | + | ||
10 | + | @Callable(i) | |
11 | + | func IssueEATHToken () = { | |
12 | + | let asset = Issue("EATH", "EATH is a digital token backed by a 1:1 reserve of Waves tokens, meaning for every EATH token in circulation, there is one Waves token held in secure reserve. This reserve model aims to guarantee the stability and transparency of EATH's value.", 1, 8, true, unit, 0) | |
13 | + | let assetId = calculateAssetId(asset) | |
14 | + | let checkHardCap = valueOrElse(getIntegerValue(this, "EATHHardCap"), 0) | |
15 | + | if ((checkHardCap == 0)) | |
16 | + | then [asset, Burn(assetId, 1), StringEntry("EATH_ID", toBase58String(assetId)), IntegerEntry("EATH/WAVES", 100000), IntegerEntry("EATHHardCap", 100000000000000)] | |
17 | + | else throw("Token is Already Issued.") | |
18 | + | } | |
19 | + | ||
4 | 20 | ||
5 | 21 | ||
6 | 22 | @Callable(i) | |
7 | 23 | func IssueEATH () = { | |
8 | - | let asset = Issue("EATH", "EATH is a digital token backed by a 1:1 reserve of Waves tokens, meaning for every EATH token in circulation, there is one Waves token held in secure reserve. This reserve model aims to guarantee the stability and transparency of EATH's value.", 1, 8, true, unit, 0) | |
9 | - | let assetId = calculateAssetId(asset) | |
10 | - | [asset, Burn(assetId, 1), StringEntry("EATH_ID", toBase58String(assetId)), IntegerEntry("EATH/WAVES", 100000), IntegerEntry("EATHHardCap", 100000000000000)] | |
24 | + | let pmt = value(i.payments[0]) | |
25 | + | let currentKey = toBase58String(i.caller.bytes) | |
26 | + | let PricePerEATH = getIntegerValue(this, "EATH/WAVES") | |
27 | + | let EATHHardCap = getIntegerValue(this, "EATHHardCap") | |
28 | + | let NewEATHToUser = fraction(100000, pmt.amount, PricePerEATH) | |
29 | + | let PreviousIssuedEATH = getIntegerValue(this, "Total_Issued_EATH:") | |
30 | + | let TotalIssuedEATH = (PreviousIssuedEATH + NewEATHToUser) | |
31 | + | let PendingMinting = (EATHHardCap - TotalIssuedEATH) | |
32 | + | let PreviousEATHReserveValue = getIntegerValue(this, "Total_EATH_Reserve_In_WAVES:") | |
33 | + | let EATHReserveValue = (PreviousEATHReserveValue + pmt.amount) | |
34 | + | let PreviousEATHBackupPrice = getIntegerValue(this, "EATH_Backup_Value_In_WAVES:") | |
35 | + | let EATHBackupPrice = fraction(100000, EATHReserveValue, TotalIssuedEATH) | |
36 | + | if (isDefined(pmt.assetId)) | |
37 | + | then throw("Incorrect asset attached, please attach WAVES.") | |
38 | + | else if ((5000000 > pmt.amount)) | |
39 | + | then throw("Please Attach minimum 0.05 WAVES To Issue EATH Asset.") | |
40 | + | else if ((TotalIssuedEATH > EATHHardCap)) | |
41 | + | then throw((((((("EATH Minting is about to reach the Hard Cap of " + toString(EATHHardCap)) + "/10^8 EATH. Please Reduce your Minting Order by ") + toString(PendingMinting)) + " or put ") + toString((EATHHardCap - PreviousIssuedEATH))) + "/10^8")) | |
42 | + | else [IntegerEntry("Total_Issued_EATH:", TotalIssuedEATH), IntegerEntry("Balance_Minting_EATH:", PendingMinting), IntegerEntry("Total_EATH_Reserve_In_WAVES:", EATHReserveValue), IntegerEntry("EATH_Backup_Value_In_WAVES:", EATHBackupPrice), StringEntry("message", "<h1>EATH Issued Successfully!</h1><br>"), Reissue(EATH_ID, NewEATHToUser, true), ScriptTransfer(i.caller, ((NewEATHToUser * 990) / 1000), EATH_ID), ScriptTransfer(addressFromPublicKey(FeeAddress), ((NewEATHToUser * 9) / 1000), EATH_ID), ScriptTransfer(addressFromPublicKey(devAddress), ((NewEATHToUser * 1) / 1000), EATH_ID)] | |
11 | 43 | } | |
12 | 44 | ||
13 | 45 | ||
14 | 46 | @Verifier(tx) | |
15 | 47 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
16 | 48 |
github/deemru/w8io/169f3d6 28.83 ms ◑