tx · 2e633kAv5XMqML2U72fvHFaQjvAxiyvCiHHfWTeeiZgv

3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx:  -0.01000000 Waves

2023.01.04 21:13 [3456036] smart account 3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx > SELF 0.00000000 Waves

{ "type": 13, "id": "2e633kAv5XMqML2U72fvHFaQjvAxiyvCiHHfWTeeiZgv", "fee": 1000000, "feeAssetId": null, "timestamp": 1672856026224, "version": 1, "sender": "3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx", "senderPublicKey": "ERKkYKnafViKTn8uQkz9XhvosihQ5XyXkRCm2ztrjZey", "proofs": [ "2v6swpGqcq8eFtWoBvSYoejHDnGUAkRCw1yGsAKZ39iHQzTQnHwCECRjREc9NmYyWn8gAUbxYayj91WXvkTaar7C" ], "script": "base64:BgIKCAISABIAEgASAA4AD3ByaWNlT3JhY2xlQWRkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM1A1QmZkNThQUGZOdkJNMkh5OFFmYmNEcU1lTnR6ZzdLZlAAD2NvbGxhdGVyYWxMaW1pdAkAaAIAwMOTBwCAwtcvAAtvcmFjbGVJbmRleAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFD3ByaWNlT3JhY2xlQWRkcgILcHJpY2VfaW5kZXgCFEVycm9yOiBObyBwcmljZSBkYXRhABBvcmFjbGVJbmRleEJsb2NrCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgICDHByaWNlX2luZGV4XwkApAMBBQtvcmFjbGVJbmRleAIURXJyb3I6IE5vIHByaWNlIGRhdGEAE29yYWNsZVdhdmVzUHJpY2VVU0QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgIGcHJpY2VfCQCkAwEFEG9yYWNsZUluZGV4QmxvY2sCFEVycm9yOiBObyBwcmljZSBkYXRhAAd0b2tlbklkCQChCAECB3Rva2VuSWQBFGdldENpcmN1bGF0aW5nU3VwcGx5AAQHJG1hdGNoMAkA7AcBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEUVycm9yOiBObyB0b2tlbklkAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAkAZQIIBQVhc3NldAhxdWFudGl0eQkA8AcCBQR0aGlzCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEUVycm9yOiBObyB0b2tlbklkCQACAQIZRXJyb3I6IENhbiBub3QgZmluZCB0b2tlbgENZ2V0Q29sbGF0ZXJhbAAICQDvBwEFBHRoaXMHcmVndWxhcgESZ2V0Q29sbGF0ZXJhbEluVVNEAAkAawMJAQ1nZXRDb2xsYXRlcmFsAAUTb3JhY2xlV2F2ZXNQcmljZVVTRADAhD0BD2dldEJhY2tpbmdSYXRpbwAJAGsDCQESZ2V0Q29sbGF0ZXJhbEluVVNEAACQTgkBFGdldENpcmN1bGF0aW5nU3VwcGx5AAEQZ2V0SGlzdG9yaWNQcmljZQEIZGF5c19hZ28EGWhpc3RvcmljX29yYWNsZUluZGV4QmxvY2sJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgIMcHJpY2VfaW5kZXhfCQCkAwEJAGUCBQtvcmFjbGVJbmRleAkAaAIFCGRheXNfYWdvAKALAh1FcnJvcjogTm8gaGlzdG9yaWMgcHJpY2UgZGF0YQQcaGlzdG9yaWNfb3JhY2xlV2F2ZXNQcmljZVVTRAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFD3ByaWNlT3JhY2xlQWRkcgkArAICAgZwcmljZV8JAKQDAQUZaGlzdG9yaWNfb3JhY2xlSW5kZXhCbG9jawIdRXJyb3I6IE5vIGhpc3RvcmljIHByaWNlIGRhdGEFHGhpc3RvcmljX29yYWNsZVdhdmVzUHJpY2VVU0QBFWdldEhpc3RvcmljUHJpbnRMaW1pdAEIZGF5c19hZ28EHGhpc3RvcmljX29yYWNsZVdhdmVzUHJpY2VVU0QJARBnZXRIaXN0b3JpY1ByaWNlAQUIZGF5c19hZ28EF2hpc3RvcmljX3R3b1RoaXJkc1ByaWNlCQBrAwUcaGlzdG9yaWNfb3JhY2xlV2F2ZXNQcmljZVVTRAACAAMEEmhpc3RvcmljX2hhbGZQcmljZQkAawMFHGhpc3RvcmljX29yYWNsZVdhdmVzUHJpY2VVU0QAAQACAwkAZgIFF2hpc3RvcmljX3R3b1RoaXJkc1ByaWNlCQEQZ2V0SGlzdG9yaWNQcmljZQEJAGQCAAEFCGRheXNfYWdvAAADCQBmAgUXaGlzdG9yaWNfdHdvVGhpcmRzUHJpY2UJARBnZXRIaXN0b3JpY1ByaWNlAQkAZAIAAwUIZGF5c19hZ28AAAMJAGYCBRdoaXN0b3JpY190d29UaGlyZHNQcmljZQkBEGdldEhpc3RvcmljUHJpY2UBCQBkAgAHBQhkYXlzX2FnbwAAAwkAZgIFF2hpc3RvcmljX3R3b1RoaXJkc1ByaWNlCQEQZ2V0SGlzdG9yaWNQcmljZQEJAGQCAA4FCGRheXNfYWdvAAADCQBmAgUXaGlzdG9yaWNfdHdvVGhpcmRzUHJpY2UJARBnZXRIaXN0b3JpY1ByaWNlAQkAZAIAHgUIZGF5c19hZ28AAAMJAGYCBRJoaXN0b3JpY19oYWxmUHJpY2UJARBnZXRIaXN0b3JpY1ByaWNlAQkAZAIAPAUIZGF5c19hZ28AAAkAaAIAoI0GAIDC1y8BFGdldEN1cnJlbnRQcmludExpbWl0AAkBFWdldEhpc3RvcmljUHJpbnRMaW1pdAEAAAEUZ2V0VG90YWxQcmludGVkVG9kYXkABANrZXkJAKwCAgITdG90YWxfcHJpbnRlZF90b2RheQkApAMBCQBuBAUGaGVpZ2h0AKALAAEFBERPV04DCQAAAgkAnwgBBQNrZXkFBHVuaXQAAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCfCAEFA2tleQIDZXJyBAFpAQtjb25zdHJ1Y3RvcgADCQECIT0CBQd0b2tlbklkBQR1bml0CQACAQIqRXJyb3I6IENvbnN0cnVjdG9yIGFscmVhZHkgaGFzIGJlZW4gY2FsbGVkBAVpc3N1ZQkAwggFAgRUZXN0AgRUZXN0AAAACAYEAmlkCQC4CAEFBWlzc3VlCQCUCgIJAMwIAgUFaXNzdWUJAMwIAgkBC0JpbmFyeUVudHJ5AgIHdG9rZW5JZAUCaWQFA25pbAUEdW5pdAFpAQ9zd2FwV2F2ZXNUb1Rlc3QAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIjRXJyb3I6IE9ubHkgb25lIHBheW1lbnQgaXMgcmVxdWlyZWQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBCWlzRGVmaW5lZAEIBQNwbXQHYXNzZXRJZAkAAgECL0Vycm9yOiBPbmx5IFdhdmVzIHRva2VuIGlzIGFsbG93ZWQgZm9yIHN3YXBwaW5nAwkAZgIJAGQCCQENZ2V0Q29sbGF0ZXJhbAAIBQNwbXQGYW1vdW50BQ9jb2xsYXRlcmFsTGltaXQJAAIBAiBFcnJvcjogQ29sbGF0ZXJhbCBsaW1pdCBleGNlZWRlZAQQYW1vdW50V2l0aG91dEZlZQkAawMIBQNwbXQGYW1vdW50BRNvcmFjbGVXYXZlc1ByaWNlVVNEAMCEPQQMcmV0dXJuQW1vdW50CQBrAwUQYW1vdW50V2l0aG91dEZlZQDjBwDoBwQDa2V5CQCsAgICE3RvdGFsX3ByaW50ZWRfdG9kYXkJAKQDAQkAbgQFBmhlaWdodACgCwABBQRET1dOBBZ0b3RhbFByaW50ZWRBZnRlcklzc3VlCQBkAgkBFGdldFRvdGFsUHJpbnRlZFRvZGF5AAUMcmV0dXJuQW1vdW50AwkAZgIFFnRvdGFsUHJpbnRlZEFmdGVySXNzdWUJARRnZXRDdXJyZW50UHJpbnRMaW1pdAAJAAIBAiBFcnJvcjogRGFpbHkgc3dhcCBsaW1pdCBleGNlZWRlZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUDa2V5BRZ0b3RhbFByaW50ZWRBZnRlcklzc3VlCQDMCAIJAQdSZWlzc3VlAwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQd0b2tlbklkAhJFcnJvcjogbm8gdG9rZW4gaWQFDHJldHVybkFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFB3Rva2VuSWQFA25pbAFpAQ9zd2FwVGVzdFRvV2F2ZXMAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIjRXJyb3I6IE9ubHkgb25lIHBheW1lbnQgaXMgcmVxdWlyZWQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFA3BtdAdhc3NldElkBQd0b2tlbklkCQACAQIuRXJyb3I6IE9ubHkgVGVzdCB0b2tlbiBpcyBhbGxvd2VkIGZvciBzd2FwcGluZwQQYW1vdW50V2l0aG91dEZlZQkAawMIBQNwbXQGYW1vdW50AMCEPQUTb3JhY2xlV2F2ZXNQcmljZVVTRAQCYnIJAQ9nZXRCYWNraW5nUmF0aW8ABAVzaGFyZQMJAGYCAKxNBQJicgkAZQIA6AcJAGkCCQBlAgCQTgUCYnIACwMJAGYCAIRSBQJicgDfBwDjBwQMcmV0dXJuQW1vdW50CQBrAwUQYW1vdW50V2l0aG91dEZlZQUFc2hhcmUA6AcJAMwIAgkBBEJ1cm4CCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEkVycm9yOiBubyB0b2tlbiBpZAgFA3BtdAZhbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFBHVuaXQFA25pbAFpARJ1cGRhdGVTcG9uc29yZWRGZWUAAwkAAAIFB3Rva2VuSWQFBHVuaXQJAAIBAilFcnJvcjogQ29uc3RydWN0b3IgaGFzIHRvIGJlIGNhbGxlZCBmaXJzdAQDZmVlCQBrAwUTb3JhY2xlV2F2ZXNQcmljZVVTRABkAM0CCQDMCAIJAQpTcG9uc29yRmVlAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQd0b2tlbklkAhJFcnJvcjogbm8gdG9rZW4gaWQFA2ZlZQUDbmlsALBl53c=", "chainId": 87, "height": 3456036, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: EPNGP6PYW8pQVQRFPepLbmFeSk5S9wctGmVRKAFSkoXy Next: 4Hi8tTA3tkGMV67bhsHxs9mT1Pm5FKSYVpMeynoKKxDe Diff:
OldNewDifferences
1515
1616 func getCirculatingSupply () = match assetInfo(valueOrErrorMessage(tokenId, "Error: No tokenId")) {
1717 case asset: Asset =>
18- asset.quantity
18+ (asset.quantity - assetBalance(this, valueOrErrorMessage(tokenId, "Error: No tokenId")))
1919 case _ =>
2020 throw("Error: Can not find token")
2121 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let priceOracleAddr = addressFromStringValue("3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP")
55
66 let collateralLimit = (15000000 * 100000000)
77
88 let oracleIndex = valueOrErrorMessage(getInteger(priceOracleAddr, "price_index"), "Error: No price data")
99
1010 let oracleIndexBlock = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_index_" + toString(oracleIndex))), "Error: No price data")
1111
1212 let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString(oracleIndexBlock))), "Error: No price data")
1313
1414 let tokenId = getBinary("tokenId")
1515
1616 func getCirculatingSupply () = match assetInfo(valueOrErrorMessage(tokenId, "Error: No tokenId")) {
1717 case asset: Asset =>
18- asset.quantity
18+ (asset.quantity - assetBalance(this, valueOrErrorMessage(tokenId, "Error: No tokenId")))
1919 case _ =>
2020 throw("Error: Can not find token")
2121 }
2222
2323
2424 func getCollateral () = wavesBalance(this).regular
2525
2626
2727 func getCollateralInUSD () = fraction(getCollateral(), oracleWavesPriceUSD, 1000000)
2828
2929
3030 func getBackingRatio () = fraction(getCollateralInUSD(), 10000, getCirculatingSupply())
3131
3232
3333 func getHistoricPrice (days_ago) = {
3434 let historic_oracleIndexBlock = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_index_" + toString((oracleIndex - (days_ago * 1440))))), "Error: No historic price data")
3535 let historic_oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString(historic_oracleIndexBlock))), "Error: No historic price data")
3636 historic_oracleWavesPriceUSD
3737 }
3838
3939
4040 func getHistoricPrintLimit (days_ago) = {
4141 let historic_oracleWavesPriceUSD = getHistoricPrice(days_ago)
4242 let historic_twoThirdsPrice = fraction(historic_oracleWavesPriceUSD, 2, 3)
4343 let historic_halfPrice = fraction(historic_oracleWavesPriceUSD, 1, 2)
4444 if ((historic_twoThirdsPrice > getHistoricPrice((1 + days_ago))))
4545 then 0
4646 else if ((historic_twoThirdsPrice > getHistoricPrice((3 + days_ago))))
4747 then 0
4848 else if ((historic_twoThirdsPrice > getHistoricPrice((7 + days_ago))))
4949 then 0
5050 else if ((historic_twoThirdsPrice > getHistoricPrice((14 + days_ago))))
5151 then 0
5252 else if ((historic_twoThirdsPrice > getHistoricPrice((30 + days_ago))))
5353 then 0
5454 else if ((historic_halfPrice > getHistoricPrice((60 + days_ago))))
5555 then 0
5656 else (100000 * 100000000)
5757 }
5858
5959
6060 func getCurrentPrintLimit () = getHistoricPrintLimit(0)
6161
6262
6363 func getTotalPrintedToday () = {
6464 let key = ("total_printed_today" + toString(fraction(height, 1440, 1, DOWN)))
6565 if ((getInteger(key) == unit))
6666 then 0
6767 else valueOrErrorMessage(getInteger(key), "err")
6868 }
6969
7070
7171 @Callable(i)
7272 func constructor () = if ((tokenId != unit))
7373 then throw("Error: Constructor already has been called")
7474 else {
7575 let issue = Issue("Test", "Test", 0, 8, true)
7676 let id = calculateAssetId(issue)
7777 $Tuple2([issue, BinaryEntry("tokenId", id)], unit)
7878 }
7979
8080
8181
8282 @Callable(i)
8383 func swapWavesToTest () = if ((size(i.payments) != 1))
8484 then throw("Error: Only one payment is required")
8585 else {
8686 let pmt = value(i.payments[0])
8787 if (isDefined(pmt.assetId))
8888 then throw("Error: Only Waves token is allowed for swapping")
8989 else if (((getCollateral() + pmt.amount) > collateralLimit))
9090 then throw("Error: Collateral limit exceeded")
9191 else {
9292 let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
9393 let returnAmount = fraction(amountWithoutFee, 995, 1000)
9494 let key = ("total_printed_today" + toString(fraction(height, 1440, 1, DOWN)))
9595 let totalPrintedAfterIssue = (getTotalPrintedToday() + returnAmount)
9696 if ((totalPrintedAfterIssue > getCurrentPrintLimit()))
9797 then throw("Error: Daily swap limit exceeded")
9898 else [IntegerEntry(key, totalPrintedAfterIssue), Reissue(valueOrErrorMessage(tokenId, "Error: no token id"), returnAmount, true), ScriptTransfer(i.caller, returnAmount, tokenId)]
9999 }
100100 }
101101
102102
103103
104104 @Callable(i)
105105 func swapTestToWaves () = if ((size(i.payments) != 1))
106106 then throw("Error: Only one payment is required")
107107 else {
108108 let pmt = value(i.payments[0])
109109 if ((pmt.assetId != tokenId))
110110 then throw("Error: Only Test token is allowed for swapping")
111111 else {
112112 let amountWithoutFee = fraction(pmt.amount, 1000000, oracleWavesPriceUSD)
113113 let br = getBackingRatio()
114114 let share = if ((9900 > br))
115115 then (1000 - ((10000 - br) / 11))
116116 else if ((10500 > br))
117117 then 991
118118 else 995
119119 let returnAmount = fraction(amountWithoutFee, share, 1000)
120120 [Burn(valueOrErrorMessage(tokenId, "Error: no token id"), pmt.amount), ScriptTransfer(i.caller, returnAmount, unit)]
121121 }
122122 }
123123
124124
125125
126126 @Callable(i)
127127 func updateSponsoredFee () = if ((tokenId == unit))
128128 then throw("Error: Constructor has to be called first")
129129 else {
130130 let fee = fraction(oracleWavesPriceUSD, 100, 333)
131131 [SponsorFee(valueOrErrorMessage(tokenId, "Error: no token id"), fee)]
132132 }
133133
134134

github/deemru/w8io/6500d08 
30.40 ms