tx · bB5ChiEUfmPxumG5H1dnuQBt4cYnPSd4mVJtELzxZ6n 3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp: -0.01000000 Waves 2024.02.22 16:41 [2987519] smart account 3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp > SELF 0.00000000 Waves
{ "type": 13, "id": "bB5ChiEUfmPxumG5H1dnuQBt4cYnPSd4mVJtELzxZ6n", "fee": 1000000, "feeAssetId": null, "timestamp": 1708609325553, "version": 2, "chainId": 84, "sender": "3Mq6mSfCYaGQkEHMAhobtjJGvb7xj1aiSBp", "senderPublicKey": "C5DMu2JvfbtJnPu4pyFYhyyeaYRS1RsnRnsgNFnkL55E", "proofs": [ "3w5uG3DGRGFmV4FbxJ9skEMQyXC2he4j6DeVLiuR3oVWWN2uLaVdFNAwc2o8gSYmZEHbjrwkXc1kFykPdbDRRAJi" ], "script": "base64:BgIGCAISABIAAwAHRUFUSF9JRAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgdFQVRIX0lEAApGZWVBZGRyZXNzAQAACmRldkFkZHJlc3MBAAIBaQEOSXNzdWVFQVRIVG9rZW4ABAVhc3NldAkAwwgHAgRFQVRIAvMBRUFUSCBpcyBhIGRpZ2l0YWwgdG9rZW4gYmFja2VkIGJ5IGEgMToxIHJlc2VydmUgb2YgV2F2ZXMgdG9rZW5zLCBtZWFuaW5nIGZvciBldmVyeSBFQVRIIHRva2VuIGluIGNpcmN1bGF0aW9uLCB0aGVyZSBpcyBvbmUgV2F2ZXMgdG9rZW4gaGVsZCBpbiBzZWN1cmUgcmVzZXJ2ZS4gVGhpcyByZXNlcnZlIG1vZGVsIGFpbXMgdG8gZ3VhcmFudGVlIHRoZSBzdGFiaWxpdHkgYW5kIHRyYW5zcGFyZW5jeSBvZiBFQVRIJ3MgdmFsdWUuAAEACAYFBHVuaXQAAAQHYXNzZXRJZAkAuAgBBQVhc3NldAQMY2hlY2tIYXJkQ2FwCQELdmFsdWVPckVsc2UCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAgtFQVRISGFyZENhcAAAAwkAAAIFDGNoZWNrSGFyZENhcAAACQDMCAIFBWFzc2V0CQDMCAIJAQRCdXJuAgUHYXNzZXRJZAABCQDMCAIJAQtTdHJpbmdFbnRyeQICB0VBVEhfSUQJANgEAQUHYXNzZXRJZAkAzAgCCQEMSW50ZWdlckVudHJ5AgIKRUFUSC9XQVZFUwCgjQYJAMwIAgkBDEludGVnZXJFbnRyeQICC0VBVEhIYXJkQ2FwAICA6YOx3hYFA25pbAkAAgECGFRva2VuIGlzIEFscmVhZHkgSXNzdWVkLgFpAQlJc3N1ZUVBVEgABANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQKY3VycmVudEtleQkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBAxQcmljZVBlckVBVEgJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMCCkVBVEgvV0FWRVMEC0VBVEhIYXJkQ2FwCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAgtFQVRISGFyZENhcAQNTmV3RUFUSFRvVXNlcgkAawMAoI0GCAUDcG10BmFtb3VudAUMUHJpY2VQZXJFQVRIBBJQcmV2aW91c0lzc3VlZEVBVEgEByRtYXRjaDAJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMCElRvdGFsX0lzc3VlZF9FQVRIOgMJAAECBQckbWF0Y2gwAgNJbnQEAWEFByRtYXRjaDAFAWEAAAQPVG90YWxJc3N1ZWRFQVRICQBkAgUSUHJldmlvdXNJc3N1ZWRFQVRIBQ1OZXdFQVRIVG9Vc2VyBA5QZW5kaW5nTWludGluZwkAZQIFC0VBVEhIYXJkQ2FwBQ9Ub3RhbElzc3VlZEVBVEgEGFByZXZpb3VzRUFUSFJlc2VydmVWYWx1ZQkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIcVG90YWxfRUFUSF9SZXNlcnZlX0luX1dBVkVTOgQQRUFUSFJlc2VydmVWYWx1ZQkAZAIFGFByZXZpb3VzRUFUSFJlc2VydmVWYWx1ZQgFA3BtdAZhbW91bnQEF1ByZXZpb3VzRUFUSEJhY2t1cFByaWNlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzAhtFQVRIX0JhY2t1cF9WYWx1ZV9Jbl9XQVZFUzoED0VBVEhCYWNrdXBQcmljZQkAawMAoI0GBRBFQVRIUmVzZXJ2ZVZhbHVlBQ9Ub3RhbElzc3VlZEVBVEgDCQEJaXNEZWZpbmVkAQgFA3BtdAdhc3NldElkCQACAQIuSW5jb3JyZWN0IGFzc2V0IGF0dGFjaGVkLCBwbGVhc2UgYXR0YWNoIFdBVkVTLgMJAGYCAMCWsQIIBQNwbXQGYW1vdW50CQACAQI1UGxlYXNlIEF0dGFjaCBtaW5pbXVtIDAuMDUgV0FWRVMgVG8gSXNzdWUgRUFUSCBBc3NldC4DCQBmAgUPVG90YWxJc3N1ZWRFQVRIBQtFQVRISGFyZENhcAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICL0VBVEggTWludGluZyBpcyBhYm91dCB0byByZWFjaCB0aGUgSGFyZCBDYXAgb2YgCQCkAwEFC0VBVEhIYXJkQ2FwAjAvMTBeOCBFQVRILiBQbGVhc2UgUmVkdWNlIHlvdXIgTWludGluZyBPcmRlciBieSAJAKQDAQUOUGVuZGluZ01pbnRpbmcCCCBvciBwdXQgCQCkAwEJAGUCBQtFQVRISGFyZENhcAUSUHJldmlvdXNJc3N1ZWRFQVRIAgUvMTBeOAkAzAgCCQEMSW50ZWdlckVudHJ5AgISVG90YWxfSXNzdWVkX0VBVEg6BQ9Ub3RhbElzc3VlZEVBVEgJAMwIAgkBDEludGVnZXJFbnRyeQICFUJhbGFuY2VfTWludGluZ19FQVRIOgUOUGVuZGluZ01pbnRpbmcJAMwIAgkBDEludGVnZXJFbnRyeQICHFRvdGFsX0VBVEhfUmVzZXJ2ZV9Jbl9XQVZFUzoFEEVBVEhSZXNlcnZlVmFsdWUJAMwIAgkBDEludGVnZXJFbnRyeQICG0VBVEhfQmFja3VwX1ZhbHVlX0luX1dBVkVTOgUPRUFUSEJhY2t1cFByaWNlCQDMCAIJAQtTdHJpbmdFbnRyeQICB21lc3NhZ2UCJjxoMT5FQVRIIElzc3VlZCBTdWNjZXNzZnVsbHkhPC9oMT48YnI+CQDMCAIJAQdSZWlzc3VlAwUHRUFUSF9JRAUNTmV3RUFUSFRvVXNlcgYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyCQBpAgkAaAIFDU5ld0VBVEhUb1VzZXIA3gcA6AcFB0VBVEhfSUQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkApwgBBQpGZWVBZGRyZXNzCQBpAgkAaAIFDU5ld0VBVEhUb1VzZXIACQDoBwUHRUFUSF9JRAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCQCnCAEFCmRldkFkZHJlc3MJAGkCCQBoAgUNTmV3RUFUSFRvVXNlcgABAOgHBQdFQVRIX0lEBQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5nT2S3g==", "height": 2987519, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DPvgSzfCShv6xop9XBz7Jqxk5QXBvskfdGEWnFWtAgTZ Next: 76P5D61KJgJ9LSWZqdFg8x4UbhFXURC8JnnaN8SeGzQa Diff:
Old | New | Differences | |
---|---|---|---|
26 | 26 | let PricePerEATH = getIntegerValue(this, "EATH/WAVES") | |
27 | 27 | let EATHHardCap = getIntegerValue(this, "EATHHardCap") | |
28 | 28 | let NewEATHToUser = fraction(100000, pmt.amount, PricePerEATH) | |
29 | - | let PreviousIssuedEATH = getIntegerValue(this, "Total_Issued_EATH:") | |
29 | + | let PreviousIssuedEATH = match getIntegerValue(this, "Total_Issued_EATH:") { | |
30 | + | case a: Int => | |
31 | + | a | |
32 | + | case _ => | |
33 | + | 0 | |
34 | + | } | |
30 | 35 | let TotalIssuedEATH = (PreviousIssuedEATH + NewEATHToUser) | |
31 | 36 | let PendingMinting = (EATHHardCap - TotalIssuedEATH) | |
32 | 37 | let PreviousEATHReserveValue = getIntegerValue(this, "Total_EATH_Reserve_In_WAVES:") |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let EATH_ID = fromBase58String(getStringValue(this, "EATH_ID")) | |
5 | 5 | ||
6 | 6 | let FeeAddress = base58'' | |
7 | 7 | ||
8 | 8 | let devAddress = base58'' | |
9 | 9 | ||
10 | 10 | @Callable(i) | |
11 | 11 | func IssueEATHToken () = { | |
12 | 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 | 13 | let assetId = calculateAssetId(asset) | |
14 | 14 | let checkHardCap = valueOrElse(getIntegerValue(this, "EATHHardCap"), 0) | |
15 | 15 | if ((checkHardCap == 0)) | |
16 | 16 | then [asset, Burn(assetId, 1), StringEntry("EATH_ID", toBase58String(assetId)), IntegerEntry("EATH/WAVES", 100000), IntegerEntry("EATHHardCap", 100000000000000)] | |
17 | 17 | else throw("Token is Already Issued.") | |
18 | 18 | } | |
19 | 19 | ||
20 | 20 | ||
21 | 21 | ||
22 | 22 | @Callable(i) | |
23 | 23 | func IssueEATH () = { | |
24 | 24 | let pmt = value(i.payments[0]) | |
25 | 25 | let currentKey = toBase58String(i.caller.bytes) | |
26 | 26 | let PricePerEATH = getIntegerValue(this, "EATH/WAVES") | |
27 | 27 | let EATHHardCap = getIntegerValue(this, "EATHHardCap") | |
28 | 28 | let NewEATHToUser = fraction(100000, pmt.amount, PricePerEATH) | |
29 | - | let PreviousIssuedEATH = getIntegerValue(this, "Total_Issued_EATH:") | |
29 | + | let PreviousIssuedEATH = match getIntegerValue(this, "Total_Issued_EATH:") { | |
30 | + | case a: Int => | |
31 | + | a | |
32 | + | case _ => | |
33 | + | 0 | |
34 | + | } | |
30 | 35 | let TotalIssuedEATH = (PreviousIssuedEATH + NewEATHToUser) | |
31 | 36 | let PendingMinting = (EATHHardCap - TotalIssuedEATH) | |
32 | 37 | let PreviousEATHReserveValue = getIntegerValue(this, "Total_EATH_Reserve_In_WAVES:") | |
33 | 38 | let EATHReserveValue = (PreviousEATHReserveValue + pmt.amount) | |
34 | 39 | let PreviousEATHBackupPrice = getIntegerValue(this, "EATH_Backup_Value_In_WAVES:") | |
35 | 40 | let EATHBackupPrice = fraction(100000, EATHReserveValue, TotalIssuedEATH) | |
36 | 41 | if (isDefined(pmt.assetId)) | |
37 | 42 | then throw("Incorrect asset attached, please attach WAVES.") | |
38 | 43 | else if ((5000000 > pmt.amount)) | |
39 | 44 | then throw("Please Attach minimum 0.05 WAVES To Issue EATH Asset.") | |
40 | 45 | else if ((TotalIssuedEATH > EATHHardCap)) | |
41 | 46 | 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 | 47 | 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)] | |
43 | 48 | } | |
44 | 49 | ||
45 | 50 | ||
46 | 51 | @Verifier(tx) | |
47 | 52 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
48 | 53 |
github/deemru/w8io/026f985 19.18 ms ◑