tx · APw1heca28X7GdCboGNKfYWysp2hXnXPUpXZKF8URjDE

3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx:  -0.01000000 Waves

2023.01.04 01:37 [3454864] smart account 3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx > SELF 0.00000000 Waves

{ "type": 13, "id": "APw1heca28X7GdCboGNKfYWysp2hXnXPUpXZKF8URjDE", "fee": 1000000, "feeAssetId": null, "timestamp": 1672785493872, "version": 1, "sender": "3P8ScM8vDYv3YK1QhFMbF4LsbZTRSowSQLx", "senderPublicKey": "ERKkYKnafViKTn8uQkz9XhvosihQ5XyXkRCm2ztrjZey", "proofs": [ "2vFxk16QkvHSmUB8Fa6MpzsJtezupZvkAKpb2UW8eWvGpW3s2ik2ULQYjHVUYsHhV3Wt5oPNGULiVTXr7dpwUuN6" ], "script": "base64:BgIICAISABIAEgAOAA9wcmljZU9yYWNsZUFkZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNQNUJmZDU4UFBmTnZCTTJIeThRZmJjRHFNZU50emc3S2ZQAA9jb2xsYXRlcmFsTGltaXQJAGgCAICt4gQAgMLXLwALb3JhY2xlSW5kZXgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ9wcmljZU9yYWNsZUFkZHICC3ByaWNlX2luZGV4AhRFcnJvcjogTm8gcHJpY2UgZGF0YQAQb3JhY2xlSW5kZXhCbG9jawkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFD3ByaWNlT3JhY2xlQWRkcgkArAICAgxwcmljZV9pbmRleF8JAKQDAQULb3JhY2xlSW5kZXgCFEVycm9yOiBObyBwcmljZSBkYXRhABNvcmFjbGVXYXZlc1ByaWNlVVNECQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgICBnByaWNlXwkApAMBBRBvcmFjbGVJbmRleEJsb2NrAhRFcnJvcjogTm8gcHJpY2UgZGF0YQAHdG9rZW5JZAkAoQgBAgd0b2tlbklkARBnZXRUb2tlblF1YW50aXR5AAQHJG1hdGNoMAkA7AcBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEUVycm9yOiBObyB0b2tlbklkAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAgFBWFzc2V0CHF1YW50aXR5CQACAQISQ2FuIG5vdCBmaW5kIHRva2VuAQ1nZXRDb2xsYXRlcmFsAAgJAO8HAQUEdGhpcwdyZWd1bGFyARJnZXRDb2xsYXRlcmFsSW5VU0QACQBrAwgJAO8HAQUEdGhpcwdyZWd1bGFyBRNvcmFjbGVXYXZlc1ByaWNlVVNEAMCEPQEPZ2V0QmFja2luZ1JhdGlvAAkAawMJARJnZXRDb2xsYXRlcmFsSW5VU0QAAJBOCQEQZ2V0VG9rZW5RdWFudGl0eQABEGdldEhpc3RvcmljUHJpY2UBCGRheXNfYWdvBBloaXN0b3JpY19vcmFjbGVJbmRleEJsb2NrCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgICDHByaWNlX2luZGV4XwkApAMBCQBlAgULb3JhY2xlSW5kZXgJAGgCBQhkYXlzX2FnbwCgCwIdRXJyb3I6IE5vIGhpc3RvcmljIHByaWNlIGRhdGEEHGhpc3RvcmljX29yYWNsZVdhdmVzUHJpY2VVU0QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgIGcHJpY2VfCQCkAwEFEG9yYWNsZUluZGV4QmxvY2sCHUVycm9yOiBObyBoaXN0b3JpYyBwcmljZSBkYXRhBRxoaXN0b3JpY19vcmFjbGVXYXZlc1ByaWNlVVNEARVnZXRIaXN0b3JpY1ByaW50TGltaXQBCGRheXNfYWdvBBxoaXN0b3JpY19vcmFjbGVXYXZlc1ByaWNlVVNECQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgICBnByaWNlXwkApAMBCQBlAgUQb3JhY2xlSW5kZXhCbG9jawkAaAIFCGRheXNfYWdvAKALAhRFcnJvcjogTm8gcHJpY2UgZGF0YQUcaGlzdG9yaWNfb3JhY2xlV2F2ZXNQcmljZVVTRAEUZ2V0Q3VycmVudFByaW50TGltaXQABAloYWxmUHJpY2UJAGsDBRNvcmFjbGVXYXZlc1ByaWNlVVNEAAEAAgMJAGYCBQloYWxmUHJpY2UJARBnZXRIaXN0b3JpY1ByaWNlAQAHAAADCQBmAgUJaGFsZlByaWNlCQEQZ2V0SGlzdG9yaWNQcmljZQEADgAAAwkAZgIFCWhhbGZQcmljZQkBEGdldEhpc3RvcmljUHJpY2UBAB4AAAkAaAIAoI0GAIDC1y8BFGdldFRvdGFsUHJpbnRlZFRvZGF5AAQDa2V5CQCsAgICE3RvdGFsX3ByaW50ZWRfdG9kYXkJAKQDAQkAbgQFBmhlaWdodACgCwABBQRET1dOAwkAAAIJAJ8IAQUDa2V5BQR1bml0AAAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnwgBBQNrZXkCA2VycgMBaQELY29uc3RydWN0b3IAAwkBAiE9AgUHdG9rZW5JZAUEdW5pdAkAAgECKkVycm9yOiBDb25zdHJ1Y3RvciBhbHJlYWR5IGhhcyBiZWVuIGNhbGxlZAQFaXNzdWUJAMIIBQIEVGVzdAIEVGVzdAAAAAgGBAJpZAkAuAgBBQVpc3N1ZQkAlAoCCQDMCAIFBWlzc3VlCQDMCAIJAQtCaW5hcnlFbnRyeQICB3Rva2VuSWQFAmlkBQNuaWwFBHVuaXQBaQEPc3dhcFdhdmVzVG9UZXN0AAMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECI0Vycm9yOiBPbmx5IG9uZSBwYXltZW50IGlzIHJlcXVpcmVkBANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAMJAQlpc0RlZmluZWQBCAUDcG10B2Fzc2V0SWQJAAIBAi9FcnJvcjogT25seSBXYXZlcyB0b2tlbiBpcyBhbGxvd2VkIGZvciBzd2FwcGluZwMJAGYCCQBkAggJAO8HAQUEdGhpcwdyZWd1bGFyCAUDcG10BmFtb3VudAUPY29sbGF0ZXJhbExpbWl0CQACAQIgRXJyb3I6IENvbGxhdGVyYWwgbGltaXQgZXhjZWVkZWQEEGFtb3VudFdpdGhvdXRGZWUJAGsDCAUDcG10BmFtb3VudAUTb3JhY2xlV2F2ZXNQcmljZVVTRADAhD0EDHJldHVybkFtb3VudAkAawMFEGFtb3VudFdpdGhvdXRGZWUA4wcA6AcDCQBmAgkAZAIJARRnZXRUb3RhbFByaW50ZWRUb2RheQAFDHJldHVybkFtb3VudAkBFGdldEN1cnJlbnRQcmludExpbWl0AAkAAgECIEVycm9yOiBEYWlseSBzd2FwIGxpbWl0IGV4Y2VlZGVkCQDMCAIJAQdSZWlzc3VlAwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQd0b2tlbklkAhJFcnJvcjogbm8gdG9rZW4gaWQFDHJldHVybkFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFB3Rva2VuSWQFA25pbAFpAQ9zd2FwVGVzdFRvV2F2ZXMAAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABCQACAQIjRXJyb3I6IE9ubHkgb25lIHBheW1lbnQgaXMgcmVxdWlyZWQEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAAwkBAiE9AggFA3BtdAdhc3NldElkBQd0b2tlbklkCQACAQIuRXJyb3I6IE9ubHkgVGVzdCB0b2tlbiBpcyBhbGxvd2VkIGZvciBzd2FwcGluZwQQYW1vdW50V2l0aG91dEZlZQkAawMIBQNwbXQGYW1vdW50AMCEPQUTb3JhY2xlV2F2ZXNQcmljZVVTRAQCYnIJAQ9nZXRCYWNraW5nUmF0aW8ABAVzaGFyZQMJAGYCAKxNBQJicgkAZQIA6AcJAGkCCQBlAgCQTgUCYnIACwMJAGYCAIRSBQJicgDfBwDjBwQMcmV0dXJuQW1vdW50CQBrAwUQYW1vdW50V2l0aG91dEZlZQUFc2hhcmUA6AcJAMwIAgkBBEJ1cm4CCQETdmFsdWVPckVycm9yTWVzc2FnZQIFB3Rva2VuSWQCEkVycm9yOiBubyB0b2tlbiBpZAgFA3BtdAZhbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxyZXR1cm5BbW91bnQFBHVuaXQFA25pbACcQSzg", "chainId": 87, "height": 3454864, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 7bYhJxByYftZdK35nQrnNZcpa4GFJR732CwcvvkxvKWz Next: DQEGrEG5R9r29dD9U5q1k4NWuVUQDbBnLZvaTgUaXsAw Diff:
OldNewDifferences
99
1010 let oracleIndexBlock = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_index_" + toString(oracleIndex))), "Error: No price data")
1111
12-let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString((oracleIndexBlock - (7 * 1440))))), "Error: No price data")
12+let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString(oracleIndexBlock))), "Error: No price data")
1313
1414 let tokenId = getBinary("tokenId")
1515
3737 }
3838
3939
40+func getHistoricPrintLimit (days_ago) = {
41+ let historic_oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString((oracleIndexBlock - (days_ago * 1440))))), "Error: No price data")
42+ historic_oracleWavesPriceUSD
43+ }
44+
45+
4046 func getCurrentPrintLimit () = {
41- let halfPrice = fraction(oracleWavesPriceUSD, 2, 1)
47+ let halfPrice = fraction(oracleWavesPriceUSD, 1, 2)
4248 if ((halfPrice > getHistoricPrice(7)))
4349 then 0
4450 else if ((halfPrice > getHistoricPrice(14)))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let priceOracleAddr = addressFromStringValue("3P5Bfd58PPfNvBM2Hy8QfbcDqMeNtzg7KfP")
55
66 let collateralLimit = (10000000 * 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
12-let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString((oracleIndexBlock - (7 * 1440))))), "Error: No price data")
12+let oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString(oracleIndexBlock))), "Error: No price data")
1313
1414 let tokenId = getBinary("tokenId")
1515
1616 func getTokenQuantity () = match assetInfo(valueOrErrorMessage(tokenId, "Error: No tokenId")) {
1717 case asset: Asset =>
1818 asset.quantity
1919 case _ =>
2020 throw("Can not find token")
2121 }
2222
2323
2424 func getCollateral () = wavesBalance(this).regular
2525
2626
2727 func getCollateralInUSD () = fraction(wavesBalance(this).regular, oracleWavesPriceUSD, 1000000)
2828
2929
3030 func getBackingRatio () = fraction(getCollateralInUSD(), 10000, getTokenQuantity())
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(oracleIndexBlock))), "Error: No historic price data")
3636 historic_oracleWavesPriceUSD
3737 }
3838
3939
40+func getHistoricPrintLimit (days_ago) = {
41+ let historic_oracleWavesPriceUSD = valueOrErrorMessage(getInteger(priceOracleAddr, ("price_" + toString((oracleIndexBlock - (days_ago * 1440))))), "Error: No price data")
42+ historic_oracleWavesPriceUSD
43+ }
44+
45+
4046 func getCurrentPrintLimit () = {
41- let halfPrice = fraction(oracleWavesPriceUSD, 2, 1)
47+ let halfPrice = fraction(oracleWavesPriceUSD, 1, 2)
4248 if ((halfPrice > getHistoricPrice(7)))
4349 then 0
4450 else if ((halfPrice > getHistoricPrice(14)))
4551 then 0
4652 else if ((halfPrice > getHistoricPrice(30)))
4753 then 0
4854 else (100000 * 100000000)
4955 }
5056
5157
5258 func getTotalPrintedToday () = {
5359 let key = ("total_printed_today" + toString(fraction(height, 1440, 1, DOWN)))
5460 if ((getInteger(key) == unit))
5561 then 0
5662 else valueOrErrorMessage(getInteger(key), "err")
5763 }
5864
5965
6066 @Callable(i)
6167 func constructor () = if ((tokenId != unit))
6268 then throw("Error: Constructor already has been called")
6369 else {
6470 let issue = Issue("Test", "Test", 0, 8, true)
6571 let id = calculateAssetId(issue)
6672 $Tuple2([issue, BinaryEntry("tokenId", id)], unit)
6773 }
6874
6975
7076
7177 @Callable(i)
7278 func swapWavesToTest () = if ((size(i.payments) != 1))
7379 then throw("Error: Only one payment is required")
7480 else {
7581 let pmt = value(i.payments[0])
7682 if (isDefined(pmt.assetId))
7783 then throw("Error: Only Waves token is allowed for swapping")
7884 else if (((wavesBalance(this).regular + pmt.amount) > collateralLimit))
7985 then throw("Error: Collateral limit exceeded")
8086 else {
8187 let amountWithoutFee = fraction(pmt.amount, oracleWavesPriceUSD, 1000000)
8288 let returnAmount = fraction(amountWithoutFee, 995, 1000)
8389 if (((getTotalPrintedToday() + returnAmount) > getCurrentPrintLimit()))
8490 then throw("Error: Daily swap limit exceeded")
8591 else [Reissue(valueOrErrorMessage(tokenId, "Error: no token id"), returnAmount, true), ScriptTransfer(i.caller, returnAmount, tokenId)]
8692 }
8793 }
8894
8995
9096
9197 @Callable(i)
9298 func swapTestToWaves () = if ((size(i.payments) != 1))
9399 then throw("Error: Only one payment is required")
94100 else {
95101 let pmt = value(i.payments[0])
96102 if ((pmt.assetId != tokenId))
97103 then throw("Error: Only Test token is allowed for swapping")
98104 else {
99105 let amountWithoutFee = fraction(pmt.amount, 1000000, oracleWavesPriceUSD)
100106 let br = getBackingRatio()
101107 let share = if ((9900 > br))
102108 then (1000 - ((10000 - br) / 11))
103109 else if ((10500 > br))
104110 then 991
105111 else 995
106112 let returnAmount = fraction(amountWithoutFee, share, 1000)
107113 [Burn(valueOrErrorMessage(tokenId, "Error: no token id"), pmt.amount), ScriptTransfer(i.caller, returnAmount, unit)]
108114 }
109115 }
110116
111117

github/deemru/w8io/6500d08 
34.81 ms